From 01dcd4e95e8b4c14309d12dd86d49ccf35177aa1 Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 18:11:42 -0500 Subject: [PATCH 1/7] fix(aws-codepipeline-actions): update zip to noncorrupted one --- .../test/assets/nodejs.zip | Bin 4928 -> 3092 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/assets/nodejs.zip b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/assets/nodejs.zip index e8db142cdf85d7fbbfaca296005556392754e1f7..4810a50d131d9dbf56c6a43f1c11887031ce794b 100644 GIT binary patch literal 3092 zcma);c{G&!AIBfY%-ESij8d|cHA5vL!eH!)D22fo!!TpZATqhg9V1!el8j`@Hb~YY zp%kJtSx2%|whC9`>NoDar>pDM`JLx{pYuHbyuPpVdCvF!ysb<@96|s9Z~{qJsaB6& za#Wyf05Hc|BEU`nsdp0XO~hl46NyR|1UHPQzcS7nZ)?K^fFS%Sjtcszj)5c|fQ^H{ z#(xLL(@>Ca*i}nY5JKqT{2xM+i*<(0k&k?MdQ0}7i|QStKkW44b6-eJyIIW~nPKiV zCXiRm-DOcz`5om_3C}&$!h`&uh`rjDQXLaVP=7K`?#3on=?U|yTr8D*vwP)vDai?M zr*YqYeg*%){)~%lE_gaU#nvs`H%|wZ2w||png@)G%Al%|f-=zXBTh}Z2PG3jy+==6 z#-%klG!*A&#`ee?667^q2aV#Q)=QQlI>@8m)VDmi3AW2>-uEM_Ea95BtS>b)nz2JC zBhZjclkGx_1J9&o?U_TnW6sTI?v=YS6r#C2KhS_IW+~u&+%P0%kAS}&-2dC5&#pOs@UURxvcfF~ zp+*C1d>KslgiXx|@&FRPhfPF7tjZV_CuhB!rpK$@{F$@|pXjYj{gy0n}s8S&^EmA@0->ZWqPwQFX(cbc3110_NMSxM2aW zh!R@pXA%i`lx(FLo$a?AqA}nv+eN!ZFd19Luxzk3?GeEmTF8*xurEF4oS?dF->tTq$DFgciV0g^N7hyAioAV)UY z@AN|zY+n>fM{lY1p>8!qU1>r7MBorCTQOrt9u>W^HubpL_GQug*j(pY?Q8K-l9zT| zd&<^$q2nk~3|kqi^&kmv=h0^j=l#-PUz|!Agsq$<-?4LfQmEugqAwax>A}Qz(?!w8 zBxiLv11<8U2EkdG*VE)36-5{ezs0^opXlle=%$zH98=gb6`FyqQ9h52Lr!29)kOoQlt8Y9gftV9KAzRTyu_i zac4BW1@N)DD-s|jBO>6@AEZ*0qANDrAPSb9uRT@a(#xLaY&xl09Odb;txqB*NQPaa zR$TDr)zh&mN_Qu~X9(rRJG+SnW_y#zZFbI!j~A+0&YQSgM0|kXSryJpzYyzi5#UwS{@dlK)@m!0}=%6g8ys5lX z%Vtdfm$EQa5~qK-IeU7d*zJ2y4>~JNf^W|%P2-1 zsaAj0mP&lQm~-up+CsaJJq*QWFfvOMR$#@FIKXRJwk6868aBsI4Qw`BD@;e(x%Dw3#-nzm`D+7!?W<*G1W zYeT~hvrGYC!~M^Pzi<33cV&zV zh7^GD@y8K-{11GySKRvZ_*VX;9#rJvuVKm7;uht6Clex(pI$43&!j|E(>ZuNypwYMw{<#}rV5CYLL&t#`|)tL z?8E}hK1%mF3_@hxK^i;wlB(puV5Zr4RpYa&3VuD1(zetyPA@PcALw;Js$QXKdp+yy z3Oz5IUxYxwE8006nIEn1C}qGTbL%=YiyWwOgVHe+IZ>@9EK+n|V#ex{pLw-v{Sh)3 zr}2so8Tg&4L+uU=v7CQ4*Hgj%RWZHt?1R7>N~pQu0#E*$8DqMr`nAPNW6a4W7dk*c zQ>so2`q2LT;-S{7{d&ae^%3YNePoU?eev}~aDRF}qA44=rnpCRD)L?O8r!2l_(JK4 z#v)_-mRQ(Hlk_OtYej48d@56a2UD5%LDuzk9-9}+v=($ee$;FPb%$2+va z4bWsQWshNjkBLQ*ro)vA*7MFb)Gp#_V1dY`ce(W;K3szC%ml@xtSLW2L2V8KQsJMaQ#ID06}2(I1&PEiLswC|N1~1mfwfiW=rZ8 m=D#ED|J&jFsM)*&3JQD+o*%KmEDHdDvMx(jT$OQcy!{W?L(&WY literal 4928 zcmb7Ii%(nE8NbFDjDZjnAYc+g5+31YAcPPI1i~xCgl9}hAOvhM#$arNO)wCkTGdHa zyGeaUk(N$Ns;SGgbZysY(o{`a)@{v}wavC>)i!05CT&_PO;i7Y{eFCR7l%OU#P55Y z?_Qtto$qmuO?SIKIz>?wqw?>cz9;C0aDvKWbqcNEY04g@rSYs|I^cDk3$KR7g` z4Mmws9RK3gtFLdc9%%E6rDHtrG_-p^JSgLdik0~w)C^Fvn1uVQw2@o1#?*weRjBl1 zALw_t!^7VGYG~&{fS2lkvk$`X*|k^t#-PlA>bYVJD9Q{5oH_*-dl+nIZtTjjVX+?J z#7om)Js^)52Sr5k!d8D_%_uCKB@!|9EywwBAf6xBfhtr3)GkX6crQo;cXk%!pm(-i z>%q>+Q}@J;4uK97fB}n~L-5P5Epn^EpUV3A*a=wcu6S!#s zOmNO*%N6a@uiF~T2IvoN>=Db#%xvqV&C@w)YGxD+HcvqVWb$rh-PL$`m9;)q89$|0 zl%@nlF~MDrZ_E|8PJ~o{$G_ZPe7;|%0zbM_)FOyMF5TSAIx;u(*yTY>X^SOWmsZUR zZDS=B^k&PGMG;G^18!^z#Q5h-B&I_E6|DMN(Jza*|82;5(ZL%%Tv)?Cg)10AX_}2u z1We9iQL5AqZ2tVkH(>ea_2VjbE3+^xvQL7!>(z+iazfGlXTvcp z6+P(4Di|x0tw|{uOJZ`fG>jtE`F9r6QCAzsf;ow^V}8}^qeuS0aS>v9f7>UZ2_~~Nq!Po z9!D3z%G`f=CS1=N5wOr=s!G5Md*;BoO~!gR2%u|%5AO7Ra_e8u-dx+WX63P=zRHfj z0y-YZPy<-|vzNU66EL+|)R3r+4HLknE{fXk{Pp)rM#C~_gJ?8ovis8=C%8hrajp}B zxnbjID7;j>UMdcrTtMi4W!jzIgN6 z>+}cMtBN_MHIxIU(1+M^Fb9Z<&taaz$%$1AA9H^9WiTL%2dnWn-i`vov8Do>hV7GY4d3=P(mg!8qES ztBekV0;GxnXE!pN2W`<^ySV%~C=xXoaK^*Cz?jO^1v|a7ug`ILBx8T|xVITrAPzL* z;1Mz`25#;Qi1%oonJF^{S30;BpoT#PBLT>x3G5FI1ERG;=vK&H~hqnnSe%Y&V#Ae-3sfO-OP!vZISK6QN?7%plLp$w<$AH6Ata%Q*+^ov*NVkFe2 z_MJDM)}3lc3CHbe&5=ct!*w)9;xL#d}&V_c}(y-UT+2hKD~E zRV^t!Mpn@BOm8a#&I$$+m})yK4CqV;YY-j$u5ifZ3wr#%U};2{ikZyKzLP#4dAbPXjblzo@I6n=>h-(b9-rGf>i3O%+!1SR z`Mp;rJ#K<*NZ>(R$C6?t@oSUem&|APA=fQMwV1K@obp%3i?`<{>-8%|e z2K8og|A}Y807e%mTKW8yXGD#TpJ14QAkXGYq9|_ z4gSeDN(LbwUA0d^ctILUH4Vz&-+F`1PTOFM+H!ULh+ye*o+#zz+#?XJ`qK-Y2{$uM z!2NH5aY-hU7bey8T5xwuy6T}=XFDLd6q6fgWM{Ff)C^MvmKVE30sr`Ic7CypFG9?T zy41nDDqaTM#b>wffHS&nE{2!qFQ**<@oeRlAy}<^{{?7`>t`)1wTa14J6+ye`1BeS zRwTfwinH1D0;XV&Vd>FKqMV_V0)q(lD(fQ>jWV!8eDoX(WVbn=RW0B*1mJu~jeFZk zjOsWYJ*~B}8^74dn!Auh@(!-f3tIpa#aHfe``@ z@jZIlnqgUhpi977m>>%{J>UhgK2ky~PvHJdu?PSNl9atp*hg<#k z!SKKTK5X)ThsYH-`)RsyoqjAC@naQJ%U!$8)N0o-k&pe9+&Dd+V}Zz@msml5UT(9( z7GDlFS-_xd_`N-X}maQk86IFA1dvya}i From 443bb7fde2f67ba8774d9d68f9dc40b15e95b88e Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 18:46:33 -0500 Subject: [PATCH 2/7] update snapshots --- ...eline-elastic-beanstalk-deploy.assets.json | 10 +- ...ine-elastic-beanstalk-deploy.template.json | 2 +- .../manifest.json | 2 +- ...7a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip | Bin 0 -> 4540 bytes ...e782b91873a033a2af81afb07f38cf38ec67ea.zip | Bin 0 -> 310 bytes packages/@aws-cdk/aws-batch-alpha/.jsii | 15284 ++++++++++++++++ .../aws-batch-alpha/.warnings.jsii.js | 515 + .../lib/compute-environment-base.d.ts | 87 + .../lib/compute-environment-base.js | 20 + .../lib/ecs-container-definition.d.ts | 726 + .../lib/ecs-container-definition.js | 531 + .../lib/ecs-job-definition.d.ts | 67 + .../aws-batch-alpha/lib/ecs-job-definition.js | 102 + .../lib/eks-container-definition.d.ts | 728 + .../lib/eks-container-definition.js | 338 + .../lib/eks-job-definition.d.ts | 123 + .../aws-batch-alpha/lib/eks-job-definition.js | 134 + .../@aws-cdk/aws-batch-alpha/lib/index.d.ts | 12 + .../@aws-cdk/aws-batch-alpha/lib/index.js | 29 + .../lib/job-definition-base.d.ts | 217 + .../lib/job-definition-base.js | 153 + .../aws-batch-alpha/lib/job-queue.d.ts | 140 + .../@aws-cdk/aws-batch-alpha/lib/job-queue.js | 102 + .../aws-batch-alpha/lib/linux-parameters.d.ts | 196 + .../aws-batch-alpha/lib/linux-parameters.js | 175 + .../lib/managed-compute-environment.d.ts | 806 + .../lib/managed-compute-environment.js | 451 + .../lib/multinode-job-definition.d.ts | 107 + .../lib/multinode-job-definition.js | 104 + .../lib/scheduling-policy.d.ts | 188 + .../aws-batch-alpha/lib/scheduling-policy.js | 101 + .../lib/unmanaged-compute-environment.d.ts | 47 + .../lib/unmanaged-compute-environment.js | 70 + .../test/aws-events-targets/batch.test.d.ts | 1 + .../test/aws-events-targets/batch.test.js | 294 + .../run-batch-job.test.d.ts | 1 + .../run-batch-job.test.js | 286 + .../submit-job.test.d.ts | 1 + .../submit-job.test.js | 401 + .../test/ecs-container-definition.test.d.ts | 1 + .../test/ecs-container-definition.test.js | 998 + .../test/ecs-job-definition.test.d.ts | 1 + .../test/ecs-job-definition.test.js | 147 + .../test/eks-container-definition.test.d.ts | 1 + .../test/eks-container-definition.test.js | 712 + .../test/eks-job-definition.test.d.ts | 1 + .../test/eks-job-definition.test.js | 72 + .../test/integ.batch-unique-name.d.ts | 1 + .../test/integ.batch-unique-name.js | 34 + .../test/integ.ecs-job-definition.d.ts | 1 + .../test/integ.ecs-job-definition.js | 94 + .../test/integ.eks-job-definition.d.ts | 1 + .../test/integ.eks-job-definition.js | 59 + .../aws-batch-alpha/test/integ.grants.d.ts | 1 + .../aws-batch-alpha/test/integ.grants.js | 35 + .../aws-batch-alpha/test/integ.job-queue.d.ts | 1 + .../aws-batch-alpha/test/integ.job-queue.js | 41 + .../integ.managed-compute-environment.d.ts | 1 + .../test/integ.managed-compute-environment.js | 78 + .../test/integ.multinode-job-definition.d.ts | 1 + .../test/integ.multinode-job-definition.js | 48 + .../integ.unmanaged-compute-environment.d.ts | 1 + .../integ.unmanaged-compute-environment.js | 25 + .../test/job-definition-base.test.d.ts | 1 + .../test/job-definition-base.test.js | 205 + .../aws-batch-alpha/test/job-queue.test.d.ts | 1 + .../aws-batch-alpha/test/job-queue.test.js | 228 + .../managed-compute-environment.test.d.ts | 1 + .../test/managed-compute-environment.test.js | 860 + .../test/multinode-job-definition.test.d.ts | 1 + .../test/multinode-job-definition.test.js | 155 + .../test/scheduling-policy.test.d.ts | 1 + .../test/scheduling-policy.test.js | 133 + .../unmanaged-compute-environment.test.d.ts | 1 + .../unmanaged-compute-environment.test.js | 90 + .../@aws-cdk/aws-batch-alpha/test/utils.d.ts | 6 + .../@aws-cdk/aws-batch-alpha/test/utils.js | 28 + .../@aws-cdk/aws-batch-alpha/tsconfig.json | 53 + .../test/workers/integ-worker.test.ts | 4 +- 79 files changed, 26665 insertions(+), 9 deletions(-) create mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip create mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip create mode 100644 packages/@aws-cdk/aws-batch-alpha/.jsii create mode 100644 packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/index.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts create mode 100644 packages/@aws-cdk/aws-batch-alpha/test/utils.js create mode 100644 packages/@aws-cdk/aws-batch-alpha/tsconfig.json diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json index f385825f1f871..0d246ebffb760 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json @@ -40,20 +40,20 @@ } } }, - "a69ee80d8b447031cda0ebb680c4b77d8ad701ea4b043f241da243fa6e34f9b7": { + "6a9a0507c3e2bfac9749f257bdd3d9f313c01ee3984ad7bf373597c341863d6f": { "source": { - "path": "asset.a69ee80d8b447031cda0ebb680c4b77d8ad701ea4b043f241da243fa6e34f9b7.zip", + "path": "asset.6a9a0507c3e2bfac9749f257bdd3d9f313c01ee3984ad7bf373597c341863d6f.zip", "packaging": "file" }, "destinations": { "current_account-current_region": { "bucketName": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}", - "objectKey": "a69ee80d8b447031cda0ebb680c4b77d8ad701ea4b043f241da243fa6e34f9b7.zip", + "objectKey": "6a9a0507c3e2bfac9749f257bdd3d9f313c01ee3984ad7bf373597c341863d6f.zip", "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}" } } }, - "8ef1242d08beb235d6de8a49a1da6b3c01b739b93cb0125ff17f3b68e5984c8e": { + "c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55": { "source": { "path": "aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json", "packaging": "file" @@ -61,7 +61,7 @@ "destinations": { "current_account-current_region": { "bucketName": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}", - "objectKey": "8ef1242d08beb235d6de8a49a1da6b3c01b739b93cb0125ff17f3b68e5984c8e.json", + "objectKey": "c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}" } } diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json index 82b5cf0897a09..3fabf1dc5a284 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json @@ -175,7 +175,7 @@ } ], "SourceObjectKeys": [ - "a69ee80d8b447031cda0ebb680c4b77d8ad701ea4b043f241da243fa6e34f9b7.zip" + "6a9a0507c3e2bfac9749f257bdd3d9f313c01ee3984ad7bf373597c341863d6f.zip" ], "DestinationBucketName": { "Ref": "PipelineBucketB967BD35" diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json index 56c6ce44c290b..169010b153254 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json @@ -17,7 +17,7 @@ "validateOnSynth": false, "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", - "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/8ef1242d08beb235d6de8a49a1da6b3c01b739b93cb0125ff17f3b68e5984c8e.json", + "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", "requiresBootstrapStackVersion": 6, "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", "additionalDependencies": [ diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip b/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip new file mode 100644 index 0000000000000000000000000000000000000000..cb2790cf47f87701182d2d185a3bef4ec4634d2b GIT binary patch literal 4540 zcmV;t5ku}!O9KQH00;mG0000X00000000000000000;m80BLSyWq2-ddBt0AbK5v` zf3Humr6xn_F|Az3ebLd3I+MreJoUtJTs!Vft9m#vxsq_E06qk0S;^(QcNTw0K$ddX z>ooO?NFo=D-Nj<@+r@@&8rf;6~w z*tD`l)xX!cX_mak(Xy2r=-RsGkJA?a-l5XqCc3phb9yZs6ppszm8a-BUj37O{Dm8S z{>^{#<~_0Z5_G8&b&?5bre zg@!p8e$%q%D0G$%uhPj#oxOUm&eF+fbpHOjxVt|;zqq@DIVA3DVxGT$cX@U3Gd;H7 zlF`NWzZV}a{-gN#>Hhk2ar5r;ztY>`*FbUi;qs<9zq)vLeSc#Z2fvfi=-n@O#rf4` zasKK0{pH_^_m@`}MDD)fGGG*$~LWR zu+&#MMaBEKRd zS{aMSu6#mW2)02|!HBjl?Lfj#*{22G1g{<0^-D<&UscVh_C z9MW`H6q?%m2z~c|&XiW83+qHQRJR?b6PVB4*GR7xHRGa?qOe{|%pyj&hTxO<**JBY zLqhx#!_R(=_*Go#mOq-kNnZ1c-_HTTWpzNcPGMVYP_v3@=5&iBx>wkKbnnyHUx{4p zl*UcWAsT;Y2)@IiX*+>#X8#d!xFLeUw9{H{vCWQ|7+=b|t73)`y9-N@=CF8(mzj&- z8G3064h*HROlPJ>p${r?$5-Oqz9&_dtX7y#4(JlC?-(9g`LtzirJ$6XhH3uDYp!>2 zN^vxac2Yv81RW%*!ICdIR{0(?rc}2w2L~PZVrpD-^`)F=_F{GSYcM9$PPrO$s`EO#IM37>uOy@UfwXhhIter z>;~VLm@ILW!xTlO=vd5>w@CmZyc$Ob!U-Xzo4IglKL5Ph|492c9pt)qjmEvLr{*2#0 zhvh0vU2Su>@CihKya7o^%P&Y(keRyaAU>E?ov%#+{kAhKVXmdL@$_5`~&R+*(c5*|cH1TC%Djj$Et?6zs9aim2=f6B^6 z&Sr1lzEN*2zR&tslibIv5dHKI15^|EjyfwyI?8MI_=ZB;Il?E_GJ_8i06fmChlgg1 zC9hxzfiYT?WRk=0(e{wV4)7TUx!4%w<1?3?s&{fAEtq z1xS7ar?cOq?&n~aJ@SCF9}+x@k^#Pitxb~*@~4f;K;X8=>^U82vSb=5OL8d~@X8)M zgVtk^dX4RtE6j-{zBE|sXoQxONwrwB9aiwT+si~k1ICHQ9FlXBm+V>4i(^4OrOeZ^ zdYY=U3Y%K)HYoJe`Y#1FQ@_Xpuf$sIg-){{2cZjI#Y;xZAB0yfo>|Q+AG~J%3z+*@w(?Z}Q{g z<}r2)_8g_;eiQe8PUySh)SqG-i84@|cGKfWaK!t&X`;<-u}T5b>ydW{X)rGtK5- zBexpE4YSZsuUpxzY>DdK?KLP`0#TxZ3L6v^eMbdSxLx4`XT(LW9F{#A~90WX4 zO*h0PbKLBK5W}EhB7bW{W9WP40@xndbOSul>{%Nf1KWj`(h|07Ual=rv_)dFzN_*m zkV~@~UwC62+wk%)i;A~%pB(-wx$x@bka`+dWb768&uOevBP!~Sp^{rcS)7@dwdI;W zqc7W|OL>g@_=2UDK#3t$rPNTfpc?&tIVMWGCV{`waT_@!7?cnsX$wA7zlqw{e(V80 z_ot^BOlqF5nn>2XH@M4?2MC%EltQLE{{bj*lk& z&7a&RV{yx+B?<9gf}pft8oT0NY5%#$%h}JX;3G?9OB(8oSujx*EjBePv2ethliOXe z39V@6+^<+{j(E!*5vr8U?$2rW2Q3|&s8@CjY9~tT`-6wmF%n?r!OzrLQQATY%wdsO z$W9!Rz!~|{LbA{ehk;Yp5ERLh(^HGUeds02P%yP+;YqQ2Bd3#3p_H1wp~u zmCC*kjf3;Pu=Q;R9U|X!}{=LH4o)1 zcyRe}X-g3H#*XQ7y_X22wzxclI6t6`mHu1Dgywpe&J3)I=CBz{4ByS5OS)=KX9x0| zUUs7U77tC&SzTj$i%V=N<49)_LK%o1&L2~G$dy=g*z&rDE#n%xhT_ma{sbE?I_<8J zhjk)kR1hJySsEIaLR3Q;bCph}MDQmpUCkqow4jSLw14`rNH43DBFYcS02FHQ7mU_r zO_^*jBD8E<>_r87w0FJe_O658uf~`=!JiBQA`E_r0TqsZ8Umv&SHZ#^1549!usur1YNEyiD%=G4eWQbc%YXOLCwNwQ1FDn%74UHmqe@ zwrZZGIbF@p(#hn3PIPji$OaSm7x)PX7xfO~{3q1pg!*t=bI!pDgo2#f^nz-FIV86i zH&^e@F9?DBpq*&jcu-NoM}_Fb+=V&(VYX&;+>$BXhGSbbPu|K#Q-4@lbNWbNZ1LB- ztvavy72CON;Dnt$KhHlYVE8`bSxb zI>M;i%2%!^n8)o%Hi{i<9`obwG}E2huYi3!STdsyu^fcFDA#iSo_YiN#xvLDW;UH? zec#r;L5Mn=`gSqj+2rZ|Dk}Uitv@UQ_!hnu$2j6x0LfXz42z5VG_R zZ9Sr*rj=UJ{x-1X7dqqNO0M9JZW1>$Na4iy^i6BIDwKI{nv$#=#Ihaeq9ZwdVbM2I zT~;KAfut{bpYH)R?ldc(=J(0C28ZsyS$U%hhi?IxgEMpHWxH?doKVDCR`c}c{&SiGH7v~^ zcN&#pJ4I2-3bVA+%hP{OCzBkUeFm>p!sJ&=JR8wwtLjh{0Hl|rpGn;4LWl}Ptk`WQqPhe#NC_0orzo7 zs0RGQju#WZ>EN`rTe>HH8I-oC)OUA`#ze_AQRy`bs ztvWN{-ifK1X@wt9Jh`5|cbEsl8;101@K1*-nAm06%Od%JyX0XSG!bdGnoJBbdNEkg z-dHV?&un#vI&paDkNKPTVbeDaE7u64*~%5_t)#!>V=hp9GQ@OU*?PHYBQoeHl)zMgf{Pq7a?p0f z6;;Z6PLr8A4Y}xS_1-QDElXSm><0v;KV$bpg!W$Cmm96!Oi$G_w%SypD_&}Sit-y_CuR=c!)OpRwOc@E~Cu&TO9u$F`T<=!5dZ)qGynil zO928c0~7!V00;m803iUh`T<=!5dZ)qGynhy000000000003ZOQfdBvi0BLSyWq2-d ac~DCQ1^@s60096205$*s0B{ii00014ZoSF? literal 0 HcmV?d00001 diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip b/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip new file mode 100644 index 0000000000000000000000000000000000000000..3cf3517aadf3c86fe0b7520aa3a9693e6b601fcd GIT binary patch literal 310 zcmWIWW@Zs#-~d7f21Ou700$t`)Xc=xz|_FN(AXl?Fv-Niz%nH%$uu$1GAY^AFgZEJ zFx4O_*}%ZWB-t#{#MC&+#2_WjJk>PO(A>zx#N5O{ThCWZ@1%~V?#VOfx%E7OjBP<0 zZbFxJ^?d#OboKnS&jvm@<$1=}%d\n\n---\n\n![cdk-constructs: Developer Preview](https://img.shields.io/badge/cdk--constructs-developer--preview-informational.svg?style=for-the-badge)\n\n> The APIs of higher level constructs in this module are in **developer preview** before they\n> become stable. We will only make breaking changes to address unforeseen API issues. Therefore,\n> these APIs are not subject to [Semantic Versioning](https://semver.org/), and breaking changes\n> will be announced in release notes. This means that while you may use them, you may need to\n> update your source code when upgrading to a newer version of this package.\n\n---\n\n\n\nThis module is part of the [AWS Cloud Development Kit](https://github.com/aws/aws-cdk) project.\n\nAWS Batch is a batch processing tool for efficiently running hundreds of thousands computing jobs in AWS.\nBatch can dynamically provision [Amazon EC2](https://aws.amazon.com/ec2/) Instances to meet the resource requirements of submitted jobs\nand simplifies the planning, scheduling, and executions of your batch workloads. Batch achieves this through four different resources:\n\n* ComputeEnvironments: Contain the resources used to execute Jobs\n* JobDefinitions: Define a type of Job that can be submitted\n* JobQueues: Route waiting Jobs to ComputeEnvironments\n* SchedulingPolicies: Applied to Queues to control how and when Jobs exit the JobQueue and enter the ComputeEnvironment\n\n`ComputeEnvironment`s can be managed or unmanaged. Batch will automatically provision EC2 Instances in a managed `ComputeEnvironment` and will\nnot provision any Instances in an unmanaged `ComputeEnvironment`. Managed `ComputeEnvironment`s can use ECS, Fargate, or EKS resources to spin up\nEC2 Instances in (ensure your EKS Cluster has [been configured](https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html)\nto support a Batch ComputeEnvironment before linking it). You can use Launch Templates and Placement Groups to configure exactly how these resources\nwill be provisioned.\n\n`JobDefinition`s can use either ECS resources or EKS resources. ECS `JobDefinition`s can use multiple containers to execute distributed workloads.\nEKS `JobDefinition`s can only execute a single container. Submitted Jobs use `JobDefinition`s as templates.\n\n`JobQueue`s must link at least one `ComputeEnvironment`. Jobs exit the Queue in FIFO order unless a `SchedulingPolicy` is specified.\n\n`SchedulingPolicy`s tell the Scheduler how to choose which Jobs should be executed next by the ComputeEnvironment.\n\n## Use Cases & Examples\n\n### Cost Optimization\n\n#### Spot Instances\n\nSpot instances are significantly discounted EC2 instances that can be reclaimed at any time by AWS.\nWorkloads that are fault-tolerant or stateless can take advantage of spot pricing.\nTo use spot spot instances, set `spot` to `true` on a managed Ec2 or Fargate Compute Environment:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\nnew batch.FargateComputeEnvironment(this, 'myFargateComputeEnv', {\n vpc,\n spot: true,\n});\n```\n\nBatch allows you to specify the percentage of the on-demand instance that the current spot price\nmust be to provision the instance using the `spotBidPercentage`.\nThis defaults to 100%, which is the recommended value.\nThis value cannot be specified for `FargateComputeEnvironment`s\nand only applies to `ManagedEc2EcsComputeEnvironment`s.\nThe following code configures a Compute Environment to only use spot instances that\nare at most 20% the price of the on-demand instance price:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n spot: true,\n spotBidPercentage: 20,\n});\n```\n\nFor stateful or otherwise non-interruption-tolerant workflows, omit `spot` or set it to `false` to only provision on-demand instances.\n\n#### Choosing Your Instance Types\n\nBatch allows you to choose the instance types or classes that will run your workload.\nThis example configures your `ComputeEnvironment` to use only the `M5AD.large` instance:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\n\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE)],\n});\n```\n\nBatch allows you to specify only the instance class and to let it choose the size, which you can do like this:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\n\ndeclare const computeEnv: batch.IManagedEc2EcsComputeEnvironment\ncomputeEnv.addInstanceClass(ec2.InstanceClass.M5AD);\n// Or, specify it on the constructor:\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.R4],\n});\n```\n\nUnless you explicitly specify `useOptimalInstanceClasses: false`, this compute environment will use `'optimal'` instances,\nwhich tells Batch to pick an instance from the C4, M4, and R4 instance families.\n*Note*: Batch does not allow specifying instance types or classes with different architectures.\nFor example, `InstanceClass.A1` cannot be specified alongside `'optimal'`,\nbecause `A1` uses ARM and `'optimal'` uses x86_64.\nYou can specify both `'optimal'` alongside several different instance types in the same compute environment:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE)],\n useOptimalInstanceClasses: true, // default\n vpc,\n});\n// Note: this is equivalent to specifying\ncomputeEnv.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE));\ncomputeEnv.addInstanceClass(ec2.InstanceClass.C4);\ncomputeEnv.addInstanceClass(ec2.InstanceClass.M4);\ncomputeEnv.addInstanceClass(ec2.InstanceClass.R4);\n```\n\n#### Allocation Strategies\n\n| Allocation Strategy | Optimized for | Downsides |\n| ----------------------- | ------------- | ----------------------------- |\n| BEST_FIT | Cost | May limit throughput |\n| BEST_FIT_PROGRESSIVE | Throughput | May increase cost |\n| SPOT_CAPACITY_OPTIMIZED | Least interruption | Only useful on Spot instances |\n| SPOT_PRICE_CAPACITY_OPTIMIZED | Least interruption + Price | Only useful on Spot instances |\n\nBatch provides different Allocation Strategies to help it choose which instances to provision.\nIf your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment`\nand use `SPOT_PRICE_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled).\nThis will tell Batch to choose the instance types from the ones you’ve specified that have\nthe most spot capacity available to minimize the chance of interruption and have the lowest price.\nTo get the most benefit from your spot instances,\nyou should allow Batch to choose from as many different instance types as possible.\nIf you only care about minimal interruptions and not want Batch to optimize for cost, use\n`SPOT_CAPACITY_OPTIMIZED`. `SPOT_PRICE_CAPACITY_OPTIMIZED` is recommended over `SPOT_CAPACITY_OPTIMIZED`\nfor most use cases.\n\nIf your workflow does not tolerate interruptions and you want to minimize your costs at the expense\nof potentially longer waiting times, use `AllocationStrategy.BEST_FIT`.\nThis will choose the lowest-cost instance type that fits all the jobs in the queue.\nIf instances of that type are not available,\nthe queue will not choose a new type; instead, it will wait for the instance to become available.\nThis can stall your `Queue`, with your compute environment only using part of its max capacity\n(or none at all) until the `BEST_FIT` instance becomes available.\n\nIf you are running a workflow that does not tolerate interruptions and you want to maximize throughput,\nyou can use `AllocationStrategy.BEST_FIT_PROGRESSIVE`.\nThis is the default Allocation Strategy if `spot` is `false` or unspecified.\nThis strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\nof the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\nHowever, if not all of the capacity can be filled with this instance type,\nit will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\nTo make the most use of this allocation strategy,\nit is recommended to use as many instance classes as is feasible for your workload.\nThis example shows a `ComputeEnvironment` that uses `BEST_FIT_PROGRESSIVE`\nwith `'optimal'` and `InstanceClass.M5` instance types:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.M5],\n});\n```\n\nThis example shows a `ComputeEnvironment` that uses `BEST_FIT` with `'optimal'` instances:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n allocationStrategy: batch.AllocationStrategy.BEST_FIT,\n});\n```\n\n*Note*: `allocationStrategy` cannot be specified on Fargate Compute Environments.\n\n### Controlling vCPU allocation\n\nYou can specify the maximum and minimum vCPUs a managed `ComputeEnvironment` can have at any given time.\nBatch will *always* maintain `minvCpus` worth of instances in your ComputeEnvironment, even if it is not executing any jobs,\nand even if it is disabled. Batch will scale the instances up to `maxvCpus` worth of instances as\njobs exit the JobQueue and enter the ComputeEnvironment. If you use `AllocationStrategy.BEST_FIT_PROGRESSIVE`,\n`AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED`, or `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`,\nbatch may exceed `maxvCpus`; it will never exceed `maxvCpus` by more than a single instance type. This example configures a\n`minvCpus` of 10 and a `maxvCpus` of 100:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.R4],\n minvCpus: 10,\n maxvCpus: 100,\n});\n```\n\n### Tagging Instances\n\nYou can tag any instances launched by your managed EC2 ComputeEnvironments by using the CDK `Tags` API:\n\n```ts\nimport { Tags } from 'aws-cdk-lib';\n\ndeclare const vpc: ec2.IVpc;\n\nconst tagCE = new batch.ManagedEc2EcsComputeEnvironment(this, 'CEThatMakesTaggedInstnaces', {\n vpc,\n});\n\nTags.of(tagCE).add('super', 'salamander');\n```\n\nUnmanaged `ComputeEnvironment`s do not support `maxvCpus` or `minvCpus` because you must provision and manage the instances yourself;\nthat is, Batch will not scale them up and down as needed.\n\n### Sharing a ComputeEnvironment between multiple JobQueues\n\nMultiple `JobQueue`s can share the same `ComputeEnvironment`.\nIf multiple Queues are attempting to submit Jobs to the same `ComputeEnvironment`,\nBatch will pick the Job from the Queue with the highest priority.\nThis example creates two `JobQueue`s that share a `ComputeEnvironment`:\n\n```ts\ndeclare const vpc: ec2.IVpc;\nconst sharedComputeEnv = new batch.FargateComputeEnvironment(this, 'spotEnv', {\n vpc,\n spot: true,\n});\nconst lowPriorityQueue = new batch.JobQueue(this, 'JobQueue', {\n priority: 1,\n});\nconst highPriorityQueue = new batch.JobQueue(this, 'JobQueue', {\n priority: 10,\n});\nlowPriorityQueue.addComputeEnvironment(sharedComputeEnv, 1);\nhighPriorityQueue.addComputeEnvironment(sharedComputeEnv, 1);\n```\n\n### Fairshare Scheduling\n\nBatch `JobQueue`s execute Jobs submitted to them in FIFO order unless you specify a `SchedulingPolicy`.\nFIFO queuing can cause short-running jobs to be starved while long-running jobs fill the compute environment.\nTo solve this, Jobs can be associated with a share.\n\nShares consist of a `shareIdentifier` and a `weightFactor`, which is inversely correlated with the vCPU allocated to that share identifier.\nWhen submitting a Job, you can specify its `shareIdentifier` to associate that particular job with that share.\nLet's see how the scheduler uses this information to schedule jobs.\n\nFor example, if there are two shares defined as follows:\n\n| Share Identifier | Weight Factor |\n| ---------------- | ------------- |\n| A | 1 |\n| B | 1 |\n\nThe weight factors share the following relationship:\n\n```math\nA_{vCpus} / A_{Weight} = B_{vCpus} / B_{Weight}\n```\n\nwhere `BvCpus` is the number of vCPUs allocated to jobs with share identifier `'B'`, and `B_weight` is the weight factor of `B`.\n\nThe total number of vCpus allocated to a share is equal to the amount of jobs in that share times the number of vCpus necessary for every job.\nLet's say that each A job needs 32 VCpus (`A_requirement` = 32) and each B job needs 64 vCpus (`B_requirement` = 64):\n\n```math\nA_{vCpus} = A_{Jobs} * A_{Requirement}\n```\n\n```math\nB_{vCpus} = B_{Jobs} * B_{Requirement}\n```\n\nWe have:\n\n```math\nA_{vCpus} / A_{Weight} = B_{vCpus} / B_{Weight}\n```\n\n```math\nA_{Jobs} * A_{Requirement} / A_{Weight} = B_{Jobs} * B_{Requirement} / B_{Weight}\n```\n\n```math\nA_{Jobs} * 32 / 1 = B_{Jobs} * 64 / 1\n```\n\n```math\nA_{Jobs} * 32 = B_{Jobs} * 64\n```\n\n```math\nA_{Jobs} = B_{Jobs} * 2\n```\n\nThus the scheduler will schedule two `'A'` jobs for each `'B'` job.\n\nYou can control the weight factors to change these ratios, but note that\nweight factors are inversely correlated with the vCpus allocated to the corresponding share.\n\nThis example would be configured like this:\n\n```ts\nconst fairsharePolicy = new batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy');\n\nfairsharePolicy.addShare({\n shareIdentifier: 'A',\n weightFactor: 1,\n});\nfairsharePolicy.addShare({\n shareIdentifier: 'B',\n weightFactor: 1,\n});\nnew batch.JobQueue(this, 'JobQueue', {\n schedulingPolicy: fairsharePolicy,\n});\n```\n\n*Note*: The scheduler will only consider the current usage of the compute environment unless you specify `shareDecay`.\nFor example, a `shareDecay` of 5 minutes in the above example means that at any given point in time, twice as many `'A'` jobs\nwill be scheduled for each `'B'` job, but only for the past 5 minutes. If `'B'` jobs run longer than 5 minutes, then\nthe scheduler is allowed to put more than two `'A'` jobs for each `'B'` job, because the usage of those long-running\n`'B'` jobs will no longer be considered after 5 minutes. `shareDecay` linearly decreases the usage of\nlong running jobs for calculation purposes. For example if share decay is 60 seconds,\nthen jobs that run for 30 seconds have their usage considered to be only 50% of what it actually is,\nbut after a whole minute the scheduler pretends they don't exist for fairness calculations.\n\nThe following code specifies a `shareDecay` of 5 minutes:\n\n```ts\nimport * as cdk from 'aws-cdk-lib'\nconst fairsharePolicy = new batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy', {\n shareDecay: cdk.Duration.minutes(5),\n});\n```\n\nIf you have high priority jobs that should always be executed as soon as they arrive,\nyou can define a `computeReservation` to specify the percentage of the\nmaximum vCPU capacity that should be reserved for shares that are *not in the queue*.\nThe actual reserved percentage is defined by Batch as:\n\n```math\n (\\frac{computeReservation}{100}) ^ {ActiveFairShares}\n```\n\nwhere `ActiveFairShares` is the number of shares for which there exists\nat least one job in the queue with a unique share identifier.\n\nThis is best illustrated with an example.\nSuppose there are three shares with share identifiers `A`, `B` and `C` respectively\nand we specify the `computeReservation` to be 75%. The queue is currently empty,\nand no other shares exist.\n\nThere are no active fair shares, since the queue is empty.\nThus (75/100)^0 = 1 = 100% of the maximum vCpus are reserved for all shares.\n\nA job with identifier `A` enters the queue.\n\nThe number of active fair shares is now 1, hence\n(75/100)^1 = .75 = 75% of the maximum vCpus are reserved for all shares that do not have the identifier `A`;\nfor this example, this is `B` and `C`,\n(but if jobs are submitted with a share identifier not covered by this fairshare policy, those would be considered just as `B` and `C` are).\n\nNow a `B` job enters the queue. The number of active fair shares is now 2,\nso (75/100)^2 = .5625 = 56.25% of the maximum vCpus are reserved for all shares that do not have the identifier `A` or `B`.\n\nNow a second `A` job enters the queue. The number of active fair shares is still 2,\nso the percentage reserved is still 56.25%\n\nNow a `C` job enters the queue. The number of active fair shares is now 3,\nso (75/100)^3 = .421875 = 42.1875% of the maximum vCpus are reserved for all shares that do not have the identifier `A`, `B`, or `C`.\n\nIf there are no other shares that your jobs can specify, this means that 42.1875% of your capacity will never be used!\n\nNow, `A`, `B`, and `C` can only consume 100% - 42.1875% = 57.8125% of the maximum vCpus.\nNote that the this percentage is **not** split between `A`, `B`, and `C`.\nInstead, the scheduler will use their `weightFactor`s to decide which jobs to schedule;\nthe only difference is that instead of competing for 100% of the max capacity, jobs compete for 57.8125% of the max capacity.\n\nThis example specifies a `computeReservation` of 75% that will behave as explained in the example above:\n\n```ts\nnew batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy', {\n computeReservation: 75,\n shares: [\n { weightFactor: 1, shareIdentifier: 'A' },\n { weightFactor: 0.5, shareIdentifier: 'B' },\n { weightFactor: 2, shareIdentifier: 'C' },\n ],\n});\n```\n\nYou can specify a `priority` on your `JobDefinition`s to tell the scheduler to prioritize certain jobs that share the same share identifier.\n\n### Configuring Job Retry Policies\n\nCertain workflows may result in Jobs failing due to intermittent issues.\nJobs can specify retry policies to respond to different failures with different actions.\nThere are three different ways information about the way a Job exited can be conveyed;\n\n* `exitCode`: the exit code returned from the process executed by the container. Will only match non-zero exit codes.\n* `reason`: any middleware errors, like your Docker registry being down.\n* `statusReason`: infrastructure errors, most commonly your spot instance being reclaimed.\n\nFor most use cases, only one of these will be associated with a particular action at a time.\nTo specify common `exitCode`s, `reason`s, or `statusReason`s, use the corresponding value from\nthe `Reason` class. This example shows some common failure reasons:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n }),\n retryAttempts: 5,\n retryStrategies: [\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n ],\n});\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.SPOT_INSTANCE_RECLAIMED),\n);\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n);\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.custom({\n onExitCode: '40*',\n onReason: 'some reason',\n })),\n);\n```\n\nWhen specifying a custom reason,\nyou can specify a glob string to match each of these and react to different failures accordingly.\nUp to five different retry strategies can be configured for each Job,\nand each strategy can match against some or all of `exitCode`, `reason`, and `statusReason`.\nYou can optionally configure the number of times a job will be retried,\nbut you cannot configure different retry counts for different strategies; they all share the same count.\nIf multiple conditions are specified in a given retry strategy,\nthey must all match for the action to be taken; the conditions are ANDed together, not ORed.\n\n### Running single-container ECS workflows\n\nBatch can run jobs on ECS or EKS. ECS jobs can be defined as single container or multinode.\nThis example creates a `JobDefinition` that runs a single container with ECS:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as efs from 'aws-cdk-lib/aws-efs';\n\ndeclare const myFileSystem: efs.IFileSystem;\ndeclare const myJobRole: iam.Role;\nmyFileSystem.grantRead(myJobRole);\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n volumes: [batch.EcsVolume.efs({\n name: 'myVolume',\n fileSystem: myFileSystem,\n containerPath: '/Volumes/myVolume',\n useJobRole: true,\n })],\n jobRole: myJobRole,\n }),\n});\n```\n\nFor workflows that need persistent storage, batch supports mounting `Volume`s to the container.\nYou can both provision the volume and mount it to the container in a single operation:\n\n```ts\nimport * as efs from 'aws-cdk-lib/aws-efs';\n\ndeclare const myFileSystem: efs.IFileSystem;\ndeclare const jobDefn: batch.EcsJobDefinition;\n\njobDefn.container.addVolume(batch.EcsVolume.efs({\n name: 'myVolume',\n fileSystem: myFileSystem,\n containerPath: '/Volumes/myVolume',\n}));\n```\n\n### Secrets\n\nYou can expose SecretsManager Secret ARNs or SSM Parameters to your container as environment variables.\nThe following example defines the `MY_SECRET_ENV_VAR` environment variable that contains the\nARN of the Secret defined by `mySecret`:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\n\ndeclare const mySecret: secretsmanager.ISecret;\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n secrets: {\n MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(mySecret),\n }\n }),\n});\n```\n\n### Running Kubernetes Workflows\n\nBatch also supports running workflows on EKS. The following example creates a `JobDefinition` that runs on EKS:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nconst jobDefn = new batch.EksJobDefinition(this, 'eksf2', {\n container: new batch.EksContainerDefinition(this, 'container', {\n image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n volumes: [batch.EksVolume.emptyDir({\n name: 'myEmptyDirVolume',\n mountPath: '/mount/path',\n medium: batch.EmptyDirMediumType.MEMORY,\n readonly: true,\n sizeLimit: cdk.Size.mebibytes(2048),\n })],\n }),\n});\n```\n\nYou can mount `Volume`s to these containers in a single operation:\n\n```ts\ndeclare const jobDefn: batch.EksJobDefinition;\njobDefn.container.addVolume(batch.EksVolume.emptyDir({\n name: 'emptyDir',\n mountPath: '/Volumes/emptyDir',\n}));\njobDefn.container.addVolume(batch.EksVolume.hostPath({\n name: 'hostPath',\n hostPath: '/sys',\n mountPath: '/Volumes/hostPath',\n}));\njobDefn.container.addVolume(batch.EksVolume.secret({\n name: 'secret',\n optional: true,\n mountPath: '/Volumes/secret',\n secretName: 'mySecret',\n}));\n```\n\n### Running Distributed Workflows\n\nSome workflows benefit from parallellization and are most powerful when run in a distributed environment,\nsuch as certain numerical calculations or simulations. Batch offers `MultiNodeJobDefinition`s,\nwhich allow a single job to run on multiple instances in parallel, for this purpose.\nMessage Passing Interface (MPI) is often used with these workflows.\nYou must configure your containers to use MPI properly,\nbut Batch allows different nodes running different containers to communicate easily with one another.\nYou must configure your containers to use certain environment variables that Batch will provide them,\nwhich lets them know which one is the main node, among other information.\nFor an in-depth example on using MPI to perform numerical computations on Batch,\nsee this [blog post](https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/)\nIn particular, the environment variable that tells the containers which one is the main node can be configured on your `MultiNodeJobDefinition` as follows:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nconst multiNodeJob = new batch.MultiNodeJobDefinition(this, 'JobDefinition', {\n instanceType: ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE),\n containers: [{\n container: new batch.EcsEc2ContainerDefinition(this, 'mainMPIContainer', {\n image: ecs.ContainerImage.fromRegistry('yourregsitry.com/yourMPIImage:latest'),\n cpu: 256,\n memory: cdk.Size.mebibytes(2048),\n }),\n startNode: 0,\n endNode: 5,\n }],\n});\n// convenience method\nmultiNodeJob.addContainer({\n startNode: 6,\n endNode: 10,\n container: new batch.EcsEc2ContainerDefinition(this, 'multiContainer', {\n image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n cpu: 256,\n memory: cdk.Size.mebibytes(2048),\n }),\n});\n```\n\nIf you need to set the control node to an index other than 0, specify it in directly:\n\n```ts\nconst multiNodeJob = new batch.MultiNodeJobDefinition(this, 'JobDefinition', {\n mainNode: 5,\n instanceType: ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE),\n});\n```\n\n### Pass Parameters to a Job\n\nBatch allows you define parameters in your `JobDefinition`, which can be referenced in the container command. For example:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nnew batch.EcsJobDefinition(this, 'JobDefn', {\n parameters: { echoParam: 'foobar' },\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n command: [\n 'echo',\n 'Ref::echoParam',\n ],\n }),\n});\n```\n\n### Understanding Progressive Allocation Strategies\n\nAWS Batch uses an [allocation strategy](https://docs.aws.amazon.com/batch/latest/userguide/allocation-strategies.html) to determine what compute resource will efficiently handle incoming job requests. By default, **BEST_FIT** will pick an available compute instance based on vCPU requirements. If none exist, the job will wait until resources become available. However, with this strategy, you may have jobs waiting in the queue unnecessarily despite having more powerful instances available. Below is an example of how that situation might look like:\n\n```plaintext\nCompute Environment:\n\n1. m5.xlarge => 4 vCPU\n2. m5.2xlarge => 8 vCPU\n```\n\n```plaintext\nJob Queue:\n---------\n| A | B |\n---------\n\nJob Requirements:\nA => 4 vCPU - ALLOCATED TO m5.xlarge\nB => 2 vCPU - WAITING\n```\n\nIn this situation, Batch will allocate **Job A** to compute resource #1 because it is the most cost efficient resource that matches the vCPU requirement. However, with this `BEST_FIT` strategy, **Job B** will not be allocated to our other available compute resource even though it is strong enough to handle it. Instead, it will wait until the first job is finished processing or wait a similar `m5.xlarge` resource to be provisioned.\n\nThe alternative would be to use the `BEST_FIT_PROGRESSIVE` strategy in order for the remaining job to be handled in larger containers regardless of vCPU requirement and costs.\n\n### Permissions\n\nYou can grant any Principal the `batch:submitJob` permission on both a job definition and a job queue like this:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\ndeclare const vpc: ec2.IVpc;\n\nconst ecsJob = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n }),\n});\n\nconst queue = new batch.JobQueue(this, 'JobQueue', {\n computeEnvironments: [{\n computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(this, 'managedEc2CE', {\n vpc,\n }),\n order: 1,\n }],\n priority: 10,\n});\n\nconst user = new iam.User(this, 'MyUser');\necsJob.grantSubmitJob(user, queue);\n```\n" + }, + "repository": { + "directory": "packages/@aws-cdk/aws-batch-alpha", + "type": "git", + "url": "https://github.com/aws/aws-cdk.git" + }, + "schema": "jsii/0.10.0", + "targets": { + "dotnet": { + "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png", + "namespace": "Amazon.CDK.AWS.Batch.Alpha", + "packageId": "Amazon.CDK.AWS.Batch.Alpha" + }, + "go": { + "moduleName": "github.com/aws/aws-cdk-go", + "packageName": "awscdkbatchalpha" + }, + "java": { + "maven": { + "artifactId": "batch-alpha", + "groupId": "software.amazon.awscdk" + }, + "package": "software.amazon.awscdk.services.batch.alpha" + }, + "js": { + "npm": "@aws-cdk/aws-batch-alpha" + }, + "python": { + "classifiers": [ + "Framework :: AWS CDK", + "Framework :: AWS CDK :: 2" + ], + "distName": "aws-cdk.aws-batch-alpha", + "module": "aws_cdk.aws_batch_alpha" + } + }, + "types": { + "@aws-cdk/aws-batch-alpha.Action": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "The Action to take when all specified conditions in a RetryStrategy are met." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Action", + "kind": "enum", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 159 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "The job will not retry." + }, + "name": "EXIT" + }, + { + "docs": { + "remarks": "It can be retried up to the number of times specified in `retryAttempts`.", + "stability": "experimental", + "summary": "The job will retry." + }, + "name": "RETRY" + } + ], + "name": "Action", + "symbolId": "lib/job-definition-base:Action" + }, + "@aws-cdk/aws-batch-alpha.AllocationStrategy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "see": "https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/", + "stability": "experimental", + "summary": "Determines how this compute environment chooses instances to spawn." + }, + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy", + "kind": "enum", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 423 + }, + "members": [ + { + "docs": { + "remarks": "If instances of that type are not available, the queue will not choose a new type;\ninstead, it will wait for the instance to become available.\nThis can stall your `Queue`, with your compute environment only using part of its max capacity\n(or none at all) until the `BEST_FIT` instance becomes available.\nThis allocation strategy keeps costs lower but can limit scaling.\n`BEST_FIT` isn't supported when updating compute environments", + "stability": "experimental", + "summary": "Batch chooses the lowest-cost instance type that fits all the jobs in the queue." + }, + "name": "BEST_FIT" + }, + { + "docs": { + "remarks": "This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\nof the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\nHowever, if not all of the capacity can be filled with this instance type,\nit will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\nTo make the most use of this allocation strategy,\nit is recommended to use as many instance classes as is feasible for your workload.", + "stability": "experimental", + "summary": "This is the default Allocation Strategy if `spot` is `false` or unspecified." + }, + "name": "BEST_FIT_PROGRESSIVE" + }, + { + "docs": { + "remarks": "This will tell Batch to choose the instance types from the ones you’ve specified that have\nthe most spot capacity available to minimize the chance of interruption.\nTo get the most benefit from your spot instances,\nyou should allow Batch to choose from as many different instance types as possible.", + "stability": "experimental", + "summary": "If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled)." + }, + "name": "SPOT_CAPACITY_OPTIMIZED" + }, + { + "docs": { + "remarks": "The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances.", + "stability": "experimental", + "summary": "The price and capacity optimized allocation strategy looks at both price and capacity to select the Spot Instance pools that are the least likely to be interrupted and have the lowest possible price." + }, + "name": "SPOT_PRICE_CAPACITY_OPTIMIZED" + } + ], + "name": "AllocationStrategy", + "symbolId": "lib/managed-compute-environment:AllocationStrategy" + }, + "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props common to all ComputeEnvironments." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 50 + }, + "name": "ComputeEnvironmentProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- generated by CloudFormation", + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 56 + }, + "name": "computeEnvironmentName", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 81 + }, + "name": "enabled", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- a serviceRole will be created for managed CEs, none for unmanaged CEs", + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 64 + }, + "name": "serviceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + } + ], + "symbolId": "lib/compute-environment-base:ComputeEnvironmentProps" + }, + "@aws-cdk/aws-batch-alpha.CustomReason": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "The corresponding Action will only be taken if *all* of the conditions specified here are met." + }, + "fqn": "@aws-cdk/aws-batch-alpha.CustomReason", + "kind": "interface", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 173 + }, + "name": "CustomReason", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- will not match on the exit code", + "remarks": "For example, `'40*'` will match 400, 404, 40123456789012", + "stability": "experimental", + "summary": "A glob string that will match on the job exit code." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 179 + }, + "name": "onExitCode", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- will not match on the reason", + "stability": "experimental", + "summary": "A glob string that will match on the reason returned by the exiting job For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 195 + }, + "name": "onReason", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- will not match on the status reason", + "remarks": "For example, `'Host EC2*'` indicates that the spot instance has been reclaimed.", + "stability": "experimental", + "summary": "A glob string that will match on the statusReason returned by the exiting job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 187 + }, + "name": "onStatusReason", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/job-definition-base:CustomReason" + }, + "@aws-cdk/aws-batch-alpha.Device": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "A container instance host device." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Device", + "kind": "interface", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 143 + }, + "name": "Device", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The path for the device on the host container instance." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 154 + }, + "name": "hostPath", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "Same path as the host", + "stability": "experimental", + "summary": "The path inside the container at which to expose the host device." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 149 + }, + "name": "containerPath", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "Readonly", + "remarks": "By default, the container has permissions for read, write, and mknod for the device.", + "stability": "experimental", + "summary": "The explicit permissions to provide to the container for the device." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 162 + }, + "name": "permissions", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.DevicePermission" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/linux-parameters:Device" + }, + "@aws-cdk/aws-batch-alpha.DevicePermission": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Permissions for device access." + }, + "fqn": "@aws-cdk/aws-batch-alpha.DevicePermission", + "kind": "enum", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 191 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "Read." + }, + "name": "READ" + }, + { + "docs": { + "stability": "experimental", + "summary": "Write." + }, + "name": "WRITE" + }, + { + "docs": { + "stability": "experimental", + "summary": "Make a node." + }, + "name": "MKNOD" + } + ], + "name": "DevicePermission", + "symbolId": "lib/linux-parameters:DevicePermission" + }, + "@aws-cdk/aws-batch-alpha.DnsPolicy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", + "stability": "experimental", + "summary": "The DNS Policy for the pod used by the Job Definition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy", + "kind": "enum", + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 100 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "The Pod inherits the name resolution configuration from the node that the Pods run on." + }, + "name": "DEFAULT" + }, + { + "docs": { + "stability": "experimental", + "summary": "Any DNS query that does not match the configured cluster domain suffix, such as `\"www.kubernetes.io\"`, is forwarded to an upstream nameserver by the DNS server. Cluster administrators may have extra stub-domain and upstream DNS servers configured." + }, + "name": "CLUSTER_FIRST" + }, + { + "docs": { + "remarks": "Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy.", + "stability": "experimental", + "summary": "For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`." + }, + "name": "CLUSTER_FIRST_WITH_HOST_NET" + } + ], + "name": "DnsPolicy", + "symbolId": "lib/eks-job-definition:DnsPolicy" + }, + "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure an EcsContainerDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 472 + }, + "name": "EcsContainerDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", + "stability": "experimental", + "summary": "The number of vCPUs reserved for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 483 + }, + "name": "cpu", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 476 + }, + "name": "image", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "abstract": true, + "docs": { + "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", + "stability": "experimental", + "summary": "The memory hard limit present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 490 + }, + "name": "memory", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "- no command", + "see": "https://docs.docker.com/engine/reference/builder/#cmd", + "stability": "experimental", + "summary": "The command that's passed to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 499 + }, + "name": "command", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no environment variables", + "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", + "stability": "experimental", + "summary": "The environment variables to pass to a container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 508 + }, + "name": "environment", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- a Role will be created", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html", + "stability": "experimental", + "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 517 + }, + "name": "executionRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "- no job role", + "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html", + "stability": "experimental", + "summary": "The role that the container can assume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 526 + }, + "name": "jobRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "stability": "experimental", + "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 533 + }, + "name": "linuxParameters", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" + } + }, + { + "abstract": true, + "docs": { + "default": "- the log configuration of the Docker daemon", + "stability": "experimental", + "summary": "The loging configuration for this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 540 + }, + "name": "logging", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ecs.LogDriver" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Gives the container readonly access to its root filesystem." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 547 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- no secrets", + "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html", + "stability": "experimental", + "summary": "A map from environment variable names to the secrets for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 557 + }, + "name": "secrets", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no user", + "stability": "experimental", + "summary": "The user name to use inside the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 564 + }, + "name": "user", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- no volumes", + "remarks": "Automatically added to the job definition.", + "stability": "experimental", + "summary": "The volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 571 + }, + "name": "volumes", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsContainerDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "constructs.Construct", + "docs": { + "stability": "experimental", + "summary": "A container orchestrated by ECS that uses EC2 resources." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 900 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 895 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Add a ulimit to this container." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 934 + }, + "name": "addUlimit", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "parameters": [ + { + "name": "ulimit", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" + } + } + ] + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a Volume to this container." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 706 + }, + "name": "addVolume", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "parameters": [ + { + "name": "volume", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + } + } + ] + } + ], + "name": "EcsEc2ContainerDefinition", + "properties": [ + { + "docs": { + "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", + "stability": "experimental", + "summary": "The number of vCPUs reserved for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 579 + }, + "name": "cpu", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 583 + }, + "name": "executionRole", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 578 + }, + "name": "image", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "docs": { + "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", + "stability": "experimental", + "summary": "The memory hard limit present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 580 + }, + "name": "memory", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Limits to set for the user this docker container will run as." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 897 + }, + "name": "ulimits", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "Automatically added to the job definition.", + "stability": "experimental", + "summary": "The volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 590 + }, + "name": "volumes", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The command that's passed to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 581 + }, + "name": "command", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", + "stability": "experimental", + "summary": "The environment variables to pass to a container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 582 + }, + "name": "environment", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "docs": { + "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", + "stability": "experimental", + "summary": "The number of physical GPUs to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 898 + }, + "name": "gpu", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role that the container can assume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 584 + }, + "name": "jobRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 585 + }, + "name": "linuxParameters", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The configuration of the log driver." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 586 + }, + "name": "logDriverConfig", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 896 + }, + "name": "privileged", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Gives the container readonly access to its root filesystem." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 587 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", + "stability": "experimental", + "summary": "A map from environment variable names to the secrets for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 588 + }, + "name": "secrets", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + }, + "kind": "map" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The user name to use inside the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 589 + }, + "name": "user", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsEc2ContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure an EcsEc2ContainerDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 867 + }, + "name": "EcsEc2ContainerDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- no gpus", + "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", + "stability": "experimental", + "summary": "The number of physical GPUs to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 889 + }, + "name": "gpu", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 873 + }, + "name": "privileged", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- no ulimits", + "stability": "experimental", + "summary": "Limits to set for the user this docker container will run as." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 880 + }, + "name": "ulimits", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsEc2ContainerDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "constructs.Construct", + "docs": { + "stability": "experimental", + "summary": "A container orchestrated by ECS that uses Fargate resources." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1022 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", + "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1017 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Add a Volume to this container." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 706 + }, + "name": "addVolume", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "parameters": [ + { + "name": "volume", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + } + } + ] + } + ], + "name": "EcsFargateContainerDefinition", + "properties": [ + { + "docs": { + "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", + "stability": "experimental", + "summary": "The number of vCPUs reserved for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 579 + }, + "name": "cpu", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 583 + }, + "name": "executionRole", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 578 + }, + "name": "image", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "docs": { + "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", + "stability": "experimental", + "summary": "The memory hard limit present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 580 + }, + "name": "memory", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "remarks": "Automatically added to the job definition.", + "stability": "experimental", + "summary": "The volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 590 + }, + "name": "volumes", + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", + "stability": "experimental", + "summary": "Indicates whether the job has a public IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1019 + }, + "name": "assignPublicIp", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The command that's passed to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 581 + }, + "name": "command", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", + "stability": "experimental", + "summary": "The environment variables to pass to a container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 582 + }, + "name": "environment", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The size for ephemeral storage." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1020 + }, + "name": "ephemeralStorageSize", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Which version of Fargate to use when running this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1018 + }, + "name": "fargatePlatformVersion", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role that the container can assume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 584 + }, + "name": "jobRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 585 + }, + "name": "linuxParameters", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The configuration of the log driver." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 586 + }, + "name": "logDriverConfig", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Gives the container readonly access to its root filesystem." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 587 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", + "stability": "experimental", + "summary": "A map from environment variable names to the secrets for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 588 + }, + "name": "secrets", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + }, + "kind": "map" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The user name to use inside the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 589 + }, + "name": "user", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsFargateContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure an EcsFargateContainerDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 987 + }, + "name": "EcsFargateContainerDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", + "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html", + "stability": "experimental", + "summary": "Indicates whether the job has a public IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 997 + }, + "name": "assignPublicIp", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- 20 GiB", + "stability": "experimental", + "summary": "The size for ephemeral storage." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1011 + }, + "name": "ephemeralStorageSize", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "LATEST", + "stability": "experimental", + "summary": "Which version of Fargate to use when running this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 1004 + }, + "name": "fargatePlatformVersion", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsFargateContainerDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EcsJobDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::JobDefinition" + }, + "stability": "experimental", + "summary": "A JobDefinition that uses ECS orchestration." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 84 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IJobDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 58 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Import a JobDefinition by its arn." + }, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 62 + }, + "name": "fromJobDefinitionArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "jobDefinitionArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a RetryStrategy to this JobDefinition." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 259 + }, + "name": "addRetryStrategy", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "parameters": [ + { + "name": "strategy", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + } + } + ] + }, + { + "docs": { + "stability": "experimental", + "summary": "Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue`." + }, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 110 + }, + "name": "grantSubmitJob", + "parameters": [ + { + "name": "identity", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IGrantable" + } + }, + { + "name": "queue", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue" + } + } + ] + } + ], + "name": "EcsJobDefinition", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The container that this job will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 78 + }, + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 81 + }, + "name": "jobDefinitionArn", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 82 + }, + "name": "jobDefinitionName", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Defines the retry behavior for this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 243 + }, + "name": "retryStrategies", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 241 + }, + "name": "parameters", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "any" + }, + "kind": "map" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 79 + }, + "name": "propagateTags", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "The job is retried on failure the same number of attempts as the value.", + "stability": "experimental", + "summary": "The number of times to retry a job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 242 + }, + "name": "retryAttempts", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", + "stability": "experimental", + "summary": "The priority of this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 244 + }, + "name": "schedulingPriority", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", + "stability": "experimental", + "summary": "The timeout time for jobs that are submitted with this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 245 + }, + "name": "timeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/ecs-job-definition:EcsJobDefinition" + }, + "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for EcsJobDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.JobDefinitionProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 38 + }, + "name": "EcsJobDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The container that this job will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 42 + }, + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-job-definition.ts", + "line": 50 + }, + "name": "propagateTags", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-job-definition:EcsJobDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EcsMachineImage": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "A Batch MachineImage that is compatible with ECS." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage", + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 367 + }, + "name": "EcsMachineImage", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- chosen by batch", + "stability": "experimental", + "summary": "The machine image to use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 361 + }, + "name": "image", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IMachineImage" + } + }, + { + "abstract": true, + "docs": { + "default": "- 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances", + "stability": "experimental", + "summary": "Tells Batch which instance type to launch this image on." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 373 + }, + "name": "imageType", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImageType" + } + } + ], + "symbolId": "lib/managed-compute-environment:EcsMachineImage" + }, + "@aws-cdk/aws-batch-alpha.EcsMachineImageType": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Maps the image to instance types." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImageType", + "kind": "enum", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 391 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "Tells Batch that this machine image runs on non-GPU instances." + }, + "name": "ECS_AL2" + }, + { + "docs": { + "stability": "experimental", + "summary": "Tells Batch that this machine image runs on GPU instances." + }, + "name": "ECS_AL2_NVIDIA" + } + ], + "name": "EcsMachineImageType", + "symbolId": "lib/managed-compute-environment:EcsMachineImageType" + }, + "@aws-cdk/aws-batch-alpha.EcsVolume": { + "abstract": true, + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Represents a Volume that can be mounted to a container that uses ECS." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 162 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 126 + }, + "methods": [ + { + "docs": { + "remarks": "this volume can grow and shrink as needed", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html", + "stability": "experimental", + "summary": "Creates a Volume that uses an AWS Elastic File System (EFS);" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 132 + }, + "name": "efs", + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EfsVolume" + } + }, + "static": true + }, + { + "docs": { + "remarks": "This volume will persist on the host at the specified `hostPath`.\nIf the `hostPath` is not specified, Docker will choose the host path. In this case,\nthe data may not persist after the containers that use it stop running.", + "stability": "experimental", + "summary": "Creates a Host volume." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 141 + }, + "name": "host", + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostVolume" + } + }, + "static": true + } + ], + "name": "EcsVolume", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The path on the container that this volume will be mounted to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 153 + }, + "name": "containerPath", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 148 + }, + "name": "name", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Whether or not the container has readonly access to this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 160 + }, + "name": "readonly", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsVolume" + }, + "@aws-cdk/aws-batch-alpha.EcsVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Options to configure an EcsVolume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolumeOptions", + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 104 + }, + "name": "EcsVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "the path on the container where this volume is mounted." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 113 + }, + "name": "containerPath", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "the name of this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 108 + }, + "name": "name", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "if set, the container will have readonly access to the volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 120 + }, + "name": "readonly", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:EcsVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.EfsVolume": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "@aws-cdk/aws-batch-alpha.EcsVolume", + "docs": { + "remarks": "this volume can grow and shrink as needed", + "stability": "experimental", + "summary": "A Volume that uses an AWS Elastic File System (EFS);" + }, + "fqn": "@aws-cdk/aws-batch-alpha.EfsVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 297 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 233 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Returns true if x is an EfsVolume, false otherwise." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 237 + }, + "name": "isEfsVolume", + "parameters": [ + { + "name": "x", + "type": { + "primitive": "any" + } + } + ], + "returns": { + "type": { + "primitive": "boolean" + } + }, + "static": true + } + ], + "name": "EfsVolume", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The EFS File System that supports this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 244 + }, + "name": "fileSystem", + "type": { + "fqn": "aws-cdk-lib.aws_efs.IFileSystem" + } + }, + { + "docs": { + "default": "- no accessPointId", + "remarks": "If an access point is specified, `rootDirectory` must either be omitted or set to `/`\nwhich enforces the path set on the EFS access point.\nIf an access point is used, `enableTransitEncryption` must be `true`.", + "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html", + "stability": "experimental", + "summary": "The Amazon EFS access point ID to use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 285 + }, + "name": "accessPointId", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "false", + "see": "https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html", + "stability": "experimental", + "summary": "Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 263 + }, + "name": "enableTransitEncryption", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "default": "- root of the EFS File System", + "remarks": "If this parameter is omitted, the root of the Amazon EFS volume is used instead.\nSpecifying `/` has the same effect as omitting this parameter.\nThe maximum length is 4,096 characters.", + "stability": "experimental", + "summary": "The directory within the Amazon EFS file system to mount as the root directory inside the host." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 254 + }, + "name": "rootDirectory", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "- chosen by the EFS Mount Helper", + "remarks": "The value must be between 0 and 65,535.", + "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html", + "stability": "experimental", + "summary": "The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 273 + }, + "name": "transitEncryptionPort", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "docs": { + "default": "false", + "remarks": "If specified, `enableTransitEncryption` must be `true`.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints", + "stability": "experimental", + "summary": "Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 295 + }, + "name": "useJobRole", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:EfsVolume" + }, + "@aws-cdk/aws-batch-alpha.EfsVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Options for configuring an EfsVolume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 172 + }, + "name": "EfsVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The EFS File System that supports this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 176 + }, + "name": "fileSystem", + "type": { + "fqn": "aws-cdk-lib.aws_efs.IFileSystem" + } + }, + { + "abstract": true, + "docs": { + "default": "- no accessPointId", + "remarks": "If an access point is specified, `rootDirectory` must either be omitted or set to `/`\nwhich enforces the path set on the EFS access point.\nIf an access point is used, `enableTransitEncryption` must be `true`.", + "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html", + "stability": "experimental", + "summary": "The Amazon EFS access point ID to use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 217 + }, + "name": "accessPointId", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "see": "https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html", + "stability": "experimental", + "summary": "Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 195 + }, + "name": "enableTransitEncryption", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- root of the EFS File System", + "remarks": "If this parameter is omitted, the root of the Amazon EFS volume is used instead.\nSpecifying `/` has the same effect as omitting this parameter.\nThe maximum length is 4,096 characters.", + "stability": "experimental", + "summary": "The directory within the Amazon EFS file system to mount as the root directory inside the host." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 186 + }, + "name": "rootDirectory", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- chosen by the EFS Mount Helper", + "remarks": "The value must be between 0 and 65,535.", + "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html", + "stability": "experimental", + "summary": "The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 205 + }, + "name": "transitEncryptionPort", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "If specified, `enableTransitEncryption` must be `true`.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints", + "stability": "experimental", + "summary": "Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 227 + }, + "name": "useJobRole", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:EfsVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.EksContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "constructs.Construct", + "docs": { + "stability": "experimental", + "summary": "A container that can be run with EKS orchestration on EC2 resources." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 555 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEksContainerDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 533 + }, + "methods": [ + { + "docs": { + "remarks": "Automatically added to the Pod.", + "stability": "experimental", + "summary": "Mount a Volume to this container." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 579 + }, + "name": "addVolume", + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "parameters": [ + { + "name": "volume", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" + } + } + ] + } + ], + "name": "EksContainerDefinition", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 534 + }, + "name": "image", + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "docs": { + "remarks": "Automatically added to the Pod.", + "stability": "experimental", + "summary": "The Volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 551 + }, + "name": "volumes", + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", + "stability": "experimental", + "summary": "An array of arguments to the entrypoint." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 535 + }, + "name": "args", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", + "stability": "experimental", + "summary": "The entrypoint for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 536 + }, + "name": "command", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "stability": "experimental", + "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 542 + }, + "name": "cpuLimit", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 543 + }, + "name": "cpuReservation", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", + "stability": "experimental", + "summary": "The environment variables to pass to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 537 + }, + "name": "env", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "docs": { + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "stability": "experimental", + "summary": "The hard limit of GPUs to present to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 544 + }, + "name": "gpuLimit", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 545 + }, + "name": "gpuReservation", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The image pull policy for this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 538 + }, + "name": "imagePullPolicy", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" + } + }, + { + "docs": { + "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "stability": "experimental", + "summary": "The amount (in MiB) of memory to present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 540 + }, + "name": "memoryLimit", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "stability": "experimental", + "summary": "The soft limit (in MiB) of memory to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 541 + }, + "name": "memoryReservation", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 539 + }, + "name": "name", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "stability": "experimental", + "summary": "If specified, gives this container elevated permissions on the host container instance." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 546 + }, + "name": "privileged", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "stability": "experimental", + "summary": "If specified, gives this container readonly access to its root file system." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 547 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "stability": "experimental", + "summary": "If specified, the container is run as the specified group ID (`gid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 548 + }, + "name": "runAsGroup", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "stability": "experimental", + "summary": "If specified, the container is run as a user with a `uid` other than 0." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 549 + }, + "name": "runAsRoot", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "stability": "experimental", + "summary": "If specified, this container is run as the specified user ID (`uid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 550 + }, + "name": "runAsUser", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/eks-container-definition:EksContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure an EksContainerDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 287 + }, + "name": "EksContainerDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 291 + }, + "name": "image", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "abstract": true, + "docs": { + "default": "- no args", + "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", + "see": "https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/", + "stability": "experimental", + "summary": "An array of arguments to the entrypoint." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 308 + }, + "name": "args", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no command", + "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", + "see": "https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint", + "stability": "experimental", + "summary": "The entrypoint for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 327 + }, + "name": "command", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- No CPU limit", + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 411 + }, + "name": "cpuLimit", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- No CPUs reserved", + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 426 + }, + "name": "cpuReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no environment variables", + "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", + "stability": "experimental", + "summary": "The environment variables to pass to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 337 + }, + "name": "env", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- No GPU limit", + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The hard limit of GPUs to present to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 439 + }, + "name": "gpuLimit", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- No GPUs reserved", + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 453 + }, + "name": "gpuReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise", + "see": "https://kubernetes.io/docs/concepts/containers/images/#updating-images", + "stability": "experimental", + "summary": "The image pull policy for this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 346 + }, + "name": "imagePullPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" + } + }, + { + "abstract": true, + "docs": { + "default": "- No memory limit", + "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", + "stability": "experimental", + "summary": "The amount (in MiB) of memory to present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 371 + }, + "name": "memoryLimit", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "- No memory reserved", + "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", + "stability": "experimental", + "summary": "The soft limit (in MiB) of memory to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 396 + }, + "name": "memoryReservation", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": ": `'Default'`", + "stability": "experimental", + "summary": "The name of this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 353 + }, + "name": "name", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", + "stability": "experimental", + "summary": "If specified, gives this container elevated permissions on the host container instance." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 467 + }, + "name": "privileged", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", + "stability": "experimental", + "summary": "If specified, gives this container readonly access to its root file system." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 480 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, the container is run as the specified group ID (`gid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 493 + }, + "name": "runAsGroup", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- the container is *not* required to run as a non-root user", + "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, the container is run as a user with a `uid` other than 0." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 505 + }, + "name": "runAsRoot", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- the user that is specified in the image metadata.", + "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, this container is run as the specified user ID (`uid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 517 + }, + "name": "runAsUser", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no volumes", + "remarks": "Automatically added to the Pod.", + "see": "https://kubernetes.io/docs/concepts/storage/volumes/", + "stability": "experimental", + "summary": "The Volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 527 + }, + "name": "volumes", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/eks-container-definition:EksContainerDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EksJobDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::JobDefinition" + }, + "stability": "experimental", + "summary": "A JobDefinition that uses Eks orchestration." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 151 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "@aws-cdk/aws-batch-alpha.IJobDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 125 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Import an EksJobDefinition by its arn." + }, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 129 + }, + "name": "fromEksJobDefinitionArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "eksJobDefinitionArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IEksJobDefinition" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a RetryStrategy to this JobDefinition." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 259 + }, + "name": "addRetryStrategy", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "parameters": [ + { + "name": "strategy", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + } + } + ] + } + ], + "name": "EksJobDefinition", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The container this Job Definition will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 143 + }, + "name": "container", + "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 148 + }, + "name": "jobDefinitionArn", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 149 + }, + "name": "jobDefinitionName", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Defines the retry behavior for this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 243 + }, + "name": "retryStrategies", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The DNS Policy of the pod used by this Job Definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 144 + }, + "name": "dnsPolicy", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 241 + }, + "name": "parameters", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "any" + }, + "kind": "map" + } + } + }, + { + "docs": { + "remarks": "The job is retried on failure the same number of attempts as the value.", + "stability": "experimental", + "summary": "The number of times to retry a job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 242 + }, + "name": "retryAttempts", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", + "stability": "experimental", + "summary": "The priority of this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 244 + }, + "name": "schedulingPriority", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", + "stability": "experimental", + "summary": "The name of the service account that's used to run the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 146 + }, + "name": "serviceAccount", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", + "stability": "experimental", + "summary": "The timeout time for jobs that are submitted with this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 245 + }, + "name": "timeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "docs": { + "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", + "stability": "experimental", + "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 145 + }, + "name": "useHostNetwork", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-job-definition:EksJobDefinition" + }, + "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for EksJobDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.JobDefinitionProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 54 + }, + "name": "EksJobDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The container this Job Definition will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 58 + }, + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" + } + }, + { + "abstract": true, + "docs": { + "default": "`DnsPolicy.CLUSTER_FIRST`", + "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", + "stability": "experimental", + "summary": "The DNS Policy of the pod used by this Job Definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 67 + }, + "name": "dnsPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" + } + }, + { + "abstract": true, + "docs": { + "default": "- the default service account of the container", + "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", + "see": "https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html", + "stability": "experimental", + "summary": "The name of the service account that's used to run the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 92 + }, + "name": "serviceAccount", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", + "see": "https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking", + "stability": "experimental", + "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 79 + }, + "name": "useHostNetwork", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-job-definition:EksJobDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.EksMachineImage": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "A Batch MachineImage that is compatible with EKS." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage", + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 379 + }, + "name": "EksMachineImage", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- chosen by batch", + "stability": "experimental", + "summary": "The machine image to use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 361 + }, + "name": "image", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IMachineImage" + } + }, + { + "abstract": true, + "docs": { + "default": "- 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances", + "stability": "experimental", + "summary": "Tells Batch which instance type to launch this image on." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 385 + }, + "name": "imageType", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImageType" + } + } + ], + "symbolId": "lib/managed-compute-environment:EksMachineImage" + }, + "@aws-cdk/aws-batch-alpha.EksMachineImageType": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Maps the image to instance types." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImageType", + "kind": "enum", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 406 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "Tells Batch that this machine image runs on non-GPU instances." + }, + "name": "EKS_AL2" + }, + { + "docs": { + "stability": "experimental", + "summary": "Tells Batch that this machine image runs on GPU instances." + }, + "name": "EKS_AL2_NVIDIA" + } + ], + "name": "EksMachineImageType", + "symbolId": "lib/managed-compute-environment:EksMachineImageType" + }, + "@aws-cdk/aws-batch-alpha.EksVolume": { + "abstract": true, + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A Volume that can be mounted to a container supported by EKS." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 717 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 668 + }, + "methods": [ + { + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", + "stability": "experimental", + "summary": "Creates a Kubernetes EmptyDir volume." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 674 + }, + "name": "emptyDir", + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolume" + } + }, + "static": true + }, + { + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", + "stability": "experimental", + "summary": "Creates a Kubernetes HostPath volume." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 682 + }, + "name": "hostPath", + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolume" + } + }, + "static": true + }, + { + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", + "stability": "experimental", + "summary": "Creates a Kubernetes Secret volume." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 690 + }, + "name": "secret", + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolume" + } + }, + "static": true + } + ], + "name": "EksVolume", + "properties": [ + { + "docs": { + "remarks": "The name must be a valid DNS subdomain name.", + "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", + "stability": "experimental", + "summary": "The name of this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 700 + }, + "name": "name", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "- the container is not mounted", + "stability": "experimental", + "summary": "The path on the container where the container is mounted." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 707 + }, + "name": "containerPath", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "false", + "remarks": "Otherwise, the container has read/write access.", + "stability": "experimental", + "summary": "If specified, the container has readonly access to the volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 715 + }, + "name": "readonly", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-container-definition:EksVolume" + }, + "@aws-cdk/aws-batch-alpha.EksVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Options to configure an EksVolume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EksVolumeOptions", + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 640 + }, + "name": "EksVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "The name must be a valid DNS subdomain name.", + "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", + "stability": "experimental", + "summary": "The name of this volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 647 + }, + "name": "name", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- the volume is not mounted", + "stability": "experimental", + "summary": "The path on the container where the volume is mounted." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 654 + }, + "name": "mountPath", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "Otherwise, the container has read/write access.", + "stability": "experimental", + "summary": "If specified, the container has readonly access to the volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 662 + }, + "name": "readonly", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-container-definition:EksVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.EmptyDirMediumType": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "What medium the volume will live in." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType", + "kind": "enum", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 748 + }, + "members": [ + { + "docs": { + "remarks": "Items written here will survive node reboots.", + "stability": "experimental", + "summary": "Use the disk storage of the node." + }, + "name": "DISK" + }, + { + "docs": { + "remarks": "Items written here will *not* survive node reboots.", + "stability": "experimental", + "summary": "Use the `tmpfs` volume that is backed by RAM of the node." + }, + "name": "MEMORY" + } + ], + "name": "EmptyDirMediumType", + "symbolId": "lib/eks-container-definition:EmptyDirMediumType" + }, + "@aws-cdk/aws-batch-alpha.EmptyDirVolume": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "@aws-cdk/aws-batch-alpha.EksVolume", + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", + "stability": "experimental", + "summary": "A Kubernetes EmptyDir volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 789 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 767 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Returns `true` if `x` is an EmptyDirVolume, `false` otherwise." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 771 + }, + "name": "isEmptyDirVolume", + "parameters": [ + { + "name": "x", + "type": { + "primitive": "any" + } + } + ], + "returns": { + "type": { + "primitive": "boolean" + } + }, + "static": true + } + ], + "name": "EmptyDirVolume", + "properties": [ + { + "docs": { + "default": "`EmptyDirMediumType.DISK`", + "stability": "experimental", + "summary": "The storage type to use for this Volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 780 + }, + "name": "medium", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType" + } + }, + { + "docs": { + "default": "- no size limit", + "stability": "experimental", + "summary": "The maximum size for this Volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 787 + }, + "name": "sizeLimit", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + } + ], + "symbolId": "lib/eks-container-definition:EmptyDirVolume" + }, + "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", + "stability": "experimental", + "summary": "Options for a Kubernetes EmptyDir volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EksVolumeOptions" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 729 + }, + "name": "EmptyDirVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "default": "`EmptyDirMediumType.DISK`", + "stability": "experimental", + "summary": "The storage type to use for this Volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 735 + }, + "name": "medium", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType" + } + }, + { + "abstract": true, + "docs": { + "default": "- no size limit", + "stability": "experimental", + "summary": "The maximum size for this Volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 742 + }, + "name": "sizeLimit", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + } + ], + "symbolId": "lib/eks-container-definition:EmptyDirVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::SchedulingPolicy" + }, + "remarks": "The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\nThe scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\neach share are currently being executed by the ComputeEnvironment*. The weight factors associated with\neach share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\nfairshare policies.", + "stability": "experimental", + "summary": "Represents a Fairshare Scheduling Policy. Instructs the scheduler to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers." + }, + "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 212 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", + "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 191 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Reference an exisiting Scheduling Policy by its ARN." + }, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 195 + }, + "name": "fromFairshareSchedulingPolicyArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "fairshareSchedulingPolicyArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a share this to this Fairshare SchedulingPolicy." + }, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 242 + }, + "name": "addShare", + "parameters": [ + { + "name": "share", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Share" + } + } + ] + } + ], + "name": "FairshareSchedulingPolicy", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The arn of this scheduling policy." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 209 + }, + "name": "schedulingPolicyArn", + "overrides": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this scheduling policy." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 210 + }, + "name": "schedulingPolicyName", + "overrides": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", + "stability": "experimental", + "summary": "The shares that this Scheduling Policy applies to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 208 + }, + "name": "shares", + "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Share" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", + "stability": "experimental", + "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 206 + }, + "name": "computeReservation", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", + "stability": "experimental", + "summary": "The amount of time to use to measure the usage of each job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 207 + }, + "name": "shareDecay", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/scheduling-policy:FairshareSchedulingPolicy" + }, + "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Fairshare SchedulingPolicy configuration." + }, + "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 136 + }, + "name": "FairshareSchedulingPolicyProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- no vCPU is reserved", + "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", + "stability": "experimental", + "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 155 + }, + "name": "computeReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- generated by CloudFormation", + "stability": "experimental", + "summary": "The name of this SchedulingPolicy." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 34 + }, + "name": "schedulingPolicyName", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- 0: only the current job usage is considered", + "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", + "stability": "experimental", + "summary": "The amount of time to use to measure the usage of each job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 167 + }, + "name": "shareDecay", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "abstract": true, + "docs": { + "default": "- no shares", + "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", + "stability": "experimental", + "summary": "The shares that this Scheduling Policy applies to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 176 + }, + "name": "shares", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Share" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/scheduling-policy:FairshareSchedulingPolicyProps" + }, + "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::ComputeEnvironment" + }, + "stability": "experimental", + "summary": "A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances." + }, + "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1096 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1072 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Reference an existing FargateComputeEnvironment by its arn." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1076 + }, + "name": "fromFargateComputeEnvironmentArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "fargateComputeEnvironmentArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment" + } + }, + "static": true + } + ], + "name": "FargateComputeEnvironment", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this compute environment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1094 + }, + "name": "computeEnvironmentArn", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1093 + }, + "name": "computeEnvironmentName", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The network connections associated with this resource." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 210 + }, + "name": "connections", + "overrides": "aws-cdk-lib.aws_ec2.IConnectable", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.Connections" + } + }, + { + "docs": { + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 92 + }, + "name": "enabled", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", + "stability": "experimental", + "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 201 + }, + "name": "maxvCpus", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The security groups this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 206 + }, + "name": "securityGroups", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "TagManager to set, remove and format tags." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 208 + }, + "name": "tags", + "overrides": "aws-cdk-lib.ITaggable", + "type": { + "fqn": "aws-cdk-lib.TagManager" + } + }, + { + "docs": { + "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", + "stability": "experimental", + "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 202 + }, + "name": "replaceComputeEnvironment", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 91 + }, + "name": "serviceRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", + "stability": "experimental", + "summary": "Whether or not to use spot instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 203 + }, + "name": "spot", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", + "stability": "experimental", + "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 205 + }, + "name": "terminateOnUpdate", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", + "stability": "experimental", + "summary": "Only meaningful if `terminateOnUpdate` is `false`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 204 + }, + "name": "updateTimeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "docs": { + "remarks": "If you specify a specific AMI, this property will be ignored.", + "stability": "experimental", + "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 207 + }, + "name": "updateToLatestImageVersion", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:FargateComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for a FargateComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1065 + }, + "name": "FargateComputeEnvironmentProps", + "symbolId": "lib/managed-compute-environment:FargateComputeEnvironmentProps" + }, + "@aws-cdk/aws-batch-alpha.HostPathVolume": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "@aws-cdk/aws-batch-alpha.EksVolume", + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", + "stability": "experimental", + "summary": "A Kubernetes HostPath volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 840 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 823 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "returns `true` if `x` is a HostPathVolume, `false` otherwise." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 827 + }, + "name": "isHostPathVolume", + "parameters": [ + { + "name": "x", + "type": { + "primitive": "any" + } + } + ], + "returns": { + "type": { + "primitive": "boolean" + } + }, + "static": true + } + ], + "name": "HostPathVolume", + "properties": [ + { + "docs": { + "remarks": "*Note*: HothPath Volumes present many security risks, and should be avoided when possible.", + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", + "stability": "experimental", + "summary": "The path of the file or directory on the host to mount into containers on the pod." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 838 + }, + "name": "path", + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/eks-container-definition:HostPathVolume" + }, + "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", + "stability": "experimental", + "summary": "Options for a kubernetes HostPath volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EksVolumeOptions" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 807 + }, + "name": "HostPathVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "*Note*: HothPath Volumes present many security risks, and should be avoided when possible.", + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", + "stability": "experimental", + "summary": "The path of the file or directory on the host to mount into containers on the pod." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 815 + }, + "name": "hostPath", + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/eks-container-definition:HostPathVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.HostVolume": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "@aws-cdk/aws-batch-alpha.EcsVolume", + "docs": { + "remarks": "This volume will persist on the host at the specified `hostPath`.\nIf the `hostPath` is not specified, Docker will choose the host path. In this case,\nthe data may not persist after the containers that use it stop running.", + "stability": "experimental", + "summary": "Creates a Host volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.HostVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 346 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 333 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "returns `true` if `x` is a `HostVolume`, `false` otherwise." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 337 + }, + "name": "isHostVolume", + "parameters": [ + { + "name": "x", + "type": { + "primitive": "any" + } + } + ], + "returns": { + "type": { + "primitive": "boolean" + } + }, + "static": true + } + ], + "name": "HostVolume", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The path on the host machine this container will have access to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 344 + }, + "name": "hostPath", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:HostVolume" + }, + "@aws-cdk/aws-batch-alpha.HostVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Options for configuring an ECS HostVolume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 318 + }, + "name": "HostVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- Docker will choose the host path.\nThe data may not persist after the containers that use it stop running.", + "stability": "experimental", + "summary": "The path on the host machine this container will have access to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 325 + }, + "name": "hostPath", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:HostVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.IComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Represents a ComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "interfaces": [ + "aws-cdk-lib.IResource" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 8 + }, + "name": "IComputeEnvironment", + "properties": [ + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The ARN of this compute environment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 21 + }, + "name": "computeEnvironmentArn", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 14 + }, + "name": "computeEnvironmentName", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 44 + }, + "name": "enabled", + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- a serviceRole will be created for managed CEs, none for unmanaged CEs", + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 29 + }, + "name": "serviceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + } + ], + "symbolId": "lib/compute-environment-base:IComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A container that can be run with ECS orchestration." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", + "interfaces": [ + "constructs.IConstruct" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 361 + }, + "methods": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Add a Volume to this container." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 466 + }, + "name": "addVolume", + "parameters": [ + { + "name": "volume", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + } + } + ] + } + ], + "name": "IEcsContainerDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", + "stability": "experimental", + "summary": "The number of vCPUs reserved for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 372 + }, + "name": "cpu", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "see": "https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html", + "stability": "experimental", + "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 402 + }, + "name": "executionRole", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 365 + }, + "name": "image", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "abstract": true, + "docs": { + "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", + "stability": "experimental", + "summary": "The memory hard limit present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 379 + }, + "name": "memory", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "- no volumes", + "remarks": "Automatically added to the job definition.", + "stability": "experimental", + "summary": "The volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 454 + }, + "name": "volumes", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "see": "https://docs.docker.com/engine/reference/builder/#cmd", + "stability": "experimental", + "summary": "The command that's passed to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 386 + }, + "name": "command", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no environment variables", + "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", + "stability": "experimental", + "summary": "The environment variables to pass to a container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 395 + }, + "name": "environment", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no jobRole", + "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html", + "stability": "experimental", + "summary": "The role that the container can assume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 411 + }, + "name": "jobRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "stability": "experimental", + "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 418 + }, + "name": "linuxParameters", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The configuration of the log driver." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 423 + }, + "name": "logDriverConfig", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Gives the container readonly access to its root filesystem." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 430 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- no secrets", + "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html", + "stability": "experimental", + "summary": "A map from environment variable names to the secrets for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 440 + }, + "name": "secrets", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no user", + "stability": "experimental", + "summary": "The user name to use inside the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 447 + }, + "name": "user", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:IEcsContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A container orchestrated by ECS that uses EC2 resources." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 836 + }, + "methods": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Add a ulimit to this container." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 861 + }, + "name": "addUlimit", + "parameters": [ + { + "name": "ulimit", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" + } + } + ] + } + ], + "name": "IEcsEc2ContainerDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Limits to set for the user this docker container will run as." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 847 + }, + "name": "ulimits", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no gpus", + "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", + "stability": "experimental", + "summary": "The number of physical GPUs to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 856 + }, + "name": "gpu", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 842 + }, + "name": "privileged", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:IEcsEc2ContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 957 + }, + "name": "IEcsFargateContainerDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", + "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html", + "stability": "experimental", + "summary": "Indicates whether the job has a public IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 967 + }, + "name": "assignPublicIp", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- 20 GiB", + "stability": "experimental", + "summary": "The size for ephemeral storage." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 981 + }, + "name": "ephemeralStorageSize", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "LATEST", + "stability": "experimental", + "summary": "Which version of Fargate to use when running this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 974 + }, + "name": "fargatePlatformVersion", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" + } + } + ], + "symbolId": "lib/ecs-container-definition:IEcsFargateContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.IEksContainerDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A container that can be run with EKS orchestration on EC2 resources." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", + "interfaces": [ + "constructs.IConstruct" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 13 + }, + "methods": [ + { + "abstract": true, + "docs": { + "remarks": "Automatically added to the Pod.", + "stability": "experimental", + "summary": "Mount a Volume to this container." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 250 + }, + "name": "addVolume", + "parameters": [ + { + "name": "volume", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" + } + } + ] + } + ], + "name": "IEksContainerDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The image that this container will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 17 + }, + "name": "image", + "type": { + "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" + } + }, + { + "abstract": true, + "docs": { + "remarks": "Automatically added to the Pod.", + "see": "https://kubernetes.io/docs/concepts/storage/volumes/", + "stability": "experimental", + "summary": "The Volumes to mount to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 245 + }, + "name": "volumes", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", + "see": "https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/", + "stability": "experimental", + "summary": "An array of arguments to the entrypoint." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 32 + }, + "name": "args", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", + "see": "https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint", + "stability": "experimental", + "summary": "The entrypoint for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 49 + }, + "name": "command", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- No CPU limit", + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 131 + }, + "name": "cpuLimit", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- No CPUs reserved", + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 146 + }, + "name": "cpuReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", + "stability": "experimental", + "summary": "The environment variables to pass to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 57 + }, + "name": "env", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "string" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- No GPU limit", + "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The hard limit of GPUs to present to this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 159 + }, + "name": "gpuLimit", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- No GPUs reserved", + "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", + "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", + "stability": "experimental", + "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 173 + }, + "name": "gpuReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise", + "see": "https://kubernetes.io/docs/concepts/containers/images/#updating-images", + "stability": "experimental", + "summary": "The image pull policy for this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 66 + }, + "name": "imagePullPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" + } + }, + { + "abstract": true, + "docs": { + "default": "- No memory limit", + "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", + "stability": "experimental", + "summary": "The amount (in MiB) of memory to present to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 91 + }, + "name": "memoryLimit", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "- No memory reserved", + "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", + "stability": "experimental", + "summary": "The soft limit (in MiB) of memory to reserve for the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 116 + }, + "name": "memoryReservation", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": ": `'Default'`", + "stability": "experimental", + "summary": "The name of this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 73 + }, + "name": "name", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", + "stability": "experimental", + "summary": "If specified, gives this container elevated permissions on the host container instance." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 187 + }, + "name": "privileged", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", + "stability": "experimental", + "summary": "If specified, gives this container readonly access to its root file system." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 200 + }, + "name": "readonlyRootFilesystem", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, the container is run as the specified group ID (`gid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 213 + }, + "name": "runAsGroup", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- the container is *not* required to run as a non-root user", + "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, the container is run as a user with a `uid` other than 0." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 225 + }, + "name": "runAsRoot", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- the user that is specified in the image metadata.", + "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", + "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", + "stability": "experimental", + "summary": "If specified, this container is run as the specified user ID (`uid`)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 237 + }, + "name": "runAsUser", + "optional": true, + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/eks-container-definition:IEksContainerDefinition" + }, + "@aws-cdk/aws-batch-alpha.IEksJobDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A JobDefinition that uses Eks orchestration." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IJobDefinition" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 10 + }, + "name": "IEksJobDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The container this Job Definition will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 14 + }, + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" + } + }, + { + "abstract": true, + "docs": { + "default": "`DnsPolicy.CLUSTER_FIRST`", + "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", + "stability": "experimental", + "summary": "The DNS Policy of the pod used by this Job Definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 23 + }, + "name": "dnsPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" + } + }, + { + "abstract": true, + "docs": { + "default": "- the default service account of the container", + "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", + "see": "https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html", + "stability": "experimental", + "summary": "The name of the service account that's used to run the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 48 + }, + "name": "serviceAccount", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", + "see": "https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking", + "stability": "experimental", + "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-job-definition.ts", + "line": 35 + }, + "name": "useHostNetwork", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-job-definition:IEksJobDefinition" + }, + "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "remarks": "The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\nIt does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\neach share are currently being executed by the ComputeEnvironment*. The weight factors associated with\neach share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\nfairshare policies.", + "stability": "experimental", + "summary": "Represents a Fairshare Scheduling Policy. Instructs the scheduler to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 92 + }, + "name": "IFairshareSchedulingPolicy", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", + "stability": "experimental", + "summary": "The shares that this Scheduling Policy applies to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 130 + }, + "name": "shares", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Share" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no vCPU is reserved", + "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", + "stability": "experimental", + "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 111 + }, + "name": "computeReservation", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- 0: only the current job usage is considered", + "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", + "stability": "experimental", + "summary": "The amount of time to use to measure the usage of each job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 123 + }, + "name": "shareDecay", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/scheduling-policy:IFairshareSchedulingPolicy" + }, + "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1060 + }, + "name": "IFargateComputeEnvironment", + "symbolId": "lib/managed-compute-environment:IFargateComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.IJobDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Represents a JobDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "interfaces": [ + "aws-cdk-lib.IResource" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 8 + }, + "methods": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Add a RetryStrategy to this JobDefinition." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 70 + }, + "name": "addRetryStrategy", + "parameters": [ + { + "name": "strategy", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + } + } + ] + } + ], + "name": "IJobDefinition", + "properties": [ + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The ARN of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 14 + }, + "name": "jobDefinitionArn", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The name of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 21 + }, + "name": "jobDefinitionName", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- no `RetryStrategy`", + "stability": "experimental", + "summary": "Defines the retry behavior for this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 47 + }, + "name": "retryStrategies", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters", + "stability": "experimental", + "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 32 + }, + "name": "parameters", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "any" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "1", + "remarks": "The job is retried on failure the same number of attempts as the value.", + "stability": "experimental", + "summary": "The number of times to retry a job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 40 + }, + "name": "retryAttempts", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", + "stability": "experimental", + "summary": "The priority of this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 56 + }, + "name": "schedulingPriority", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no timeout", + "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", + "stability": "experimental", + "summary": "The timeout time for jobs that are submitted with this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 65 + }, + "name": "timeout", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/job-definition-base:IJobDefinition" + }, + "@aws-cdk/aws-batch-alpha.IJobQueue": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Represents a JobQueue." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue", + "interfaces": [ + "aws-cdk-lib.IResource" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 10 + }, + "methods": [ + { + "abstract": true, + "docs": { + "remarks": "The Queue will prefer lower-order `ComputeEnvironment`s.", + "stability": "experimental", + "summary": "Add a `ComputeEnvironment` to this Queue." + }, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 66 + }, + "name": "addComputeEnvironment", + "parameters": [ + { + "name": "computeEnvironment", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + } + }, + { + "name": "order", + "type": { + "primitive": "number" + } + } + ] + } + ], + "name": "IJobQueue", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", + "stability": "experimental", + "summary": "The set of compute environments mapped to a job queue and their order relative to each other." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 37 + }, + "name": "computeEnvironments", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The ARN of this job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 24 + }, + "name": "jobQueueArn", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", + "stability": "experimental", + "summary": "The name of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 17 + }, + "name": "jobQueueName", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.", + "stability": "experimental", + "summary": "The priority of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 45 + }, + "name": "priority", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", + "stability": "experimental", + "summary": "If the job queue is enabled, it is able to accept jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 53 + }, + "name": "enabled", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- no scheduling policy", + "remarks": "Instructs the Scheduler how to schedule different jobs.", + "stability": "experimental", + "summary": "The SchedulingPolicy for this JobQueue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 60 + }, + "name": "schedulingPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" + } + } + ], + "symbolId": "lib/job-queue:IJobQueue" + }, + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "remarks": "Batch will provision EC2 Instances to\nmeet the requirements of the jobs executing in this ComputeEnvironment.", + "stability": "experimental", + "summary": "Represents a Managed ComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "aws-cdk-lib.aws_ec2.IConnectable", + "aws-cdk-lib.ITaggable" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 14 + }, + "name": "IManagedComputeEnvironment", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", + "stability": "experimental", + "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 23 + }, + "name": "maxvCpus", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The security groups this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 78 + }, + "name": "securityGroups", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", + "see": "https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html", + "stability": "experimental", + "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 42 + }, + "name": "replaceComputeEnvironment", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", + "stability": "experimental", + "summary": "Whether or not to use spot instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 52 + }, + "name": "spot", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", + "stability": "experimental", + "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 73 + }, + "name": "terminateOnUpdate", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "30 minutes", + "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", + "stability": "experimental", + "summary": "Only meaningful if `terminateOnUpdate` is `false`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 62 + }, + "name": "updateTimeout", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "If you specify a specific AMI, this property will be ignored.", + "stability": "experimental", + "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 93 + }, + "name": "updateToLatestImageVersion", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The VPC Subnets this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 83 + }, + "name": "vpcSubnets", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.SubnetSelection" + } + } + ], + "symbolId": "lib/managed-compute-environment:IManagedComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 235 + }, + "methods": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Add an instance class to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 348 + }, + "name": "addInstanceClass", + "parameters": [ + { + "name": "instanceClass", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + } + } + ] + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Add an instance type to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 343 + }, + "name": "addInstanceType", + "parameters": [ + { + "name": "instanceType", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + } + } + ] + } + ], + "name": "IManagedEc2EcsComputeEnvironment", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the size.", + "stability": "experimental", + "summary": "The instance classes that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 287 + }, + "name": "instanceClasses", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 280 + }, + "name": "instanceTypes", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", + "stability": "experimental", + "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 253 + }, + "name": "allocationStrategy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" + } + }, + { + "abstract": true, + "docs": { + "default": "- ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances", + "remarks": "Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.", + "stability": "experimental", + "summary": "Configure which AMIs this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 244 + }, + "name": "images", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- a role will be created", + "stability": "experimental", + "summary": "The execution Role that instances launched by this Compute Environment will use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 304 + }, + "name": "instanceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "no launch template", + "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", + "stability": "experimental", + "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 317 + }, + "name": "launchTemplate", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" + } + }, + { + "abstract": true, + "docs": { + "default": "0", + "stability": "experimental", + "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 325 + }, + "name": "minvCpus", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no placement group", + "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", + "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", + "stability": "experimental", + "summary": "The EC2 placement group to associate with your compute resources." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 338 + }, + "name": "placementGroup", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" + } + }, + { + "abstract": true, + "docs": { + "default": "- 100%", + "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.", + "stability": "experimental", + "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 265 + }, + "name": "spotBidPercentage", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- a new Role will be created", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html", + "stability": "experimental", + "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 274 + }, + "name": "spotFleetRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", + "stability": "experimental", + "summary": "Whether or not to use batch's optimal instance type." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 297 + }, + "name": "useOptimalInstanceClasses", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:IManagedEc2EcsComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.ISchedulingPolicy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "remarks": "Scheduling Policies tell the Batch\nJob Scheduler how to schedule incoming jobs.", + "stability": "experimental", + "summary": "Represents a Scheduling Policy." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", + "interfaces": [ + "aws-cdk-lib.IResource" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 9 + }, + "name": "ISchedulingPolicy", + "properties": [ + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The arn of this scheduling policy." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 22 + }, + "name": "schedulingPolicyArn", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "custom": { + "attribute": "true" + }, + "stability": "experimental", + "summary": "The name of this scheduling policy." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 15 + }, + "name": "schedulingPolicyName", + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/scheduling-policy:ISchedulingPolicy" + }, + "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "remarks": "Batch will not provision instances on your behalf\nin this ComputeEvironment.", + "stability": "experimental", + "summary": "Represents an UnmanagedComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 11 + }, + "name": "IUnmanagedComputeEnvironment", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", + "stability": "experimental", + "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 19 + }, + "name": "unmanagedvCPUs", + "optional": true, + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/unmanaged-compute-environment:IUnmanagedComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.ImagePullPolicy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Determines when the image is pulled from the registry to launch a container." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy", + "kind": "enum", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 256 + }, + "members": [ + { + "docs": { + "remarks": "If the kubelet has a container image with that exact digest cached locally,\nthe kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest,\nand uses that image to launch the container.", + "see": "https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier", + "stability": "experimental", + "summary": "Every time the kubelet launches a container, the kubelet queries the container image registry to resolve the name to an image digest." + }, + "name": "ALWAYS" + }, + { + "docs": { + "stability": "experimental", + "summary": "The image is pulled only if it is not already present locally." + }, + "name": "IF_NOT_PRESENT" + }, + { + "docs": { + "remarks": "If the image is somehow already present locally,\nthe kubelet attempts to start the container; otherwise, startup fails.\nSee pre-pulled images for more details.", + "see": "https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images", + "stability": "experimental", + "summary": "The kubelet does not try fetching the image." + }, + "name": "NEVER" + } + ], + "name": "ImagePullPolicy", + "symbolId": "lib/eks-container-definition:ImagePullPolicy" + }, + "@aws-cdk/aws-batch-alpha.JobDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props common to all JobDefinitions." + }, + "fqn": "@aws-cdk/aws-batch-alpha.JobDefinitionProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 76 + }, + "name": "JobDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- generated by CloudFormation", + "stability": "experimental", + "summary": "The name of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 82 + }, + "name": "jobDefinitionName", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters", + "stability": "experimental", + "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 93 + }, + "name": "parameters", + "optional": true, + "type": { + "collection": { + "elementtype": { + "primitive": "any" + }, + "kind": "map" + } + } + }, + { + "abstract": true, + "docs": { + "default": "1", + "remarks": "The job is retried on failure the same number of attempts as the value.", + "stability": "experimental", + "summary": "The number of times to retry a job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 101 + }, + "name": "retryAttempts", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no `RetryStrategy`", + "stability": "experimental", + "summary": "Defines the retry behavior for this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 108 + }, + "name": "retryStrategies", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", + "stability": "experimental", + "summary": "The priority of this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 117 + }, + "name": "schedulingPriority", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no timeout", + "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", + "stability": "experimental", + "summary": "The timeout time for jobs that are submitted with this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 126 + }, + "name": "timeout", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/job-definition-base:JobDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.JobQueue": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "remarks": "Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked.", + "stability": "experimental", + "summary": "JobQueues can receive Jobs, which are removed from the queue when sent to the linked ComputeEnvironment(s) to be executed." + }, + "fqn": "@aws-cdk/aws-batch-alpha.JobQueue", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 171 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.JobQueueProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IJobQueue" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 143 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "refer to an existing JobQueue by its arn." + }, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 147 + }, + "name": "fromJobQueueArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "jobQueueArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue" + } + }, + "static": true + }, + { + "docs": { + "remarks": "The Queue will prefer lower-order `ComputeEnvironment`s.", + "stability": "experimental", + "summary": "Add a `ComputeEnvironment` to this Queue." + }, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 206 + }, + "name": "addComputeEnvironment", + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "parameters": [ + { + "name": "computeEnvironment", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + } + }, + { + "name": "order", + "type": { + "primitive": "number" + } + } + ] + } + ], + "name": "JobQueue", + "properties": [ + { + "docs": { + "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", + "stability": "experimental", + "summary": "The set of compute environments mapped to a job queue and their order relative to each other." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 163 + }, + "name": "computeEnvironments", + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 168 + }, + "name": "jobQueueArn", + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", + "stability": "experimental", + "summary": "The name of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 169 + }, + "name": "jobQueueName", + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.", + "stability": "experimental", + "summary": "The priority of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 164 + }, + "name": "priority", + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", + "stability": "experimental", + "summary": "If the job queue is enabled, it is able to accept jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 165 + }, + "name": "enabled", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "Instructs the Scheduler how to schedule different jobs.", + "stability": "experimental", + "summary": "The SchedulingPolicy for this JobQueue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 166 + }, + "name": "schedulingPolicy", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" + } + } + ], + "symbolId": "lib/job-queue:JobQueue" + }, + "@aws-cdk/aws-batch-alpha.JobQueueProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure a JobQueue." + }, + "fqn": "@aws-cdk/aws-batch-alpha.JobQueueProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 72 + }, + "name": "JobQueueProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", + "stability": "experimental", + "summary": "The set of compute environments mapped to a job queue and their order relative to each other." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 86 + }, + "name": "computeEnvironments", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", + "stability": "experimental", + "summary": "If the job queue is enabled, it is able to accept jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 112 + }, + "name": "enabled", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "- no name", + "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", + "stability": "experimental", + "summary": "The name of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 104 + }, + "name": "jobQueueName", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "1", + "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1.", + "stability": "experimental", + "summary": "The priority of the job queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 96 + }, + "name": "priority", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no scheduling policy", + "remarks": "Instructs the Scheduler how to schedule different jobs.", + "stability": "experimental", + "summary": "The SchedulingPolicy for this JobQueue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 119 + }, + "name": "schedulingPolicy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" + } + } + ], + "symbolId": "lib/job-queue:JobQueueProps" + }, + "@aws-cdk/aws-batch-alpha.LinuxParameters": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "constructs.Construct", + "docs": { + "stability": "experimental", + "summary": "Linux-specific options that are applied to the container." + }, + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters", + "initializer": { + "docs": { + "stability": "experimental", + "summary": "Constructs a new instance of the LinuxParameters class." + }, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 87 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParametersProps" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 53 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Adds one or more host devices to a container." + }, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 111 + }, + "name": "addDevices", + "parameters": [ + { + "name": "device", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Device" + }, + "variadic": true + } + ], + "variadic": true + }, + { + "docs": { + "remarks": "Only works with EC2 launch type.", + "stability": "experimental", + "summary": "Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container." + }, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 120 + }, + "name": "addTmpfs", + "parameters": [ + { + "name": "tmpfs", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs" + }, + "variadic": true + } + ], + "variadic": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Renders the Linux parameters to the Batch version of this resource, which does not have 'capabilities' and requires tmpfs.containerPath to be defined." + }, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 128 + }, + "name": "renderLinuxParameters", + "returns": { + "type": { + "fqn": "aws-cdk-lib.aws_batch.CfnJobDefinition.LinuxParametersProperty" + } + } + } + ], + "name": "LinuxParameters", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "Device mounts." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 77 + }, + "name": "devices", + "protected": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Device" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "TmpFs mounts." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 82 + }, + "name": "tmpfs", + "protected": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Whether the init process is enabled." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 57 + }, + "name": "initProcessEnabled", + "optional": true, + "protected": true, + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The max swap memory." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 67 + }, + "name": "maxSwap", + "optional": true, + "protected": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "remarks": "Not valid for Fargate launch type", + "stability": "experimental", + "summary": "The shared memory size (in MiB)." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 62 + }, + "name": "sharedMemorySize", + "optional": true, + "protected": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The swappiness behavior." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 72 + }, + "name": "swappiness", + "optional": true, + "protected": true, + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/linux-parameters:LinuxParameters" + }, + "@aws-cdk/aws-batch-alpha.LinuxParametersProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "The properties for defining Linux-specific options that are applied to the container." + }, + "fqn": "@aws-cdk/aws-batch-alpha.LinuxParametersProps", + "kind": "interface", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 8 + }, + "name": "LinuxParametersProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Specifies whether to run an init process inside the container that forwards signals and reaps processes." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 14 + }, + "name": "initProcessEnabled", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "No swap.", + "remarks": "This parameter\nwill be translated to the --memory-swap option to docker run.\n\nThis parameter is only supported when you are using the EC2 launch type.\nAccepted values are positive integers.", + "stability": "experimental", + "summary": "The total amount of swap memory a container can use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 32 + }, + "name": "maxSwap", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "No shared memory.", + "stability": "experimental", + "summary": "The value for the size of the /dev/shm volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 21 + }, + "name": "sharedMemorySize", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "60", + "remarks": "This parameter\nmaps to the --memory-swappiness option to docker run. The swappiness relates\nto the kernel's tendency to swap memory. A value of 0 will cause swapping to\nnot happen unless absolutely necessary. A value of 100 will cause pages to\nbe swapped very aggressively.\n\nThis parameter is only supported when you are using the EC2 launch type.\nAccepted values are whole numbers between 0 and 100. If a value is not\nspecified for maxSwap then this parameter is ignored.", + "stability": "experimental", + "summary": "This allows you to tune a container's memory swappiness behavior." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 47 + }, + "name": "swappiness", + "optional": true, + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/linux-parameters:LinuxParametersProps" + }, + "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for a ManagedComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 99 + }, + "name": "ManagedComputeEnvironmentProps", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "VPC in which this Compute Environment will launch Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 169 + }, + "name": "vpc", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IVpc" + } + }, + { + "abstract": true, + "docs": { + "default": "256", + "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", + "stability": "experimental", + "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to. Each vCPU is equivalent to 1024 CPU shares." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 111 + }, + "name": "maxvCpus", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", + "see": "https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html", + "stability": "experimental", + "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 132 + }, + "name": "replaceComputeEnvironment", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "new security groups will be created", + "stability": "experimental", + "summary": "The security groups this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 176 + }, + "name": "securityGroups", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", + "stability": "experimental", + "summary": "Whether or not to use spot instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 142 + }, + "name": "spot", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", + "stability": "experimental", + "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 164 + }, + "name": "terminateOnUpdate", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "30 minutes", + "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", + "stability": "experimental", + "summary": "Only meaningful if `terminateOnUpdate` is `false`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 153 + }, + "name": "updateTimeout", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "If you specify a specific AMI, this property will be ignored.", + "stability": "experimental", + "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 193 + }, + "name": "updateToLatestImageVersion", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "abstract": true, + "docs": { + "default": "new subnets will be created", + "stability": "experimental", + "summary": "The VPC Subnets this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 183 + }, + "name": "vpcSubnets", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.SubnetSelection" + } + } + ], + "symbolId": "lib/managed-compute-environment:ManagedComputeEnvironmentProps" + }, + "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::ComputeEnvironment" + }, + "stability": "experimental", + "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 635 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 588 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "refer to an existing ComputeEnvironment by its arn." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 592 + }, + "name": "fromManagedEc2EcsComputeEnvironmentArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "managedEc2EcsComputeEnvironmentArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Add an instance class to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 705 + }, + "name": "addInstanceClass", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "parameters": [ + { + "name": "instanceClass", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + } + } + ] + }, + { + "docs": { + "stability": "experimental", + "summary": "Add an instance type to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 701 + }, + "name": "addInstanceType", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "parameters": [ + { + "name": "instanceType", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + } + } + ] + } + ], + "name": "ManagedEc2EcsComputeEnvironment", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this compute environment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 619 + }, + "name": "computeEnvironmentArn", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 620 + }, + "name": "computeEnvironmentName", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The network connections associated with this resource." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 210 + }, + "name": "connections", + "overrides": "aws-cdk-lib.aws_ec2.IConnectable", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.Connections" + } + }, + { + "docs": { + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 92 + }, + "name": "enabled", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the size.", + "stability": "experimental", + "summary": "The instance classes that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 627 + }, + "name": "instanceClasses", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 626 + }, + "name": "instanceTypes", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", + "stability": "experimental", + "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 201 + }, + "name": "maxvCpus", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The security groups this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 206 + }, + "name": "securityGroups", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "TagManager to set, remove and format tags." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 208 + }, + "name": "tags", + "overrides": "aws-cdk-lib.ITaggable", + "type": { + "fqn": "aws-cdk-lib.TagManager" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 623 + }, + "name": "allocationStrategy", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" + } + }, + { + "docs": { + "remarks": "Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.", + "stability": "experimental", + "summary": "Configure which AMIs this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 622 + }, + "name": "images", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The execution Role that instances launched by this Compute Environment will use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 628 + }, + "name": "instanceRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", + "stability": "experimental", + "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 629 + }, + "name": "launchTemplate", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 630 + }, + "name": "minvCpus", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", + "stability": "experimental", + "summary": "The EC2 placement group to associate with your compute resources." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 631 + }, + "name": "placementGroup", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" + } + }, + { + "docs": { + "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", + "stability": "experimental", + "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 202 + }, + "name": "replaceComputeEnvironment", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 91 + }, + "name": "serviceRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", + "stability": "experimental", + "summary": "Whether or not to use spot instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 203 + }, + "name": "spot", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.", + "stability": "experimental", + "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 624 + }, + "name": "spotBidPercentage", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 625 + }, + "name": "spotFleetRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", + "stability": "experimental", + "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 205 + }, + "name": "terminateOnUpdate", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", + "stability": "experimental", + "summary": "Only meaningful if `terminateOnUpdate` is `false`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 204 + }, + "name": "updateTimeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "docs": { + "remarks": "If you specify a specific AMI, this property will be ignored.", + "stability": "experimental", + "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 207 + }, + "name": "updateToLatestImageVersion", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:ManagedEc2EcsComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for a ManagedEc2EcsComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 469 + }, + "name": "ManagedEc2EcsComputeEnvironmentProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", + "stability": "experimental", + "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 499 + }, + "name": "allocationStrategy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" + } + }, + { + "abstract": true, + "docs": { + "default": "- ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances", + "remarks": "If you specify this property with only `image` specified, then the\n`imageType` will default to `ECS_AL2`. *If your image needs GPU resources,\nspecify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly\njoin the ComputeEnvironment*.", + "stability": "experimental", + "summary": "Configure which AMIs this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 490 + }, + "name": "images", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the instance size.", + "stability": "experimental", + "summary": "The instance classes that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 539 + }, + "name": "instanceClasses", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- a role will be created", + "stability": "experimental", + "summary": "The execution Role that instances launched by this Compute Environment will use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 546 + }, + "name": "instanceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 530 + }, + "name": "instanceTypes", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "no launch template", + "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", + "stability": "experimental", + "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 559 + }, + "name": "launchTemplate", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" + } + }, + { + "abstract": true, + "docs": { + "default": "0", + "stability": "experimental", + "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 567 + }, + "name": "minvCpus", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no placement group", + "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", + "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", + "stability": "experimental", + "summary": "The EC2 placement group to associate with your compute resources." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 580 + }, + "name": "placementGroup", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" + } + }, + { + "abstract": true, + "docs": { + "default": "100%", + "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", + "stability": "experimental", + "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 513 + }, + "name": "spotBidPercentage", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- a new role will be created", + "see": "https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html", + "stability": "experimental", + "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 522 + }, + "name": "spotFleetRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", + "stability": "experimental", + "summary": "Whether or not to use batch's optimal instance type." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 478 + }, + "name": "useOptimalInstanceClasses", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:ManagedEc2EcsComputeEnvironmentProps" + }, + "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::ComputeEnvironment" + }, + "stability": "experimental", + "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 982 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 963 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Add an instance class to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1052 + }, + "name": "addInstanceClass", + "parameters": [ + { + "name": "instanceClass", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + } + } + ] + }, + { + "docs": { + "stability": "experimental", + "summary": "Add an instance type to this compute environment." + }, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 1048 + }, + "name": "addInstanceType", + "parameters": [ + { + "name": "instanceType", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + } + } + ] + } + ], + "name": "ManagedEc2EksComputeEnvironment", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this compute environment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 968 + }, + "name": "computeEnvironmentArn", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 967 + }, + "name": "computeEnvironmentName", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The network connections associated with this resource." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 210 + }, + "name": "connections", + "overrides": "aws-cdk-lib.aws_ec2.IConnectable", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.Connections" + } + }, + { + "docs": { + "remarks": "Please ensure that you have followed the steps at\n\nhttps://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n\nbefore attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\nIf you do not follow the steps in the link, the deployment fail with a message that the\ncompute environment did not stabilize.", + "stability": "experimental", + "summary": "The cluster that backs this Compute Environment. Required for Compute Environments running Kubernetes jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 965 + }, + "name": "eksCluster", + "type": { + "fqn": "aws-cdk-lib.aws_eks.ICluster" + } + }, + { + "docs": { + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 92 + }, + "name": "enabled", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 974 + }, + "name": "instanceClasses", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 973 + }, + "name": "instanceTypes", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", + "stability": "experimental", + "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 201 + }, + "name": "maxvCpus", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The security groups this Compute Environment will launch instances in." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 206 + }, + "name": "securityGroups", + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "TagManager to set, remove and format tags." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 208 + }, + "name": "tags", + "overrides": "aws-cdk-lib.ITaggable", + "type": { + "fqn": "aws-cdk-lib.TagManager" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 971 + }, + "name": "allocationStrategy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Configure which AMIs this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 970 + }, + "name": "images", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The execution Role that instances launched by this Compute Environment will use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 975 + }, + "name": "instanceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "Cannot be 'default', start with 'kube-', or be longer than 64 characters.", + "stability": "experimental", + "summary": "The namespace of the Cluster." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 964 + }, + "name": "kubernetesNamespace", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", + "stability": "experimental", + "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 976 + }, + "name": "launchTemplate", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 977 + }, + "name": "minvCpus", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", + "stability": "experimental", + "summary": "The EC2 placement group to associate with your compute resources." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 978 + }, + "name": "placementGroup", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" + } + }, + { + "docs": { + "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", + "stability": "experimental", + "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 202 + }, + "name": "replaceComputeEnvironment", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 91 + }, + "name": "serviceRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", + "stability": "experimental", + "summary": "Whether or not to use spot instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 203 + }, + "name": "spot", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", + "stability": "experimental", + "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 972 + }, + "name": "spotBidPercentage", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", + "stability": "experimental", + "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 205 + }, + "name": "terminateOnUpdate", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", + "stability": "experimental", + "summary": "Only meaningful if `terminateOnUpdate` is `false`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 204 + }, + "name": "updateTimeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + }, + { + "docs": { + "remarks": "If you specify a specific AMI, this property will be ignored.", + "stability": "experimental", + "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 207 + }, + "name": "updateToLatestImageVersion", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:ManagedEc2EksComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props for a ManagedEc2EksComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 835 + }, + "name": "ManagedEc2EksComputeEnvironmentProps", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "Please ensure that you have followed the steps at\n\nhttps://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n\nbefore attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\nIf you do not follow the steps in the link, the deployment fail with a message that the\ncompute environment did not stabilize.", + "stability": "experimental", + "summary": "The cluster that backs this Compute Environment. Required for Compute Environments running Kubernetes jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 853 + }, + "name": "eksCluster", + "type": { + "fqn": "aws-cdk-lib.aws_eks.ICluster" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The namespace of the Cluster." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 839 + }, + "name": "kubernetesNamespace", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", + "stability": "experimental", + "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 883 + }, + "name": "allocationStrategy", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" + } + }, + { + "abstract": true, + "docs": { + "default": "If `imageKubernetesVersion` is specified,\n- EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\nOtherwise,\n- ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances,", + "stability": "experimental", + "summary": "Configure which AMIs this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 874 + }, + "name": "images", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the instance size.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 914 + }, + "name": "instanceClasses", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- a role will be created", + "stability": "experimental", + "summary": "The execution Role that instances launched by this Compute Environment will use." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 921 + }, + "name": "instanceRole", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "abstract": true, + "docs": { + "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", + "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", + "stability": "experimental", + "summary": "The instance types that this Compute Environment can launch." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 905 + }, + "name": "instanceTypes", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "- no launch template", + "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.**", + "stability": "experimental", + "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 934 + }, + "name": "launchTemplate", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" + } + }, + { + "abstract": true, + "docs": { + "default": "0", + "stability": "experimental", + "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 942 + }, + "name": "minvCpus", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "- no placement group", + "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", + "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", + "stability": "experimental", + "summary": "The EC2 placement group to associate with your compute resources." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 955 + }, + "name": "placementGroup", + "optional": true, + "type": { + "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" + } + }, + { + "abstract": true, + "docs": { + "default": "- 100%", + "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", + "stability": "experimental", + "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 897 + }, + "name": "spotBidPercentage", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", + "stability": "experimental", + "summary": "Whether or not to use batch's optimal instance type." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/managed-compute-environment.ts", + "line": 863 + }, + "name": "useOptimalInstanceClasses", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/managed-compute-environment:ManagedEc2EksComputeEnvironmentProps" + }, + "@aws-cdk/aws-batch-alpha.MultiNodeContainer": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Runs the container on nodes [startNode, endNode]." + }, + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer", + "kind": "interface", + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 47 + }, + "name": "MultiNodeContainer", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The container that this node range will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 65 + }, + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" + } + }, + { + "abstract": true, + "docs": { + "remarks": "The container is run on all nodes in the range [startNode, endNode] (inclusive)", + "stability": "experimental", + "summary": "The index of the last node to run this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 60 + }, + "name": "endNode", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "remarks": "The container is run on all nodes in the range [startNode, endNode] (inclusive)", + "stability": "experimental", + "summary": "The index of the first node to run this container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 53 + }, + "name": "startNode", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/multinode-job-definition:MultiNodeContainer" + }, + "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::JobDefinition" + }, + "stability": "experimental", + "summary": "A JobDefinition that uses Ecs orchestration to run multiple containers." + }, + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 134 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IJobDefinition" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 109 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "refer to an existing JobDefinition by its arn." + }, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 113 + }, + "name": "fromJobDefinitionArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "jobDefinitionArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a container to this multinode job." + }, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 174 + }, + "name": "addContainer", + "parameters": [ + { + "name": "container", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" + } + } + ] + }, + { + "docs": { + "stability": "experimental", + "summary": "Add a RetryStrategy to this JobDefinition." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 259 + }, + "name": "addRetryStrategy", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "parameters": [ + { + "name": "strategy", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + } + } + ] + } + ], + "name": "MultiNodeJobDefinition", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The containers that this multinode job will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 126 + }, + "name": "containers", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" + }, + "kind": "array" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The instance type that this job definition will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 127 + }, + "name": "instanceType", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 131 + }, + "name": "jobDefinitionArn", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 132 + }, + "name": "jobDefinitionName", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Defines the retry behavior for this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 243 + }, + "name": "retryStrategies", + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + }, + "kind": "array" + } + } + }, + { + "docs": { + "remarks": "The main node is responsible for orchestration.", + "stability": "experimental", + "summary": "The index of the main node in this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 128 + }, + "name": "mainNode", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 241 + }, + "name": "parameters", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "collection": { + "elementtype": { + "primitive": "any" + }, + "kind": "map" + } + } + }, + { + "docs": { + "stability": "experimental", + "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 129 + }, + "name": "propagateTags", + "optional": true, + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "remarks": "The job is retried on failure the same number of attempts as the value.", + "stability": "experimental", + "summary": "The number of times to retry a job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 242 + }, + "name": "retryAttempts", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", + "stability": "experimental", + "summary": "The priority of this Job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 244 + }, + "name": "schedulingPriority", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "primitive": "number" + } + }, + { + "docs": { + "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", + "stability": "experimental", + "summary": "The timeout time for jobs that are submitted with this job definition." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 245 + }, + "name": "timeout", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", + "type": { + "fqn": "aws-cdk-lib.Duration" + } + } + ], + "symbolId": "lib/multinode-job-definition:MultiNodeJobDefinition" + }, + "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Props to configure a MultiNodeJobDefinition." + }, + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.JobDefinitionProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 71 + }, + "name": "MultiNodeJobDefinitionProps", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The instance type that this job definition will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 76 + }, + "name": "instanceType", + "type": { + "fqn": "aws-cdk-lib.aws_ec2.InstanceType" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "see": "https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/", + "stability": "experimental", + "summary": "The containers that this multinode job will run." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 85 + }, + "name": "containers", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" + }, + "kind": "array" + } + } + }, + { + "abstract": true, + "docs": { + "default": "0", + "remarks": "The main node is responsible for orchestration.", + "stability": "experimental", + "summary": "The index of the main node in this job." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 93 + }, + "name": "mainNode", + "optional": true, + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "default": "false", + "stability": "experimental", + "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/multinode-job-definition.ts", + "line": 101 + }, + "name": "propagateTags", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/multinode-job-definition:MultiNodeJobDefinitionProps" + }, + "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "remarks": "The JobQueue will prioritize the lowest-order ComputeEnvironment.", + "stability": "experimental", + "summary": "Assigns an order to a ComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment", + "kind": "interface", + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 126 + }, + "name": "OrderedComputeEnvironment", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The ComputeEnvironment to link to this JobQueue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 130 + }, + "name": "computeEnvironment", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The order associated with `computeEnvironment`." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-queue.ts", + "line": 135 + }, + "name": "order", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/job-queue:OrderedComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.Reason": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Common job exit reasons." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Reason", + "initializer": { + "docs": { + "stability": "experimental" + } + }, + "kind": "class", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 201 + }, + "methods": [ + { + "docs": { + "remarks": "Note that all specified conditions must be met for this reason to match.", + "stability": "experimental", + "summary": "A custom Reason that can match on multiple conditions." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 227 + }, + "name": "custom", + "parameters": [ + { + "name": "customReasonProps", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.CustomReason" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + }, + "static": true + } + ], + "name": "Reason", + "properties": [ + { + "const": true, + "docs": { + "stability": "experimental", + "summary": "Will only match if the Docker container could not be pulled." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 212 + }, + "name": "CANNOT_PULL_CONTAINER", + "static": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + }, + { + "const": true, + "docs": { + "stability": "experimental", + "summary": "Will match any non-zero exit code." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 205 + }, + "name": "NON_ZERO_EXIT_CODE", + "static": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + }, + { + "const": true, + "docs": { + "stability": "experimental", + "summary": "Will only match if the Spot instance executing the job was reclaimed." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 219 + }, + "name": "SPOT_INSTANCE_RECLAIMED", + "static": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + } + ], + "symbolId": "lib/job-definition-base:Reason" + }, + "@aws-cdk/aws-batch-alpha.RetryStrategy": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "Define how Jobs using this JobDefinition respond to different exit conditions." + }, + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 150 + }, + "parameters": [ + { + "name": "action", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Action" + } + }, + { + "name": "on", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 132 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Create a new RetryStrategy." + }, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 136 + }, + "name": "of", + "parameters": [ + { + "name": "action", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Action" + } + }, + { + "name": "on", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" + } + }, + "static": true + } + ], + "name": "RetryStrategy", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The action to take when the job exits with the Reason specified." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 143 + }, + "name": "action", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Action" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "If the job exits with this Reason it will trigger the specified Action." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/job-definition-base.ts", + "line": 148 + }, + "name": "on", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Reason" + } + } + ], + "symbolId": "lib/job-definition-base:RetryStrategy" + }, + "@aws-cdk/aws-batch-alpha.Secret": { + "abstract": true, + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "A secret environment variable." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Secret", + "initializer": { + "docs": { + "stability": "experimental" + } + }, + "kind": "class", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 36 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Creates a environment variable value from a secret stored in AWS Secrets Manager." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 58 + }, + "name": "fromSecretsManager", + "parameters": [ + { + "docs": { + "summary": "the secret stored in AWS Secrets Manager." + }, + "name": "secret", + "type": { + "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret" + } + }, + { + "docs": { + "remarks": "Only values in JSON format are supported.\nIf you do not specify a JSON field, then the full content of the secret is\nused.", + "summary": "the name of the field with the value that you want to set as the environment variable value." + }, + "name": "field", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Creates a environment variable value from a secret stored in AWS Secrets Manager." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 77 + }, + "name": "fromSecretsManagerVersion", + "parameters": [ + { + "docs": { + "summary": "the secret stored in AWS Secrets Manager." + }, + "name": "secret", + "type": { + "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret" + } + }, + { + "docs": { + "summary": "the version information to reference the secret." + }, + "name": "versionInfo", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.SecretVersionInfo" + } + }, + { + "docs": { + "remarks": "Only values in JSON format are supported.\nIf you do not specify a JSON field, then the full content of the secret is\nused.", + "summary": "the name of the field with the value that you want to set as the environment variable value." + }, + "name": "field", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + } + }, + "static": true + }, + { + "docs": { + "stability": "experimental", + "summary": "Creates an environment variable value from a parameter stored in AWS Systems Manager Parameter Store." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 41 + }, + "name": "fromSsmParameter", + "parameters": [ + { + "name": "parameter", + "type": { + "fqn": "aws-cdk-lib.aws_ssm.IParameter" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.Secret" + } + }, + "static": true + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Grants reading the secret to a principal." + }, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 98 + }, + "name": "grantRead", + "parameters": [ + { + "name": "grantee", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IGrantable" + } + } + ], + "returns": { + "type": { + "fqn": "aws-cdk-lib.aws_iam.Grant" + } + } + } + ], + "name": "Secret", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The ARN of the secret." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 88 + }, + "name": "arn", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "Whether this secret uses a specific JSON field." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 93 + }, + "name": "hasField", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/ecs-container-definition:Secret" + }, + "@aws-cdk/aws-batch-alpha.SecretPathVolume": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "@aws-cdk/aws-batch-alpha.EksVolume", + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", + "stability": "experimental", + "summary": "Specifies the configuration of a Kubernetes secret volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolume", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 902 + }, + "parameters": [ + { + "name": "options", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions" + } + } + ] + }, + "kind": "class", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 879 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "returns `true` if `x` is a `SecretPathVolume` and `false` otherwise." + }, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 883 + }, + "name": "isSecretPathVolume", + "parameters": [ + { + "name": "x", + "type": { + "primitive": "any" + } + } + ], + "returns": { + "type": { + "primitive": "boolean" + } + }, + "static": true + } + ], + "name": "SecretPathVolume", + "properties": [ + { + "docs": { + "remarks": "Must be a valid DNS subdomain name.", + "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", + "stability": "experimental", + "summary": "The name of the secret." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 893 + }, + "name": "secretName", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "default": "true", + "stability": "experimental", + "summary": "Specifies whether the secret or the secret's keys must be defined." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 900 + }, + "name": "optional", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-container-definition:SecretPathVolume" + }, + "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", + "stability": "experimental", + "summary": "Options for a Kubernetes SecretPath Volume." + }, + "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.EksVolumeOptions" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 857 + }, + "name": "SecretPathVolumeOptions", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "Must be a valid DNS subdomain name.", + "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", + "stability": "experimental", + "summary": "The name of the secret." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 864 + }, + "name": "secretName", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "true", + "stability": "experimental", + "summary": "Specifies whether the secret or the secret's keys must be defined." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/eks-container-definition.ts", + "line": 871 + }, + "name": "optional", + "optional": true, + "type": { + "primitive": "boolean" + } + } + ], + "symbolId": "lib/eks-container-definition:SecretPathVolumeOptions" + }, + "@aws-cdk/aws-batch-alpha.SecretVersionInfo": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "Specify the secret's version id or version stage." + }, + "fqn": "@aws-cdk/aws-batch-alpha.SecretVersionInfo", + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 18 + }, + "name": "SecretVersionInfo", + "properties": [ + { + "abstract": true, + "docs": { + "default": "- use default version id", + "stability": "experimental", + "summary": "version id of the secret." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 24 + }, + "name": "versionId", + "optional": true, + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "default": "- use default version stage", + "stability": "experimental", + "summary": "version stage of the secret." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 30 + }, + "name": "versionStage", + "optional": true, + "type": { + "primitive": "string" + } + } + ], + "symbolId": "lib/ecs-container-definition:SecretVersionInfo" + }, + "@aws-cdk/aws-batch-alpha.Share": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "remarks": "All Job Definitions that\ndeclare a share identifier will be considered members of the Share\ndefined by that share identifier.\n\nThe Scheduler divides the maximum available vCPUs of the ComputeEnvironment\namong Jobs in the Queue based on their shareIdentifier and the weightFactor\nassociated with that shareIdentifier.", + "stability": "experimental", + "summary": "Represents a group of Job Definitions." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Share", + "kind": "interface", + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 60 + }, + "name": "Share", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "All jobs that specify this share identifier\nwhen submitted to the queue will be considered as part of this Share.", + "stability": "experimental", + "summary": "The identifier of this Share." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 65 + }, + "name": "shareIdentifier", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "remarks": "The Scheduler decides which jobs to put in the Compute Environment\nsuch that the following ratio is equal for each job:\n\n`sharevCpu / weightFactor`,\n\nwhere `sharevCpu` is the total amount of vCPU given to that particular share; that is,\nthe sum of the vCPU of each job currently in the Compute Environment for that share.\n\nSee the readme of this module for a detailed example that shows how these are used,\nhow it relates to `computeReservation`, and how `shareDecay` affects these calculations.", + "stability": "experimental", + "summary": "The weight factor given to this Share." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/scheduling-policy.ts", + "line": 79 + }, + "name": "weightFactor", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/scheduling-policy:Share" + }, + "@aws-cdk/aws-batch-alpha.Tmpfs": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "stability": "experimental", + "summary": "The details of a tmpfs mount for a container." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs", + "kind": "interface", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 168 + }, + "name": "Tmpfs", + "properties": [ + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The absolute file path where the tmpfs volume is to be mounted." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 172 + }, + "name": "containerPath", + "type": { + "primitive": "string" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The size (in MiB) of the tmpfs volume." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 177 + }, + "name": "size", + "type": { + "fqn": "aws-cdk-lib.Size" + } + }, + { + "abstract": true, + "docs": { + "default": "none", + "remarks": "For more information, see\n[TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).", + "stability": "experimental", + "summary": "The list of tmpfs volume mount options." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 185 + }, + "name": "mountOptions", + "optional": true, + "type": { + "collection": { + "elementtype": { + "fqn": "@aws-cdk/aws-batch-alpha.TmpfsMountOption" + }, + "kind": "array" + } + } + } + ], + "symbolId": "lib/linux-parameters:Tmpfs" + }, + "@aws-cdk/aws-batch-alpha.TmpfsMountOption": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "The supported options for a tmpfs mount for a container." + }, + "fqn": "@aws-cdk/aws-batch-alpha.TmpfsMountOption", + "kind": "enum", + "locationInModule": { + "filename": "lib/linux-parameters.ts", + "line": 211 + }, + "members": [ + { + "docs": { + "stability": "experimental" + }, + "name": "DEFAULTS" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RO" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RW" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "SUID" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NOSUID" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "DEV" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NODEV" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "EXEC" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NOEXEC" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "SYNC" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "ASYNC" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "DIRSYNC" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "REMOUNT" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "MAND" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NOMAND" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "ATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NOATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "DIRATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NODIRATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "BIND" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RBIND" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "UNBINDABLE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RUNBINDABLE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "PRIVATE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RPRIVATE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "SHARED" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RSHARED" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "SLAVE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RSLAVE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "RELATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NORELATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "STRICTATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NOSTRICTATIME" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "MODE" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "UID" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "GID" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NR_INODES" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "NR_BLOCKS" + }, + { + "docs": { + "stability": "experimental" + }, + "name": "MPOL" + } + ], + "name": "TmpfsMountOption", + "symbolId": "lib/linux-parameters:TmpfsMountOption" + }, + "@aws-cdk/aws-batch-alpha.Ulimit": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "remarks": "Used by the Docker daemon.", + "stability": "experimental", + "summary": "Sets limits for a resource with `ulimit` on linux systems." + }, + "fqn": "@aws-cdk/aws-batch-alpha.Ulimit", + "kind": "interface", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 734 + }, + "name": "Ulimit", + "properties": [ + { + "abstract": true, + "docs": { + "remarks": "The container will\nbe terminated if it exceeds this limit.", + "stability": "experimental", + "summary": "The hard limit for this resource." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 739 + }, + "name": "hardLimit", + "type": { + "primitive": "number" + } + }, + { + "abstract": true, + "docs": { + "stability": "experimental", + "summary": "The resource to limit." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 744 + }, + "name": "name", + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.UlimitName" + } + }, + { + "abstract": true, + "docs": { + "remarks": "The container will\nnot be terminated if it exceeds this limit.", + "stability": "experimental", + "summary": "The reservation for this resource." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 750 + }, + "name": "softLimit", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/ecs-container-definition:Ulimit" + }, + "@aws-cdk/aws-batch-alpha.UlimitName": { + "assembly": "@aws-cdk/aws-batch-alpha", + "docs": { + "stability": "experimental", + "summary": "The resources to be limited." + }, + "fqn": "@aws-cdk/aws-batch-alpha.UlimitName", + "kind": "enum", + "locationInModule": { + "filename": "lib/ecs-container-definition.ts", + "line": 756 + }, + "members": [ + { + "docs": { + "stability": "experimental", + "summary": "max core dump file size." + }, + "name": "CORE" + }, + { + "docs": { + "stability": "experimental", + "summary": "max cpu time (seconds) for a process." + }, + "name": "CPU" + }, + { + "docs": { + "stability": "experimental", + "summary": "max data segment size." + }, + "name": "DATA" + }, + { + "docs": { + "stability": "experimental", + "summary": "max file size." + }, + "name": "FSIZE" + }, + { + "docs": { + "stability": "experimental", + "summary": "max number of file locks." + }, + "name": "LOCKS" + }, + { + "docs": { + "stability": "experimental", + "summary": "max locked memory." + }, + "name": "MEMLOCK" + }, + { + "docs": { + "stability": "experimental", + "summary": "max POSIX message queue size." + }, + "name": "MSGQUEUE" + }, + { + "docs": { + "stability": "experimental", + "summary": "max nice value for any process this user is running." + }, + "name": "NICE" + }, + { + "docs": { + "stability": "experimental", + "summary": "maximum number of open file descriptors." + }, + "name": "NOFILE" + }, + { + "docs": { + "stability": "experimental", + "summary": "maximum number of processes." + }, + "name": "NPROC" + }, + { + "docs": { + "stability": "experimental", + "summary": "size of the process' resident set (in pages)." + }, + "name": "RSS" + }, + { + "docs": { + "stability": "experimental", + "summary": "max realtime priority." + }, + "name": "RTPRIO" + }, + { + "docs": { + "stability": "experimental", + "summary": "timeout for realtime tasks." + }, + "name": "RTTIME" + }, + { + "docs": { + "stability": "experimental", + "summary": "max number of pending signals." + }, + "name": "SIGPENDING" + }, + { + "docs": { + "stability": "experimental", + "summary": "max stack size (in bytes)." + }, + "name": "STACK" + } + ], + "name": "UlimitName", + "symbolId": "lib/ecs-container-definition:UlimitName" + }, + "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment": { + "assembly": "@aws-cdk/aws-batch-alpha", + "base": "aws-cdk-lib.Resource", + "docs": { + "custom": { + "resource": "AWS::Batch::ComputeEnvironment" + }, + "stability": "experimental", + "summary": "Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf." + }, + "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment", + "initializer": { + "docs": { + "stability": "experimental" + }, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 68 + }, + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "props", + "optional": true, + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps" + } + } + ] + }, + "interfaces": [ + "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", + "@aws-cdk/aws-batch-alpha.IComputeEnvironment" + ], + "kind": "class", + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 44 + }, + "methods": [ + { + "docs": { + "stability": "experimental", + "summary": "Import an UnmanagedComputeEnvironment by its arn." + }, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 48 + }, + "name": "fromUnmanagedComputeEnvironmentArn", + "parameters": [ + { + "name": "scope", + "type": { + "fqn": "constructs.Construct" + } + }, + { + "name": "id", + "type": { + "primitive": "string" + } + }, + { + "name": "unmanagedComputeEnvironmentArn", + "type": { + "primitive": "string" + } + } + ], + "returns": { + "type": { + "fqn": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment" + } + }, + "static": true + } + ], + "name": "UnmanagedComputeEnvironment", + "properties": [ + { + "docs": { + "stability": "experimental", + "summary": "The ARN of this compute environment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 65 + }, + "name": "computeEnvironmentArn", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The name of the ComputeEnvironment." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 66 + }, + "name": "computeEnvironmentName", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "string" + } + }, + { + "docs": { + "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", + "stability": "experimental", + "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 92 + }, + "name": "enabled", + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "primitive": "boolean" + } + }, + { + "docs": { + "stability": "experimental", + "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/compute-environment-base.ts", + "line": 91 + }, + "name": "serviceRole", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", + "type": { + "fqn": "aws-cdk-lib.aws_iam.IRole" + } + }, + { + "docs": { + "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", + "stability": "experimental", + "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 64 + }, + "name": "unmanagedvCPUs", + "optional": true, + "overrides": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/unmanaged-compute-environment:UnmanagedComputeEnvironment" + }, + "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps": { + "assembly": "@aws-cdk/aws-batch-alpha", + "datatype": true, + "docs": { + "remarks": "Batch will not provision instances on your behalf\nin this ComputeEvironment.", + "stability": "experimental", + "summary": "Represents an UnmanagedComputeEnvironment." + }, + "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps", + "interfaces": [ + "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps" + ], + "kind": "interface", + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 26 + }, + "name": "UnmanagedComputeEnvironmentProps", + "properties": [ + { + "abstract": true, + "docs": { + "default": "0", + "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", + "stability": "experimental", + "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." + }, + "immutable": true, + "locationInModule": { + "filename": "lib/unmanaged-compute-environment.ts", + "line": 36 + }, + "name": "unmanagedvCpus", + "optional": true, + "type": { + "primitive": "number" + } + } + ], + "symbolId": "lib/unmanaged-compute-environment:UnmanagedComputeEnvironmentProps" + } + }, + "version": "0.0.0", + "fingerprint": "oTncRAlRM55jMKT9Vxi1eKfuNXfCgiLRFVfCY18w+gM=" +} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js b/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js new file mode 100644 index 0000000000000..204b2b9e6ead6 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js @@ -0,0 +1,515 @@ +function _aws_cdk_aws_batch_alpha_IComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_ComputeEnvironmentProps(p) { +} +function _aws_cdk_aws_batch_alpha_EcsJobDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.container)) + _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p.container); + if (p.retryStrategies != null) + for (const o of p.retryStrategies) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_RetryStrategy(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EcsJobDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_IEksJobDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_EksJobDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.container)) + _aws_cdk_aws_batch_alpha_EksContainerDefinition(p.container); + if (!visitedObjects.has(p.dnsPolicy)) + _aws_cdk_aws_batch_alpha_DnsPolicy(p.dnsPolicy); + if (p.retryStrategies != null) + for (const o of p.retryStrategies) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_RetryStrategy(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_DnsPolicy(p) { +} +function _aws_cdk_aws_batch_alpha_EksJobDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_SecretVersionInfo(p) { +} +function _aws_cdk_aws_batch_alpha_Secret(p) { +} +function _aws_cdk_aws_batch_alpha_EcsVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_EcsVolume(p) { +} +function _aws_cdk_aws_batch_alpha_EfsVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_EfsVolume(p) { +} +function _aws_cdk_aws_batch_alpha_HostVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_HostVolume(p) { +} +function _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_EcsContainerDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.linuxParameters)) + _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); + if (p.secrets != null) + for (const o of Object.values(p.secrets)) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_Secret(o); + if (p.volumes != null) + for (const o of p.volumes) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EcsVolume(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_Ulimit(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.name)) + _aws_cdk_aws_batch_alpha_UlimitName(p.name); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_UlimitName(p) { +} +function _aws_cdk_aws_batch_alpha_IEcsEc2ContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.ulimits != null) + for (const o of p.ulimits) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_Ulimit(o); + if (!visitedObjects.has(p.linuxParameters)) + _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); + if (p.secrets != null) + for (const o of Object.values(p.secrets)) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_Secret(o); + if (p.volumes != null) + for (const o of p.volumes) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EcsVolume(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_IEcsFargateContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.linuxParameters)) + _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); + if (p.secrets != null) + for (const o of Object.values(p.secrets)) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_Secret(o); + if (p.volumes != null) + for (const o of p.volumes) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EcsVolume(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_IEksContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_ImagePullPolicy(p) { +} +function _aws_cdk_aws_batch_alpha_EksContainerDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.imagePullPolicy)) + _aws_cdk_aws_batch_alpha_ImagePullPolicy(p.imagePullPolicy); + if (p.volumes != null) + for (const o of p.volumes) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EksVolume(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EksContainerDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_EksVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_EksVolume(p) { +} +function _aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.medium)) + _aws_cdk_aws_batch_alpha_EmptyDirMediumType(p.medium); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EmptyDirMediumType(p) { +} +function _aws_cdk_aws_batch_alpha_EmptyDirVolume(p) { +} +function _aws_cdk_aws_batch_alpha_HostPathVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_HostPathVolume(p) { +} +function _aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(p) { +} +function _aws_cdk_aws_batch_alpha_SecretPathVolume(p) { +} +function _aws_cdk_aws_batch_alpha_IJobDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_JobDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.retryStrategies != null) + for (const o of p.retryStrategies) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_RetryStrategy(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_RetryStrategy(p) { +} +function _aws_cdk_aws_batch_alpha_Action(p) { +} +function _aws_cdk_aws_batch_alpha_CustomReason(p) { +} +function _aws_cdk_aws_batch_alpha_Reason(p) { +} +function _aws_cdk_aws_batch_alpha_IJobQueue(p) { +} +function _aws_cdk_aws_batch_alpha_JobQueueProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.computeEnvironments != null) + for (const o of p.computeEnvironments) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment(o); + if (!visitedObjects.has(p.schedulingPolicy)) + _aws_cdk_aws_batch_alpha_ISchedulingPolicy(p.schedulingPolicy); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.computeEnvironment)) + _aws_cdk_aws_batch_alpha_IComputeEnvironment(p.computeEnvironment); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_JobQueue(p) { +} +function _aws_cdk_aws_batch_alpha_LinuxParametersProps(p) { +} +function _aws_cdk_aws_batch_alpha_LinuxParameters(p) { +} +function _aws_cdk_aws_batch_alpha_Device(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.permissions != null) + for (const o of p.permissions) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_DevicePermission(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_Tmpfs(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.mountOptions != null) + for (const o of p.mountOptions) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_TmpfsMountOption(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_DevicePermission(p) { +} +function _aws_cdk_aws_batch_alpha_TmpfsMountOption(p) { +} +function _aws_cdk_aws_batch_alpha_IManagedComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_ManagedComputeEnvironmentProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.securityGroups != null) + for (const o of p.securityGroups) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_IManagedEc2EcsComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_EcsMachineImage(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.imageType)) + _aws_cdk_aws_batch_alpha_EcsMachineImageType(p.imageType); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EksMachineImage(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.imageType)) + _aws_cdk_aws_batch_alpha_EksMachineImageType(p.imageType); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_EcsMachineImageType(p) { +} +function _aws_cdk_aws_batch_alpha_EksMachineImageType(p) { +} +function _aws_cdk_aws_batch_alpha_AllocationStrategy(p) { +} +function _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.allocationStrategy)) + _aws_cdk_aws_batch_alpha_AllocationStrategy(p.allocationStrategy); + if (p.images != null) + for (const o of p.images) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EcsMachineImage(o); + if (p.instanceClasses != null) + for (const o of p.instanceClasses) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceClass(o); + if (p.instanceTypes != null) + for (const o of p.instanceTypes) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceType(o); + if (p.securityGroups != null) + for (const o of p.securityGroups) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.allocationStrategy)) + _aws_cdk_aws_batch_alpha_AllocationStrategy(p.allocationStrategy); + if (p.images != null) + for (const o of p.images) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_EksMachineImage(o); + if (p.instanceClasses != null) + for (const o of p.instanceClasses) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceClass(o); + if (p.instanceTypes != null) + for (const o of p.instanceTypes) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceType(o); + if (p.securityGroups != null) + for (const o of p.securityGroups) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_IFargateComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.securityGroups != null) + for (const o of p.securityGroups) + if (!visitedObjects.has(o)) + require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_FargateComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_MultiNodeContainer(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (!visitedObjects.has(p.container)) + _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p.container); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.containers != null) + for (const o of p.containers) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_MultiNodeContainer(o); + if (p.retryStrategies != null) + for (const o of p.retryStrategies) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_RetryStrategy(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_MultiNodeJobDefinition(p) { +} +function _aws_cdk_aws_batch_alpha_ISchedulingPolicy(p) { +} +function _aws_cdk_aws_batch_alpha_Share(p) { +} +function _aws_cdk_aws_batch_alpha_IFairshareSchedulingPolicy(p) { +} +function _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps(p) { + if (p == null) + return; + visitedObjects.add(p); + try { + if (p.shares != null) + for (const o of p.shares) + if (!visitedObjects.has(o)) + _aws_cdk_aws_batch_alpha_Share(o); + } + finally { + visitedObjects.delete(p); + } +} +function _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicy(p) { +} +function _aws_cdk_aws_batch_alpha_IUnmanagedComputeEnvironment(p) { +} +function _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps(p) { +} +function _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironment(p) { +} +function print(name, deprecationMessage) { + const deprecated = process.env.JSII_DEPRECATED; + const deprecationMode = ["warn", "fail", "quiet"].includes(deprecated) ? deprecated : "warn"; + const message = `${name} is deprecated.\n ${deprecationMessage.trim()}\n This API will be removed in the next major release.`; + switch (deprecationMode) { + case "fail": + throw new DeprecationError(message); + case "warn": + console.warn("[WARNING]", message); + break; + } +} +function getPropertyDescriptor(obj, prop) { + const descriptor = Object.getOwnPropertyDescriptor(obj, prop); + if (descriptor) { + return descriptor; + } + const proto = Object.getPrototypeOf(obj); + const prototypeDescriptor = proto && getPropertyDescriptor(proto, prop); + if (prototypeDescriptor) { + return prototypeDescriptor; + } + return {}; +} +const visitedObjects = new Set(); +class DeprecationError extends Error { + constructor(...args) { + super(...args); + Object.defineProperty(this, "name", { + configurable: false, + enumerable: true, + value: "DeprecationError", + writable: false, + }); + } +} +module.exports = { print, getPropertyDescriptor, DeprecationError, _aws_cdk_aws_batch_alpha_IComputeEnvironment, _aws_cdk_aws_batch_alpha_ComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_EcsJobDefinitionProps, _aws_cdk_aws_batch_alpha_EcsJobDefinition, _aws_cdk_aws_batch_alpha_IEksJobDefinition, _aws_cdk_aws_batch_alpha_EksJobDefinitionProps, _aws_cdk_aws_batch_alpha_DnsPolicy, _aws_cdk_aws_batch_alpha_EksJobDefinition, _aws_cdk_aws_batch_alpha_SecretVersionInfo, _aws_cdk_aws_batch_alpha_Secret, _aws_cdk_aws_batch_alpha_EcsVolumeOptions, _aws_cdk_aws_batch_alpha_EcsVolume, _aws_cdk_aws_batch_alpha_EfsVolumeOptions, _aws_cdk_aws_batch_alpha_EfsVolume, _aws_cdk_aws_batch_alpha_HostVolumeOptions, _aws_cdk_aws_batch_alpha_HostVolume, _aws_cdk_aws_batch_alpha_IEcsContainerDefinition, _aws_cdk_aws_batch_alpha_EcsContainerDefinitionProps, _aws_cdk_aws_batch_alpha_Ulimit, _aws_cdk_aws_batch_alpha_UlimitName, _aws_cdk_aws_batch_alpha_IEcsEc2ContainerDefinition, _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinition, _aws_cdk_aws_batch_alpha_IEcsFargateContainerDefinition, _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinition, _aws_cdk_aws_batch_alpha_IEksContainerDefinition, _aws_cdk_aws_batch_alpha_ImagePullPolicy, _aws_cdk_aws_batch_alpha_EksContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EksContainerDefinition, _aws_cdk_aws_batch_alpha_EksVolumeOptions, _aws_cdk_aws_batch_alpha_EksVolume, _aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions, _aws_cdk_aws_batch_alpha_EmptyDirMediumType, _aws_cdk_aws_batch_alpha_EmptyDirVolume, _aws_cdk_aws_batch_alpha_HostPathVolumeOptions, _aws_cdk_aws_batch_alpha_HostPathVolume, _aws_cdk_aws_batch_alpha_SecretPathVolumeOptions, _aws_cdk_aws_batch_alpha_SecretPathVolume, _aws_cdk_aws_batch_alpha_IJobDefinition, _aws_cdk_aws_batch_alpha_JobDefinitionProps, _aws_cdk_aws_batch_alpha_RetryStrategy, _aws_cdk_aws_batch_alpha_Action, _aws_cdk_aws_batch_alpha_CustomReason, _aws_cdk_aws_batch_alpha_Reason, _aws_cdk_aws_batch_alpha_IJobQueue, _aws_cdk_aws_batch_alpha_JobQueueProps, _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment, _aws_cdk_aws_batch_alpha_JobQueue, _aws_cdk_aws_batch_alpha_LinuxParametersProps, _aws_cdk_aws_batch_alpha_LinuxParameters, _aws_cdk_aws_batch_alpha_Device, _aws_cdk_aws_batch_alpha_Tmpfs, _aws_cdk_aws_batch_alpha_DevicePermission, _aws_cdk_aws_batch_alpha_TmpfsMountOption, _aws_cdk_aws_batch_alpha_IManagedComputeEnvironment, _aws_cdk_aws_batch_alpha_ManagedComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_IManagedEc2EcsComputeEnvironment, _aws_cdk_aws_batch_alpha_EcsMachineImage, _aws_cdk_aws_batch_alpha_EksMachineImage, _aws_cdk_aws_batch_alpha_EcsMachineImageType, _aws_cdk_aws_batch_alpha_EksMachineImageType, _aws_cdk_aws_batch_alpha_AllocationStrategy, _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironment, _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironment, _aws_cdk_aws_batch_alpha_IFargateComputeEnvironment, _aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_FargateComputeEnvironment, _aws_cdk_aws_batch_alpha_MultiNodeContainer, _aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps, _aws_cdk_aws_batch_alpha_MultiNodeJobDefinition, _aws_cdk_aws_batch_alpha_ISchedulingPolicy, _aws_cdk_aws_batch_alpha_Share, _aws_cdk_aws_batch_alpha_IFairshareSchedulingPolicy, _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps, _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicy, _aws_cdk_aws_batch_alpha_IUnmanagedComputeEnvironment, _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironment }; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts new file mode 100644 index 0000000000000..61426345d5a13 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts @@ -0,0 +1,87 @@ +import * as iam from 'aws-cdk-lib/aws-iam'; +import { IResource, Resource } from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +/** + * Represents a ComputeEnvironment + */ +export interface IComputeEnvironment extends IResource { + /** + * The name of the ComputeEnvironment + * + * @attribute + */ + readonly computeEnvironmentName: string; + /** + * The ARN of this compute environment. + * + * @attribute + */ + readonly computeEnvironmentArn: string; + /** + * The role Batch uses to perform actions on your behalf + * in your account, such as provision instances to run your jobs + * + * @default - a serviceRole will be created for managed CEs, none for unmanaged CEs + */ + readonly serviceRole?: iam.IRole; + /** + * Whether or not this ComputeEnvironment can accept jobs from a Queue. + * Enabled ComputeEnvironments can accept jobs from a Queue and + * can scale instances up or down. + * Disabled ComputeEnvironments cannot accept jobs from a Queue or + * scale instances up or down. + * + * If you change a ComputeEnvironment from enabled to disabled while it is executing jobs, + * Jobs in the `STARTED` or `RUNNING` states will not + * be interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`. + * + * To ensure you aren't billed for unused capacity, set `minvCpus` to `0`. + */ + readonly enabled: boolean; +} +/** + * Props common to all ComputeEnvironments + */ +export interface ComputeEnvironmentProps { + /** + * The name of the ComputeEnvironment + * + * @default - generated by CloudFormation + */ + readonly computeEnvironmentName?: string; + /** + * The role Batch uses to perform actions on your behalf + * in your account, such as provision instances to run your jobs + * + * @default - a serviceRole will be created for managed CEs, none for unmanaged CEs + */ + readonly serviceRole?: iam.IRole; + /** + * Whether or not this ComputeEnvironment can accept jobs from a Queue. + * Enabled ComputeEnvironments can accept jobs from a Queue and + * can scale instances up or down. + * Disabled ComputeEnvironments cannot accept jobs from a Queue or + * scale instances up or down. + * + * If you change a ComputeEnvironment from enabled to disabled while it is executing jobs, + * Jobs in the `STARTED` or `RUNNING` states will not + * be interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`. + * + * To ensure you aren't billed for unused capacity, set `minvCpus` to `0`. + * + * @default true + */ + readonly enabled?: boolean; +} +/** + * Abstract base class for ComputeEnvironments + * + * @internal + */ +export declare abstract class ComputeEnvironmentBase extends Resource implements IComputeEnvironment { + abstract readonly computeEnvironmentName: string; + readonly serviceRole?: iam.IRole | undefined; + readonly enabled: boolean; + abstract readonly computeEnvironmentArn: string; + constructor(scope: Construct, id: string, props?: ComputeEnvironmentProps); +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js new file mode 100644 index 0000000000000..4af677e1944ac --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js @@ -0,0 +1,20 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.ComputeEnvironmentBase = void 0; +const core_1 = require("aws-cdk-lib/core"); +/** + * Abstract base class for ComputeEnvironments + * + * @internal + */ +class ComputeEnvironmentBase extends core_1.Resource { + constructor(scope, id, props) { + super(scope, id, { + physicalName: props?.computeEnvironmentName, + }); + this.serviceRole = props?.serviceRole; + this.enabled = props?.enabled ?? true; + } +} +exports.ComputeEnvironmentBase = ComputeEnvironmentBase; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcHV0ZS1lbnZpcm9ubWVudC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29tcHV0ZS1lbnZpcm9ubWVudC1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLDJDQUF1RDtBQWtGdkQ7Ozs7R0FJRztBQUNILE1BQXNCLHNCQUF1QixTQUFRLGVBQVE7SUFNM0QsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN2RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFlBQVksRUFBRSxLQUFLLEVBQUUsc0JBQXNCO1NBQzVDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxFQUFFLFdBQVcsQ0FBQztRQUN0QyxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssRUFBRSxPQUFPLElBQUksSUFBSSxDQUFDO0tBQ3ZDO0NBQ0Y7QUFkRCx3REFjQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IElSZXNvdXJjZSwgUmVzb3VyY2UgfSBmcm9tICdhd3MtY2RrLWxpYi9jb3JlJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBDb21wdXRlRW52aXJvbm1lbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJQ29tcHV0ZUVudmlyb25tZW50IGV4dGVuZHMgSVJlc291cmNlIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBDb21wdXRlRW52aXJvbm1lbnRcbiAgICpcbiAgICogQGF0dHJpYnV0ZVxuICAgKi9cbiAgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIHRoaXMgY29tcHV0ZSBlbnZpcm9ubWVudC5cbiAgICpcbiAgICogQGF0dHJpYnV0ZVxuICAgKi9cbiAgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIEJhdGNoIHVzZXMgdG8gcGVyZm9ybSBhY3Rpb25zIG9uIHlvdXIgYmVoYWxmXG4gICAqIGluIHlvdXIgYWNjb3VudCwgc3VjaCBhcyBwcm92aXNpb24gaW5zdGFuY2VzIHRvIHJ1biB5b3VyIGpvYnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBhIHNlcnZpY2VSb2xlIHdpbGwgYmUgY3JlYXRlZCBmb3IgbWFuYWdlZCBDRXMsIG5vbmUgZm9yIHVubWFuYWdlZCBDRXNcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VSb2xlPzogaWFtLklSb2xlO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0aGlzIENvbXB1dGVFbnZpcm9ubWVudCBjYW4gYWNjZXB0IGpvYnMgZnJvbSBhIFF1ZXVlLlxuICAgKiBFbmFibGVkIENvbXB1dGVFbnZpcm9ubWVudHMgY2FuIGFjY2VwdCBqb2JzIGZyb20gYSBRdWV1ZSBhbmRcbiAgICogY2FuIHNjYWxlIGluc3RhbmNlcyB1cCBvciBkb3duLlxuICAgKiBEaXNhYmxlZCBDb21wdXRlRW52aXJvbm1lbnRzIGNhbm5vdCBhY2NlcHQgam9icyBmcm9tIGEgUXVldWUgb3JcbiAgICogc2NhbGUgaW5zdGFuY2VzIHVwIG9yIGRvd24uXG4gICAqXG4gICAqIElmIHlvdSBjaGFuZ2UgYSBDb21wdXRlRW52aXJvbm1lbnQgZnJvbSBlbmFibGVkIHRvIGRpc2FibGVkIHdoaWxlIGl0IGlzIGV4ZWN1dGluZyBqb2JzLFxuICAgKiBKb2JzIGluIHRoZSBgU1RBUlRFRGAgb3IgYFJVTk5JTkdgIHN0YXRlcyB3aWxsIG5vdFxuICAgKiBiZSBpbnRlcnJ1cHRlZC4gQXMgam9icyBjb21wbGV0ZSwgdGhlIENvbXB1dGVFbnZpcm9ubWVudCB3aWxsIHNjYWxlIGluc3RhbmNlcyBkb3duIHRvIGBtaW52Q3B1c2AuXG4gICAqXG4gICAqIFRvIGVuc3VyZSB5b3UgYXJlbid0IGJpbGxlZCBmb3IgdW51c2VkIGNhcGFjaXR5LCBzZXQgYG1pbnZDcHVzYCB0byBgMGAuXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkOiBib29sZWFuO1xufVxuXG4vKipcbiAqIFByb3BzIGNvbW1vbiB0byBhbGwgQ29tcHV0ZUVudmlyb25tZW50c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBDb21wdXRlRW52aXJvbm1lbnRcbiAgICpcbiAgICogQGRlZmF1bHQgLSBnZW5lcmF0ZWQgYnkgQ2xvdWRGb3JtYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGNvbXB1dGVFbnZpcm9ubWVudE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIEJhdGNoIHVzZXMgdG8gcGVyZm9ybSBhY3Rpb25zIG9uIHlvdXIgYmVoYWxmXG4gICAqIGluIHlvdXIgYWNjb3VudCwgc3VjaCBhcyBwcm92aXNpb24gaW5zdGFuY2VzIHRvIHJ1biB5b3VyIGpvYnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBhIHNlcnZpY2VSb2xlIHdpbGwgYmUgY3JlYXRlZCBmb3IgbWFuYWdlZCBDRXMsIG5vbmUgZm9yIHVubWFuYWdlZCBDRXNcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VSb2xlPzogaWFtLklSb2xlO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0aGlzIENvbXB1dGVFbnZpcm9ubWVudCBjYW4gYWNjZXB0IGpvYnMgZnJvbSBhIFF1ZXVlLlxuICAgKiBFbmFibGVkIENvbXB1dGVFbnZpcm9ubWVudHMgY2FuIGFjY2VwdCBqb2JzIGZyb20gYSBRdWV1ZSBhbmRcbiAgICogY2FuIHNjYWxlIGluc3RhbmNlcyB1cCBvciBkb3duLlxuICAgKiBEaXNhYmxlZCBDb21wdXRlRW52aXJvbm1lbnRzIGNhbm5vdCBhY2NlcHQgam9icyBmcm9tIGEgUXVldWUgb3JcbiAgICogc2NhbGUgaW5zdGFuY2VzIHVwIG9yIGRvd24uXG4gICAqXG4gICAqIElmIHlvdSBjaGFuZ2UgYSBDb21wdXRlRW52aXJvbm1lbnQgZnJvbSBlbmFibGVkIHRvIGRpc2FibGVkIHdoaWxlIGl0IGlzIGV4ZWN1dGluZyBqb2JzLFxuICAgKiBKb2JzIGluIHRoZSBgU1RBUlRFRGAgb3IgYFJVTk5JTkdgIHN0YXRlcyB3aWxsIG5vdFxuICAgKiBiZSBpbnRlcnJ1cHRlZC4gQXMgam9icyBjb21wbGV0ZSwgdGhlIENvbXB1dGVFbnZpcm9ubWVudCB3aWxsIHNjYWxlIGluc3RhbmNlcyBkb3duIHRvIGBtaW52Q3B1c2AuXG4gICAqXG4gICAqIFRvIGVuc3VyZSB5b3UgYXJlbid0IGJpbGxlZCBmb3IgdW51c2VkIGNhcGFjaXR5LCBzZXQgYG1pbnZDcHVzYCB0byBgMGAuXG4gICAqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIHJlYWRvbmx5IGVuYWJsZWQ/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEFic3RyYWN0IGJhc2UgY2xhc3MgZm9yIENvbXB1dGVFbnZpcm9ubWVudHNcbiAqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgZXh0ZW5kcyBSZXNvdXJjZSBpbXBsZW1lbnRzIElDb21wdXRlRW52aXJvbm1lbnQge1xuICBwdWJsaWMgYWJzdHJhY3QgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgc2VydmljZVJvbGU/OiBpYW0uSVJvbGUgfCB1bmRlZmluZWQ7XG4gIHB1YmxpYyByZWFkb25seSBlbmFibGVkOiBib29sZWFuO1xuICBwdWJsaWMgYWJzdHJhY3QgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBDb21wdXRlRW52aXJvbm1lbnRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgcGh5c2ljYWxOYW1lOiBwcm9wcz8uY29tcHV0ZUVudmlyb25tZW50TmFtZSxcbiAgICB9KTtcblxuICAgIHRoaXMuc2VydmljZVJvbGUgPSBwcm9wcz8uc2VydmljZVJvbGU7XG4gICAgdGhpcy5lbmFibGVkID0gcHJvcHM/LmVuYWJsZWQgPz8gdHJ1ZTtcbiAgfVxufVxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts new file mode 100644 index 0000000000000..4d545c302aeec --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts @@ -0,0 +1,726 @@ +import * as ecs from 'aws-cdk-lib/aws-ecs'; +import { IFileSystem } from 'aws-cdk-lib/aws-efs'; +import * as iam from 'aws-cdk-lib/aws-iam'; +import * as ssm from 'aws-cdk-lib/aws-ssm'; +import * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager'; +import { Size } from 'aws-cdk-lib/core'; +import { Construct, IConstruct } from 'constructs'; +import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; +import { LinuxParameters } from './linux-parameters'; +/** + * Specify the secret's version id or version stage + */ +export interface SecretVersionInfo { + /** + * version id of the secret + * + * @default - use default version id + */ + readonly versionId?: string; + /** + * version stage of the secret + * + * @default - use default version stage + */ + readonly versionStage?: string; +} +/** + * A secret environment variable. + */ +export declare abstract class Secret { + /** + * Creates an environment variable value from a parameter stored in AWS + * Systems Manager Parameter Store. + */ + static fromSsmParameter(parameter: ssm.IParameter): Secret; + /** + * Creates a environment variable value from a secret stored in AWS Secrets + * Manager. + * + * @param secret the secret stored in AWS Secrets Manager + * @param field the name of the field with the value that you want to set as + * the environment variable value. Only values in JSON format are supported. + * If you do not specify a JSON field, then the full content of the secret is + * used. + */ + static fromSecretsManager(secret: secretsmanager.ISecret, field?: string): Secret; + /** + * Creates a environment variable value from a secret stored in AWS Secrets + * Manager. + * + * @param secret the secret stored in AWS Secrets Manager + * @param versionInfo the version information to reference the secret + * @param field the name of the field with the value that you want to set as + * the environment variable value. Only values in JSON format are supported. + * If you do not specify a JSON field, then the full content of the secret is + * used. + */ + static fromSecretsManagerVersion(secret: secretsmanager.ISecret, versionInfo: SecretVersionInfo, field?: string): Secret; + /** + * The ARN of the secret + */ + abstract readonly arn: string; + /** + * Whether this secret uses a specific JSON field + */ + abstract readonly hasField?: boolean; + /** + * Grants reading the secret to a principal + */ + abstract grantRead(grantee: iam.IGrantable): iam.Grant; +} +/** + * Options to configure an EcsVolume + */ +export interface EcsVolumeOptions { + /** + * the name of this volume + */ + readonly name: string; + /** + * the path on the container where this volume is mounted + */ + readonly containerPath: string; + /** + * if set, the container will have readonly access to the volume + * + * @default false + */ + readonly readonly?: boolean; +} +/** + * Represents a Volume that can be mounted to a container that uses ECS + */ +export declare abstract class EcsVolume { + /** + * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html + */ + static efs(options: EfsVolumeOptions): EfsVolume; + /** + * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. + * If the `hostPath` is not specified, Docker will choose the host path. In this case, + * the data may not persist after the containers that use it stop running. + */ + static host(options: HostVolumeOptions): HostVolume; + /** + * The name of this volume + */ + readonly name: string; + /** + * The path on the container that this volume will be mounted to + */ + readonly containerPath: string; + /** + * Whether or not the container has readonly access to this volume + * + * @default false + */ + readonly readonly?: boolean; + constructor(options: EcsVolumeOptions); +} +/** + * Options for configuring an EfsVolume + */ +export interface EfsVolumeOptions extends EcsVolumeOptions { + /** + * The EFS File System that supports this volume + */ + readonly fileSystem: IFileSystem; + /** + * The directory within the Amazon EFS file system to mount as the root directory inside the host. + * If this parameter is omitted, the root of the Amazon EFS volume is used instead. + * Specifying `/` has the same effect as omitting this parameter. + * The maximum length is 4,096 characters. + * + * @default - root of the EFS File System + */ + readonly rootDirectory?: string; + /** + * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server + * + * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html + * + * @default false + */ + readonly enableTransitEncryption?: boolean; + /** + * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server. + * The value must be between 0 and 65,535. + * + * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html + * + * @default - chosen by the EFS Mount Helper + */ + readonly transitEncryptionPort?: number; + /** + * The Amazon EFS access point ID to use. + * If an access point is specified, `rootDirectory` must either be omitted or set to `/` + * which enforces the path set on the EFS access point. + * If an access point is used, `enableTransitEncryption` must be `true`. + * + * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html + * + * @default - no accessPointId + */ + readonly accessPointId?: string; + /** + * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system. + * If specified, `enableTransitEncryption` must be `true`. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints + * + * @default false + */ + readonly useJobRole?: boolean; +} +/** + * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed + */ +export declare class EfsVolume extends EcsVolume { + /** + * Returns true if x is an EfsVolume, false otherwise + */ + static isEfsVolume(x: any): x is EfsVolume; + /** + * The EFS File System that supports this volume + */ + readonly fileSystem: IFileSystem; + /** + * The directory within the Amazon EFS file system to mount as the root directory inside the host. + * If this parameter is omitted, the root of the Amazon EFS volume is used instead. + * Specifying `/` has the same effect as omitting this parameter. + * The maximum length is 4,096 characters. + * + * @default - root of the EFS File System + */ + readonly rootDirectory?: string; + /** + * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server + * + * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html + * + * @default false + */ + readonly enableTransitEncryption?: boolean; + /** + * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server. + * The value must be between 0 and 65,535. + * + * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html + * + * @default - chosen by the EFS Mount Helper + */ + readonly transitEncryptionPort?: number; + /** + * The Amazon EFS access point ID to use. + * If an access point is specified, `rootDirectory` must either be omitted or set to `/` + * which enforces the path set on the EFS access point. + * If an access point is used, `enableTransitEncryption` must be `true`. + * + * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html + * + * @default - no accessPointId + */ + readonly accessPointId?: string; + /** + * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system. + * If specified, `enableTransitEncryption` must be `true`. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints + * + * @default false + */ + readonly useJobRole?: boolean; + constructor(options: EfsVolumeOptions); +} +/** + * Options for configuring an ECS HostVolume + */ +export interface HostVolumeOptions extends EcsVolumeOptions { + /** + * The path on the host machine this container will have access to + * + * @default - Docker will choose the host path. + * The data may not persist after the containers that use it stop running. + */ + readonly hostPath?: string; +} +/** + * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. + * If the `hostPath` is not specified, Docker will choose the host path. In this case, + * the data may not persist after the containers that use it stop running. + */ +export declare class HostVolume extends EcsVolume { + /** + * returns `true` if `x` is a `HostVolume`, `false` otherwise + */ + static isHostVolume(x: any): x is HostVolume; + /** + * The path on the host machine this container will have access to + */ + readonly hostPath?: string; + constructor(options: HostVolumeOptions); +} +/** + * A container that can be run with ECS orchestration + */ +export interface IEcsContainerDefinition extends IConstruct { + /** + * The image that this container will run + */ + readonly image: ecs.ContainerImage; + /** + * The number of vCPUs reserved for the container. + * Each vCPU is equivalent to 1,024 CPU shares. + * For containers running on EC2 resources, you must specify at least one vCPU. + */ + readonly cpu: number; + /** + * The memory hard limit present to the container. + * If your container attempts to exceed the memory specified, the container is terminated. + * You must specify at least 4 MiB of memory for a job. + */ + readonly memory: Size; + /** + * The command that's passed to the container + * + * @see https://docs.docker.com/engine/reference/builder/#cmd + */ + readonly command?: string[]; + /** + * The environment variables to pass to a container. + * Cannot start with `AWS_BATCH`. + * We don't recommend using plaintext environment variables for sensitive information, such as credential data. + * + * @default - no environment variables + */ + readonly environment?: { + [key: string]: string; + }; + /** + * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html + */ + readonly executionRole: iam.IRole; + /** + * The role that the container can assume. + * + * @default - no jobRole + * + * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html + */ + readonly jobRole?: iam.IRole; + /** + * Linux-specific modifications that are applied to the container, such as details for device mappings. + * + * @default none + */ + readonly linuxParameters?: LinuxParameters; + /** + * The configuration of the log driver + */ + readonly logDriverConfig?: ecs.LogDriverConfig; + /** + * Gives the container readonly access to its root filesystem. + * + * @default false + */ + readonly readonlyRootFilesystem?: boolean; + /** + * A map from environment variable names to the secrets for the container. Allows your job definitions + * to reference the secret by the environment variable name defined in this property. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html + * + * @default - no secrets + */ + readonly secrets?: { + [envVarName: string]: Secret; + }; + /** + * The user name to use inside the container + * + * @default - no user + */ + readonly user?: string; + /** + * The volumes to mount to this container. Automatically added to the job definition. + * + * @default - no volumes + */ + readonly volumes: EcsVolume[]; + /** + * Renders this container to CloudFormation + * + * @internal + */ + _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; + /** + * Add a Volume to this container + */ + addVolume(volume: EcsVolume): void; +} +/** + * Props to configure an EcsContainerDefinition + */ +export interface EcsContainerDefinitionProps { + /** + * The image that this container will run + */ + readonly image: ecs.ContainerImage; + /** + * The number of vCPUs reserved for the container. + * Each vCPU is equivalent to 1,024 CPU shares. + * For containers running on EC2 resources, you must specify at least one vCPU. + */ + readonly cpu: number; + /** + * The memory hard limit present to the container. + * If your container attempts to exceed the memory specified, the container is terminated. + * You must specify at least 4 MiB of memory for a job. + */ + readonly memory: Size; + /** + * The command that's passed to the container + * + * @see https://docs.docker.com/engine/reference/builder/#cmd + * + * @default - no command + */ + readonly command?: string[]; + /** + * The environment variables to pass to a container. + * Cannot start with `AWS_BATCH`. + * We don't recommend using plaintext environment variables for sensitive information, such as credential data. + * + * @default - no environment variables + */ + readonly environment?: { + [key: string]: string; + }; + /** + * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html + * + * @default - a Role will be created + */ + readonly executionRole?: iam.IRole; + /** + * The role that the container can assume. + * + * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html + * + * @default - no job role + */ + readonly jobRole?: iam.IRole; + /** + * Linux-specific modifications that are applied to the container, such as details for device mappings. + * + * @default none + */ + readonly linuxParameters?: LinuxParameters; + /** + * The loging configuration for this Job + * + * @default - the log configuration of the Docker daemon + */ + readonly logging?: ecs.LogDriver; + /** + * Gives the container readonly access to its root filesystem. + * + * @default false + */ + readonly readonlyRootFilesystem?: boolean; + /** + * A map from environment variable names to the secrets for the container. Allows your job definitions + * to reference the secret by the environment variable name defined in this property. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html + * + * @default - no secrets + */ + readonly secrets?: { + [envVarName: string]: Secret; + }; + /** + * The user name to use inside the container + * + * @default - no user + */ + readonly user?: string; + /** + * The volumes to mount to this container. Automatically added to the job definition. + * + * @default - no volumes + */ + readonly volumes?: EcsVolume[]; +} +/** + * Abstract base class for ECS Containers + */ +declare abstract class EcsContainerDefinitionBase extends Construct implements IEcsContainerDefinition { + readonly image: ecs.ContainerImage; + readonly cpu: number; + readonly memory: Size; + readonly command?: string[]; + readonly environment?: { + [key: string]: string; + }; + readonly executionRole: iam.IRole; + readonly jobRole?: iam.IRole; + readonly linuxParameters?: LinuxParameters; + readonly logDriverConfig?: ecs.LogDriverConfig; + readonly readonlyRootFilesystem?: boolean; + readonly secrets?: { + [envVarName: string]: Secret; + }; + readonly user?: string; + readonly volumes: EcsVolume[]; + private readonly imageConfig; + constructor(scope: Construct, id: string, props: EcsContainerDefinitionProps); + /** + * @internal + */ + _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; + addVolume(volume: EcsVolume): void; + /** + * @internal + */ + protected _renderResourceRequirements(): { + type: string; + value: string; + }[]; +} +/** + * Sets limits for a resource with `ulimit` on linux systems. + * Used by the Docker daemon. + */ +export interface Ulimit { + /** + * The hard limit for this resource. The container will + * be terminated if it exceeds this limit. + */ + readonly hardLimit: number; + /** + * The resource to limit + */ + readonly name: UlimitName; + /** + * The reservation for this resource. The container will + * not be terminated if it exceeds this limit. + */ + readonly softLimit: number; +} +/** + * The resources to be limited + */ +export declare enum UlimitName { + /** + * max core dump file size + */ + CORE = "core", + /** + * max cpu time (seconds) for a process + */ + CPU = "cpu", + /** + * max data segment size + */ + DATA = "data", + /** + * max file size + */ + FSIZE = "fsize", + /** + * max number of file locks + */ + LOCKS = "locks", + /** + * max locked memory + */ + MEMLOCK = "memlock", + /** + * max POSIX message queue size + */ + MSGQUEUE = "msgqueue", + /** + * max nice value for any process this user is running + */ + NICE = "nice", + /** + * maximum number of open file descriptors + */ + NOFILE = "nofile", + /** + * maximum number of processes + */ + NPROC = "nproc", + /** + * size of the process' resident set (in pages) + */ + RSS = "rss", + /** + * max realtime priority + */ + RTPRIO = "rtprio", + /** + * timeout for realtime tasks + */ + RTTIME = "rttime", + /** + * max number of pending signals + */ + SIGPENDING = "sigpending", + /** + * max stack size (in bytes) + */ + STACK = "stack" +} +/** + * A container orchestrated by ECS that uses EC2 resources + */ +export interface IEcsEc2ContainerDefinition extends IEcsContainerDefinition { + /** + * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user). + * + * @default false + */ + readonly privileged?: boolean; + /** + * Limits to set for the user this docker container will run as + */ + readonly ulimits: Ulimit[]; + /** + * The number of physical GPUs to reserve for the container. + * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed + * the number of available GPUs on the compute resource that the job is launched on. + * + * @default - no gpus + */ + readonly gpu?: number; + /** + * Add a ulimit to this container + */ + addUlimit(ulimit: Ulimit): void; +} +/** + * Props to configure an EcsEc2ContainerDefinition + */ +export interface EcsEc2ContainerDefinitionProps extends EcsContainerDefinitionProps { + /** + * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user). + * + * @default false + */ + readonly privileged?: boolean; + /** + * Limits to set for the user this docker container will run as + * + * @default - no ulimits + */ + readonly ulimits?: Ulimit[]; + /** + * The number of physical GPUs to reserve for the container. + * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed + * the number of available GPUs on the compute resource that the job is launched on. + * + * @default - no gpus + */ + readonly gpu?: number; +} +/** + * A container orchestrated by ECS that uses EC2 resources + */ +export declare class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase implements IEcsEc2ContainerDefinition { + readonly privileged?: boolean; + readonly ulimits: Ulimit[]; + readonly gpu?: number; + constructor(scope: Construct, id: string, props: EcsEc2ContainerDefinitionProps); + /** + * @internal + */ + _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; + /** + * Add a ulimit to this container + */ + addUlimit(ulimit: Ulimit): void; + /** + * @internal + */ + protected _renderResourceRequirements(): { + type: string; + value: string; + }[]; +} +/** + * A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS + */ +export interface IEcsFargateContainerDefinition extends IEcsContainerDefinition { + /** + * Indicates whether the job has a public IP address. + * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet + * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet. + * + * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html + * + * @default false + */ + readonly assignPublicIp?: boolean; + /** + * Which version of Fargate to use when running this container + * + * @default LATEST + */ + readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; + /** + * The size for ephemeral storage. + * + * @default - 20 GiB + */ + readonly ephemeralStorageSize?: Size; +} +/** + * Props to configure an EcsFargateContainerDefinition + */ +export interface EcsFargateContainerDefinitionProps extends EcsContainerDefinitionProps { + /** + * Indicates whether the job has a public IP address. + * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet + * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet. + * + * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html + * + * @default false + */ + readonly assignPublicIp?: boolean; + /** + * Which version of Fargate to use when running this container + * + * @default LATEST + */ + readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; + /** + * The size for ephemeral storage. + * + * @default - 20 GiB + */ + readonly ephemeralStorageSize?: Size; +} +/** + * A container orchestrated by ECS that uses Fargate resources + */ +export declare class EcsFargateContainerDefinition extends EcsContainerDefinitionBase implements IEcsFargateContainerDefinition { + readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; + readonly assignPublicIp?: boolean; + readonly ephemeralStorageSize?: Size; + constructor(scope: Construct, id: string, props: EcsFargateContainerDefinitionProps); + /** + * @internal + */ + _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; +} +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js new file mode 100644 index 0000000000000..1153535f13eac --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js @@ -0,0 +1,531 @@ +"use strict"; +var _a, _b, _c, _d, _e, _f; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcsFargateContainerDefinition = exports.EcsEc2ContainerDefinition = exports.UlimitName = exports.HostVolume = exports.EfsVolume = exports.EcsVolume = exports.Secret = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const iam = require("aws-cdk-lib/aws-iam"); +const core_1 = require("aws-cdk-lib/core"); +const constructs_1 = require("constructs"); +const aws_logs_1 = require("aws-cdk-lib/aws-logs"); +const EFS_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.EfsVolume'); +const HOST_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.HostVolume'); +/** + * A secret environment variable. + */ +class Secret { + /** + * Creates an environment variable value from a parameter stored in AWS + * Systems Manager Parameter Store. + */ + static fromSsmParameter(parameter) { + return { + arn: parameter.parameterArn, + grantRead: grantee => parameter.grantRead(grantee), + }; + } + /** + * Creates a environment variable value from a secret stored in AWS Secrets + * Manager. + * + * @param secret the secret stored in AWS Secrets Manager + * @param field the name of the field with the value that you want to set as + * the environment variable value. Only values in JSON format are supported. + * If you do not specify a JSON field, then the full content of the secret is + * used. + */ + static fromSecretsManager(secret, field) { + return { + arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn, + hasField: !!field, + grantRead: grantee => secret.grantRead(grantee), + }; + } + /** + * Creates a environment variable value from a secret stored in AWS Secrets + * Manager. + * + * @param secret the secret stored in AWS Secrets Manager + * @param versionInfo the version information to reference the secret + * @param field the name of the field with the value that you want to set as + * the environment variable value. Only values in JSON format are supported. + * If you do not specify a JSON field, then the full content of the secret is + * used. + */ + static fromSecretsManagerVersion(secret, versionInfo, field) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretVersionInfo(versionInfo); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.fromSecretsManagerVersion); + } + throw error; + } + return { + arn: `${secret.secretArn}:${field ?? ''}:${versionInfo.versionStage ?? ''}:${versionInfo.versionId ?? ''}`, + hasField: !!field, + grantRead: grantee => secret.grantRead(grantee), + }; + } +} +exports.Secret = Secret; +_a = JSII_RTTI_SYMBOL_1; +Secret[_a] = { fqn: "@aws-cdk/aws-batch-alpha.Secret", version: "0.0.0" }; +/** + * Represents a Volume that can be mounted to a container that uses ECS + */ +class EcsVolume { + /** + * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html + */ + static efs(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EfsVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.efs); + } + throw error; + } + return new EfsVolume(options); + } + /** + * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. + * If the `hostPath` is not specified, Docker will choose the host path. In this case, + * the data may not persist after the containers that use it stop running. + */ + static host(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.host); + } + throw error; + } + return new HostVolume(options); + } + constructor(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EcsVolume); + } + throw error; + } + this.name = options.name; + this.containerPath = options.containerPath; + this.readonly = options.readonly; + } +} +exports.EcsVolume = EcsVolume; +_b = JSII_RTTI_SYMBOL_1; +EcsVolume[_b] = { fqn: "@aws-cdk/aws-batch-alpha.EcsVolume", version: "0.0.0" }; +/** + * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed + */ +class EfsVolume extends EcsVolume { + /** + * Returns true if x is an EfsVolume, false otherwise + */ + static isEfsVolume(x) { + return x !== null && typeof (x) === 'object' && EFS_VOLUME_SYMBOL in x; + } + constructor(options) { + super(options); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EfsVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EfsVolume); + } + throw error; + } + this.fileSystem = options.fileSystem; + this.rootDirectory = options.rootDirectory; + this.enableTransitEncryption = options.enableTransitEncryption; + this.transitEncryptionPort = options.transitEncryptionPort; + this.accessPointId = options.accessPointId; + this.useJobRole = options.useJobRole; + } +} +exports.EfsVolume = EfsVolume; +_c = JSII_RTTI_SYMBOL_1; +EfsVolume[_c] = { fqn: "@aws-cdk/aws-batch-alpha.EfsVolume", version: "0.0.0" }; +Object.defineProperty(EfsVolume.prototype, EFS_VOLUME_SYMBOL, { + value: true, + enumerable: false, + writable: false, +}); +/** + * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. + * If the `hostPath` is not specified, Docker will choose the host path. In this case, + * the data may not persist after the containers that use it stop running. + */ +class HostVolume extends EcsVolume { + /** + * returns `true` if `x` is a `HostVolume`, `false` otherwise + */ + static isHostVolume(x) { + return x !== null && typeof (x) === 'object' && HOST_VOLUME_SYMBOL in x; + } + constructor(options) { + super(options); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, HostVolume); + } + throw error; + } + this.hostPath = options.hostPath; + } +} +exports.HostVolume = HostVolume; +_d = JSII_RTTI_SYMBOL_1; +HostVolume[_d] = { fqn: "@aws-cdk/aws-batch-alpha.HostVolume", version: "0.0.0" }; +Object.defineProperty(HostVolume.prototype, HOST_VOLUME_SYMBOL, { + value: true, + enumerable: false, + writable: false, +}); +/** + * Abstract base class for ECS Containers + */ +class EcsContainerDefinitionBase extends constructs_1.Construct { + constructor(scope, id, props) { + super(scope, id); + this.image = props.image; + this.cpu = props.cpu; + this.command = props.command; + this.environment = props.environment; + this.executionRole = props.executionRole ?? createExecutionRole(this, 'ExecutionRole', props.logging ? true : false); + this.jobRole = props.jobRole; + this.linuxParameters = props.linuxParameters; + this.memory = props.memory; + if (props.logging) { + this.logDriverConfig = props.logging.bind(this, { + ...this, + // TS! + taskDefinition: { + obtainExecutionRole: () => this.executionRole, + }, + }); + } + this.readonlyRootFilesystem = props.readonlyRootFilesystem ?? false; + this.secrets = props.secrets; + this.user = props.user; + this.volumes = props.volumes ?? []; + this.imageConfig = props.image.bind(this, { + ...this, + taskDefinition: { + obtainExecutionRole: () => this.executionRole, + }, + }); + } + /** + * @internal + */ + _renderContainerDefinition() { + return { + image: this.imageConfig.imageName, + command: this.command, + environment: Object.keys(this.environment ?? {}).map((envKey) => ({ + name: envKey, + value: (this.environment ?? {})[envKey], + })), + jobRoleArn: this.jobRole?.roleArn, + executionRoleArn: this.executionRole?.roleArn, + linuxParameters: this.linuxParameters && this.linuxParameters.renderLinuxParameters(), + logConfiguration: this.logDriverConfig, + readonlyRootFilesystem: this.readonlyRootFilesystem, + resourceRequirements: this._renderResourceRequirements(), + secrets: this.secrets ? Object.entries(this.secrets).map(([name, secret]) => { + secret.grantRead(this.executionRole); + return { + name, + valueFrom: secret.arn, + }; + }) : undefined, + mountPoints: core_1.Lazy.any({ + produce: () => { + if (this.volumes.length === 0) { + return undefined; + } + return this.volumes.map((volume) => { + return { + containerPath: volume.containerPath, + readOnly: volume.readonly, + sourceVolume: volume.name, + }; + }); + }, + }), + volumes: core_1.Lazy.any({ + produce: () => { + if (this.volumes.length === 0) { + return undefined; + } + return this.volumes.map((volume) => { + if (EfsVolume.isEfsVolume(volume)) { + return { + name: volume.name, + efsVolumeConfiguration: { + fileSystemId: volume.fileSystem.fileSystemId, + rootDirectory: volume.rootDirectory, + transitEncryption: volume.enableTransitEncryption ? 'ENABLED' : (volume.enableTransitEncryption === false ? 'DISABLED' : undefined), + transitEncryptionPort: volume.transitEncryptionPort, + authorizationConfig: volume.accessPointId || volume.useJobRole ? { + accessPointId: volume.accessPointId, + iam: volume.useJobRole ? 'ENABLED' : (volume.useJobRole === false ? 'DISABLED' : undefined), + } : undefined, + }, + }; + } + else if (HostVolume.isHostVolume(volume)) { + return { + name: volume.name, + host: { + sourcePath: volume.hostPath, + }, + }; + } + throw new Error('unsupported Volume encountered'); + }); + }, + }), + user: this.user, + }; + } + addVolume(volume) { + this.volumes.push(volume); + } + /** + * @internal + */ + _renderResourceRequirements() { + const resourceRequirements = []; + resourceRequirements.push({ + type: 'MEMORY', + value: this.memory.toMebibytes().toString(), + }); + resourceRequirements.push({ + type: 'VCPU', + value: this.cpu.toString(), + }); + return resourceRequirements; + } +} +/** + * The resources to be limited + */ +var UlimitName; +(function (UlimitName) { + /** + * max core dump file size + */ + UlimitName["CORE"] = "core"; + /** + * max cpu time (seconds) for a process + */ + UlimitName["CPU"] = "cpu"; + /** + * max data segment size + */ + UlimitName["DATA"] = "data"; + /** + * max file size + */ + UlimitName["FSIZE"] = "fsize"; + /** + * max number of file locks + */ + UlimitName["LOCKS"] = "locks"; + /** + * max locked memory + */ + UlimitName["MEMLOCK"] = "memlock"; + /** + * max POSIX message queue size + */ + UlimitName["MSGQUEUE"] = "msgqueue"; + /** + * max nice value for any process this user is running + */ + UlimitName["NICE"] = "nice"; + /** + * maximum number of open file descriptors + */ + UlimitName["NOFILE"] = "nofile"; + /** + * maximum number of processes + */ + UlimitName["NPROC"] = "nproc"; + /** + * size of the process' resident set (in pages) + */ + UlimitName["RSS"] = "rss"; + /** + * max realtime priority + */ + UlimitName["RTPRIO"] = "rtprio"; + /** + * timeout for realtime tasks + */ + UlimitName["RTTIME"] = "rttime"; + /** + * max number of pending signals + */ + UlimitName["SIGPENDING"] = "sigpending"; + /** + * max stack size (in bytes) + */ + UlimitName["STACK"] = "stack"; +})(UlimitName || (exports.UlimitName = UlimitName = {})); +/** + * A container orchestrated by ECS that uses EC2 resources + */ +class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase { + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EcsEc2ContainerDefinition); + } + throw error; + } + this.privileged = props.privileged; + this.ulimits = props.ulimits ?? []; + this.gpu = props.gpu; + } + /** + * @internal + */ + _renderContainerDefinition() { + return { + ...super._renderContainerDefinition(), + ulimits: core_1.Lazy.any({ + produce: () => { + if (this.ulimits.length === 0) { + return undefined; + } + return this.ulimits.map((ulimit) => ({ + hardLimit: ulimit.hardLimit, + name: ulimit.name, + softLimit: ulimit.softLimit, + })); + }, + }), + privileged: this.privileged, + resourceRequirements: this._renderResourceRequirements(), + }; + } + ; + /** + * Add a ulimit to this container + */ + addUlimit(ulimit) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Ulimit(ulimit); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addUlimit); + } + throw error; + } + this.ulimits.push(ulimit); + } + /** + * @internal + */ + _renderResourceRequirements() { + const resourceRequirements = super._renderResourceRequirements(); + if (this.gpu) { + resourceRequirements.push({ + type: 'GPU', + value: this.gpu.toString(), + }); + } + return resourceRequirements; + } +} +exports.EcsEc2ContainerDefinition = EcsEc2ContainerDefinition; +_e = JSII_RTTI_SYMBOL_1; +EcsEc2ContainerDefinition[_e] = { fqn: "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition", version: "0.0.0" }; +/** + * A container orchestrated by ECS that uses Fargate resources + */ +class EcsFargateContainerDefinition extends EcsContainerDefinitionBase { + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EcsFargateContainerDefinition); + } + throw error; + } + this.assignPublicIp = props.assignPublicIp; + this.fargatePlatformVersion = props.fargatePlatformVersion; + this.ephemeralStorageSize = props.ephemeralStorageSize; + // validates ephemeralStorageSize is within limits + if (props.ephemeralStorageSize) { + if (props.ephemeralStorageSize.toGibibytes() > 200) { + throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} > 200 GB`); + } + else if (props.ephemeralStorageSize.toGibibytes() < 21) { + throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} < 21 GB`); + } + } + } + /** + * @internal + */ + _renderContainerDefinition() { + return { + ...super._renderContainerDefinition(), + ephemeralStorage: this.ephemeralStorageSize ? { + sizeInGiB: this.ephemeralStorageSize?.toGibibytes(), + } : undefined, + fargatePlatformConfiguration: { + platformVersion: this.fargatePlatformVersion?.toString(), + }, + networkConfiguration: { + assignPublicIp: this.assignPublicIp ? 'ENABLED' : 'DISABLED', + }, + }; + } + ; +} +exports.EcsFargateContainerDefinition = EcsFargateContainerDefinition; +_f = JSII_RTTI_SYMBOL_1; +EcsFargateContainerDefinition[_f] = { fqn: "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition", version: "0.0.0" }; +function createExecutionRole(scope, id, logging) { + const execRole = new iam.Role(scope, id, { + assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), + // needed for cross-account access with TagParameterContainerImage + roleName: core_1.PhysicalName.GENERATE_IF_NEEDED, + }); + if (!logging) { + // all jobs will fail without this if they produce any output at all when no logging is specified + aws_logs_1.LogGroup.fromLogGroupName(scope, 'batchDefaultLogGroup', '/aws/batch/job').grantWrite(execRole); + } + return execRole; +} +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-container-definition.js","sourceRoot":"","sources":["ecs-container-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { IFileSystem } from 'aws-cdk-lib/aws-efs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport { Lazy, PhysicalName, Size } from 'aws-cdk-lib/core';\nimport { Construct, IConstruct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { LinuxParameters } from './linux-parameters';\nimport { LogGroup } from 'aws-cdk-lib/aws-logs';\n\nconst EFS_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.EfsVolume');\nconst HOST_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.HostVolume');\n\n/**\n * Specify the secret's version id or version stage\n */\nexport interface SecretVersionInfo {\n  /**\n   * version id of the secret\n   *\n   * @default - use default version id\n   */\n  readonly versionId?: string;\n  /**\n   * version stage of the secret\n   *\n   * @default - use default version stage\n   */\n  readonly versionStage?: string;\n}\n\n/**\n * A secret environment variable.\n */\nexport abstract class Secret {\n  /**\n   * Creates an environment variable value from a parameter stored in AWS\n   * Systems Manager Parameter Store.\n   */\n  public static fromSsmParameter(parameter: ssm.IParameter): Secret {\n    return {\n      arn: parameter.parameterArn,\n      grantRead: grantee => parameter.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManager(secret: secretsmanager.ISecret, field?: string): Secret {\n    return {\n      arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param versionInfo the version information to reference the secret\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManagerVersion(secret: secretsmanager.ISecret, versionInfo: SecretVersionInfo, field?: string): Secret {\n    return {\n      arn: `${secret.secretArn}:${field ?? ''}:${versionInfo.versionStage ?? ''}:${versionInfo.versionId ?? ''}`,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * The ARN of the secret\n   */\n  public abstract readonly arn: string;\n\n  /**\n   * Whether this secret uses a specific JSON field\n   */\n  public abstract readonly hasField?: boolean;\n\n  /**\n   * Grants reading the secret to a principal\n   */\n  public abstract grantRead(grantee: iam.IGrantable): iam.Grant;\n}\n\n/**\n * Options to configure an EcsVolume\n */\nexport interface EcsVolumeOptions {\n  /**\n   * the name of this volume\n   */\n  readonly name: string;\n\n  /**\n   * the path on the container where this volume is mounted\n   */\n  readonly containerPath: string;\n\n  /**\n   * if set, the container will have readonly access to the volume\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n}\n\n/**\n * Represents a Volume that can be mounted to a container that uses ECS\n */\nexport abstract class EcsVolume {\n  /**\n   * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html\n   */\n  static efs(options: EfsVolumeOptions) {\n    return new EfsVolume(options);\n  }\n\n  /**\n   * Creates a Host volume. This volume will persist on the host at the specified `hostPath`.\n   * If the `hostPath` is not specified, Docker will choose the host path. In this case,\n   * the data may not persist after the containers that use it stop running.\n   */\n  static host(options: HostVolumeOptions) {\n    return new HostVolume(options);\n  }\n\n  /**\n   * The name of this volume\n   */\n  public readonly name: string;\n\n  /**\n   * The path on the container that this volume will be mounted to\n   */\n  public readonly containerPath: string;\n\n  /**\n   * Whether or not the container has readonly access to this volume\n   *\n   * @default false\n   */\n  public readonly readonly?: boolean;\n\n  constructor(options: EcsVolumeOptions) {\n    this.name = options.name;\n    this.containerPath = options.containerPath;\n    this.readonly = options.readonly;\n  }\n}\n\n/**\n * Options for configuring an EfsVolume\n */\nexport interface EfsVolumeOptions extends EcsVolumeOptions {\n  /**\n   * The EFS File System that supports this volume\n   */\n  readonly fileSystem: IFileSystem;\n\n  /**\n   * The directory within the Amazon EFS file system to mount as the root directory inside the host.\n   * If this parameter is omitted, the root of the Amazon EFS volume is used instead.\n   * Specifying `/` has the same effect as omitting this parameter.\n   * The maximum length is 4,096 characters.\n   *\n   * @default - root of the EFS File System\n   */\n  readonly rootDirectory?: string;\n\n  /**\n   * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html\n   *\n   * @default false\n   */\n  readonly enableTransitEncryption?: boolean;\n\n  /**\n   * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server.\n   * The value must be between 0 and 65,535.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html\n   *\n   * @default - chosen by the EFS Mount Helper\n   */\n  readonly transitEncryptionPort?: number;\n\n  /**\n   * The Amazon EFS access point ID to use.\n   * If an access point is specified, `rootDirectory` must either be omitted or set to `/`\n   * which enforces the path set on the EFS access point.\n   * If an access point is used, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html\n   *\n   * @default - no accessPointId\n   */\n  readonly accessPointId?: string;\n\n  /**\n   * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system.\n   * If specified, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints\n   *\n   * @default false\n   */\n  readonly useJobRole?: boolean;\n}\n\n/**\n * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed\n */\nexport class EfsVolume extends EcsVolume {\n  /**\n   * Returns true if x is an EfsVolume, false otherwise\n   */\n  public static isEfsVolume(x: any) : x is EfsVolume {\n    return x !== null && typeof(x) === 'object' && EFS_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The EFS File System that supports this volume\n   */\n  public readonly fileSystem: IFileSystem;\n\n  /**\n   * The directory within the Amazon EFS file system to mount as the root directory inside the host.\n   * If this parameter is omitted, the root of the Amazon EFS volume is used instead.\n   * Specifying `/` has the same effect as omitting this parameter.\n   * The maximum length is 4,096 characters.\n   *\n   * @default - root of the EFS File System\n   */\n  public readonly rootDirectory?: string;\n\n  /**\n   * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html\n   *\n   * @default false\n   */\n  public readonly enableTransitEncryption?: boolean;\n\n  /**\n   * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server.\n   * The value must be between 0 and 65,535.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html\n   *\n   * @default - chosen by the EFS Mount Helper\n   */\n  public readonly transitEncryptionPort?: number;\n\n  /**\n   * The Amazon EFS access point ID to use.\n   * If an access point is specified, `rootDirectory` must either be omitted or set to `/`\n   * which enforces the path set on the EFS access point.\n   * If an access point is used, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html\n   *\n   * @default - no accessPointId\n   */\n  public readonly accessPointId?: string;\n\n  /**\n   * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system.\n   * If specified, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints\n   *\n   * @default false\n   */\n  public readonly useJobRole?: boolean;\n\n  constructor(options: EfsVolumeOptions) {\n    super(options);\n\n    this.fileSystem = options.fileSystem;\n    this.rootDirectory = options.rootDirectory;\n    this.enableTransitEncryption = options.enableTransitEncryption;\n    this.transitEncryptionPort = options.transitEncryptionPort;\n    this.accessPointId = options.accessPointId;\n    this.useJobRole = options.useJobRole;\n  }\n}\n\nObject.defineProperty(EfsVolume.prototype, EFS_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for configuring an ECS HostVolume\n */\nexport interface HostVolumeOptions extends EcsVolumeOptions {\n  /**\n   * The path on the host machine this container will have access to\n   *\n   * @default - Docker will choose the host path.\n   * The data may not persist after the containers that use it stop running.\n   */\n  readonly hostPath?: string;\n}\n\n/**\n * Creates a Host volume. This volume will persist on the host at the specified `hostPath`.\n * If the `hostPath` is not specified, Docker will choose the host path. In this case,\n * the data may not persist after the containers that use it stop running.\n */\nexport class HostVolume extends EcsVolume {\n  /**\n   * returns `true` if `x` is a `HostVolume`, `false` otherwise\n   */\n  public static isHostVolume(x: any): x is HostVolume {\n    return x !== null && typeof (x) === 'object' && HOST_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The path on the host machine this container will have access to\n   */\n  public readonly hostPath?: string;\n\n  constructor(options: HostVolumeOptions) {\n    super(options);\n    this.hostPath = options.hostPath;\n  }\n}\n\nObject.defineProperty(HostVolume.prototype, HOST_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * A container that can be run with ECS orchestration\n */\nexport interface IEcsContainerDefinition extends IConstruct {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The number of vCPUs reserved for the container.\n   * Each vCPU is equivalent to 1,024 CPU shares.\n   * For containers running on EC2 resources, you must specify at least one vCPU.\n   */\n  readonly cpu: number;\n\n  /**\n   * The memory hard limit present to the container.\n   * If your container attempts to exceed the memory specified, the container is terminated.\n   * You must specify at least 4 MiB of memory for a job.\n   */\n  readonly memory: Size;\n\n  /**\n   * The command that's passed to the container\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to a container.\n   * Cannot start with `AWS_BATCH`.\n   * We don't recommend using plaintext environment variables for sensitive information, such as credential data.\n   *\n   * @default - no environment variables\n   */\n  readonly environment?: { [key:string]: string };\n\n  /**\n   * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html\n   */\n  readonly executionRole: iam.IRole;\n\n  /**\n   * The role that the container can assume.\n   *\n   * @default - no jobRole\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html\n   */\n  readonly jobRole?: iam.IRole;\n\n  /**\n   * Linux-specific modifications that are applied to the container, such as details for device mappings.\n   *\n   * @default none\n   */\n  readonly linuxParameters?: LinuxParameters;\n\n  /**\n   * The configuration of the log driver\n   */\n  readonly logDriverConfig?: ecs.LogDriverConfig;\n\n  /**\n   * Gives the container readonly access to its root filesystem.\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * A map from environment variable names to the secrets for the container. Allows your job definitions\n   * to reference the secret by the environment variable name defined in this property.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html\n   *\n   * @default - no secrets\n   */\n  readonly secrets?: { [envVarName: string]: Secret };\n\n  /**\n   * The user name to use inside the container\n   *\n   * @default - no user\n   */\n  readonly user?: string;\n\n  /**\n   * The volumes to mount to this container. Automatically added to the job definition.\n   *\n   * @default - no volumes\n   */\n  readonly volumes: EcsVolume[];\n\n  /**\n   * Renders this container to CloudFormation\n   *\n   * @internal\n   */\n  _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty;\n\n  /**\n   * Add a Volume to this container\n   */\n  addVolume(volume: EcsVolume): void;\n}\n\n/**\n * Props to configure an EcsContainerDefinition\n */\nexport interface EcsContainerDefinitionProps {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The number of vCPUs reserved for the container.\n   * Each vCPU is equivalent to 1,024 CPU shares.\n   * For containers running on EC2 resources, you must specify at least one vCPU.\n   */\n  readonly cpu: number;\n\n  /**\n   * The memory hard limit present to the container.\n   * If your container attempts to exceed the memory specified, the container is terminated.\n   * You must specify at least 4 MiB of memory for a job.\n   */\n  readonly memory: Size;\n\n  /**\n   * The command that's passed to the container\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   *\n   * @default - no command\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to a container.\n   * Cannot start with `AWS_BATCH`.\n   * We don't recommend using plaintext environment variables for sensitive information, such as credential data.\n   *\n   * @default - no environment variables\n   */\n  readonly environment?: { [key:string]: string };\n\n  /**\n   * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html\n   *\n   * @default - a Role will be created\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * The role that the container can assume.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html\n   *\n   * @default - no job role\n   */\n  readonly jobRole?: iam.IRole;\n\n  /**\n   * Linux-specific modifications that are applied to the container, such as details for device mappings.\n   *\n   * @default none\n   */\n  readonly linuxParameters?: LinuxParameters;\n\n  /**\n   * The loging configuration for this Job\n   *\n   * @default - the log configuration of the Docker daemon\n   */\n  readonly logging?: ecs.LogDriver;\n\n  /**\n   * Gives the container readonly access to its root filesystem.\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * A map from environment variable names to the secrets for the container. Allows your job definitions\n   * to reference the secret by the environment variable name defined in this property.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html\n   *\n   * @default - no secrets\n   */\n  readonly secrets?: { [envVarName: string]: Secret };\n\n  /**\n   * The user name to use inside the container\n   *\n   * @default - no user\n   */\n  readonly user?: string;\n\n  /**\n   * The volumes to mount to this container. Automatically added to the job definition.\n   *\n   * @default - no volumes\n   */\n  readonly volumes?: EcsVolume[];\n}\n\n/**\n * Abstract base class for ECS Containers\n */\nabstract class EcsContainerDefinitionBase extends Construct implements IEcsContainerDefinition {\n  public readonly image: ecs.ContainerImage;\n  public readonly cpu: number;\n  public readonly memory: Size;\n  public readonly command?: string[];\n  public readonly environment?: { [key:string]: string };\n  public readonly executionRole: iam.IRole;\n  public readonly jobRole?: iam.IRole;\n  public readonly linuxParameters?: LinuxParameters;\n  public readonly logDriverConfig?: ecs.LogDriverConfig;\n  public readonly readonlyRootFilesystem?: boolean;\n  public readonly secrets?: { [envVarName: string]: Secret };\n  public readonly user?: string;\n  public readonly volumes: EcsVolume[];\n\n  private readonly imageConfig: ecs.ContainerImageConfig;\n\n  constructor(scope: Construct, id: string, props: EcsContainerDefinitionProps) {\n    super(scope, id);\n\n    this.image = props.image;\n    this.cpu = props.cpu;\n    this.command = props.command;\n    this.environment = props.environment;\n    this.executionRole = props.executionRole ?? createExecutionRole(this, 'ExecutionRole', props.logging ? true : false);\n    this.jobRole = props.jobRole;\n    this.linuxParameters = props.linuxParameters;\n    this.memory = props.memory;\n\n    if (props.logging) {\n      this.logDriverConfig = props.logging.bind(this, {\n        ...this as any,\n        // TS!\n        taskDefinition: {\n          obtainExecutionRole: () => this.executionRole,\n        },\n      });\n    }\n\n    this.readonlyRootFilesystem = props.readonlyRootFilesystem ?? false;\n    this.secrets = props.secrets;\n    this.user = props.user;\n    this.volumes = props.volumes ?? [];\n\n    this.imageConfig = props.image.bind(this, {\n      ...this as any,\n      taskDefinition: {\n        obtainExecutionRole: () => this.executionRole,\n      },\n    });\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      image: this.imageConfig.imageName,\n      command: this.command,\n      environment: Object.keys(this.environment ?? {}).map((envKey) => ({\n        name: envKey,\n        value: (this.environment ?? {})[envKey],\n      })),\n      jobRoleArn: this.jobRole?.roleArn,\n      executionRoleArn: this.executionRole?.roleArn,\n      linuxParameters: this.linuxParameters && this.linuxParameters.renderLinuxParameters(),\n      logConfiguration: this.logDriverConfig,\n      readonlyRootFilesystem: this.readonlyRootFilesystem,\n      resourceRequirements: this._renderResourceRequirements(),\n      secrets: this.secrets ? Object.entries(this.secrets).map(([name, secret]) => {\n        secret.grantRead(this.executionRole);\n\n        return {\n          name,\n          valueFrom: secret.arn,\n        };\n      }) : undefined,\n      mountPoints: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n          return this.volumes.map((volume) => {\n            return {\n              containerPath: volume.containerPath,\n              readOnly: volume.readonly,\n              sourceVolume: volume.name,\n            };\n          });\n        },\n      }),\n      volumes: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n\n          return this.volumes.map((volume) => {\n            if (EfsVolume.isEfsVolume(volume)) {\n              return {\n                name: volume.name,\n                efsVolumeConfiguration: {\n                  fileSystemId: volume.fileSystem.fileSystemId,\n                  rootDirectory: volume.rootDirectory,\n                  transitEncryption: volume.enableTransitEncryption ? 'ENABLED' : (volume.enableTransitEncryption === false ? 'DISABLED' : undefined),\n                  transitEncryptionPort: volume.transitEncryptionPort,\n                  authorizationConfig: volume.accessPointId || volume.useJobRole ? {\n                    accessPointId: volume.accessPointId,\n                    iam: volume.useJobRole ? 'ENABLED' : (volume.useJobRole === false ? 'DISABLED' : undefined),\n                  } : undefined,\n                },\n              };\n            } else if (HostVolume.isHostVolume(volume)) {\n              return {\n                name: volume.name,\n                host: {\n                  sourcePath: volume.hostPath,\n                },\n              };\n            }\n\n            throw new Error('unsupported Volume encountered');\n          });\n        },\n      }),\n      user: this.user,\n    };\n  }\n\n  public addVolume(volume: EcsVolume): void {\n    this.volumes.push(volume);\n  }\n\n  /**\n   * @internal\n   */\n  protected _renderResourceRequirements() {\n    const resourceRequirements = [];\n\n    resourceRequirements.push({\n      type: 'MEMORY',\n      value: this.memory.toMebibytes().toString(),\n    });\n\n    resourceRequirements.push({\n      type: 'VCPU',\n      value: this.cpu.toString(),\n    });\n\n    return resourceRequirements;\n  }\n}\n\n/**\n * Sets limits for a resource with `ulimit` on linux systems.\n * Used by the Docker daemon.\n */\nexport interface Ulimit {\n  /**\n   * The hard limit for this resource. The container will\n   * be terminated if it exceeds this limit.\n   */\n  readonly hardLimit: number;\n\n  /**\n   * The resource to limit\n   */\n  readonly name: UlimitName;\n\n  /**\n   * The reservation for this resource. The container will\n   * not be terminated if it exceeds this limit.\n   */\n  readonly softLimit: number;\n}\n\n/**\n * The resources to be limited\n */\nexport enum UlimitName {\n  /**\n   * max core dump file size\n   */\n  CORE = 'core',\n\n  /**\n   * max cpu time (seconds) for a process\n   */\n  CPU = 'cpu',\n\n  /**\n   * max data segment size\n   */\n  DATA = 'data',\n\n  /**\n   * max file size\n   */\n  FSIZE = 'fsize',\n\n  /**\n   * max number of file locks\n   */\n  LOCKS = 'locks',\n\n  /**\n   * max locked memory\n   */\n  MEMLOCK = 'memlock',\n\n  /**\n   * max POSIX message queue size\n   */\n  MSGQUEUE = 'msgqueue',\n\n  /**\n   * max nice value for any process this user is running\n   */\n  NICE = 'nice',\n\n  /**\n   * maximum number of open file descriptors\n   */\n  NOFILE = 'nofile',\n\n  /**\n   * maximum number of processes\n   */\n  NPROC = 'nproc',\n\n  /**\n   * size of the process' resident set (in pages)\n   */\n  RSS = 'rss',\n\n  /**\n   * max realtime priority\n   */\n  RTPRIO = 'rtprio',\n\n  /**\n   * timeout for realtime tasks\n   */\n  RTTIME = 'rttime',\n\n  /**\n   * max number of pending signals\n   */\n  SIGPENDING = 'sigpending',\n\n  /**\n   * max stack size (in bytes)\n   */\n  STACK = 'stack',\n}\n\n/**\n * A container orchestrated by ECS that uses EC2 resources\n */\nexport interface IEcsEc2ContainerDefinition extends IEcsContainerDefinition {\n  /**\n   * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user).\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Limits to set for the user this docker container will run as\n   */\n  readonly ulimits: Ulimit[];\n\n  /**\n   * The number of physical GPUs to reserve for the container.\n   * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\n   * the number of available GPUs on the compute resource that the job is launched on.\n   *\n   * @default - no gpus\n   */\n  readonly gpu?: number;\n\n  /**\n   * Add a ulimit to this container\n   */\n  addUlimit(ulimit: Ulimit): void;\n}\n\n/**\n * Props to configure an EcsEc2ContainerDefinition\n */\nexport interface EcsEc2ContainerDefinitionProps extends EcsContainerDefinitionProps {\n  /**\n   * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user).\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Limits to set for the user this docker container will run as\n   *\n   * @default - no ulimits\n   */\n  readonly ulimits?: Ulimit[];\n\n  /**\n   * The number of physical GPUs to reserve for the container.\n   * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\n   * the number of available GPUs on the compute resource that the job is launched on.\n   *\n   * @default - no gpus\n   */\n  readonly gpu?: number;\n}\n\n/**\n * A container orchestrated by ECS that uses EC2 resources\n */\nexport class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase implements IEcsEc2ContainerDefinition {\n  public readonly privileged?: boolean;\n  public readonly ulimits: Ulimit[];\n  public readonly gpu?: number;\n\n  constructor(scope: Construct, id: string, props: EcsEc2ContainerDefinitionProps) {\n    super(scope, id, props);\n    this.privileged = props.privileged;\n    this.ulimits = props.ulimits ?? [];\n    this.gpu = props.gpu;\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      ...super._renderContainerDefinition(),\n      ulimits: Lazy.any({\n        produce: () => {\n          if (this.ulimits.length === 0) {\n            return undefined;\n          }\n\n          return this.ulimits.map((ulimit) => ({\n            hardLimit: ulimit.hardLimit,\n            name: ulimit.name,\n            softLimit: ulimit.softLimit,\n          }));\n        },\n      }),\n      privileged: this.privileged,\n      resourceRequirements: this._renderResourceRequirements(),\n    };\n  };\n\n  /**\n   * Add a ulimit to this container\n   */\n  addUlimit(ulimit: Ulimit): void {\n    this.ulimits.push(ulimit);\n  }\n\n  /**\n   * @internal\n   */\n  protected _renderResourceRequirements() {\n    const resourceRequirements = super._renderResourceRequirements();\n    if (this.gpu) {\n      resourceRequirements.push({\n        type: 'GPU',\n        value: this.gpu.toString(),\n      });\n    }\n\n    return resourceRequirements;\n  }\n}\n\n/**\n * A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS\n */\nexport interface IEcsFargateContainerDefinition extends IEcsContainerDefinition {\n  /**\n   * Indicates whether the job has a public IP address.\n   * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n   * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html\n   *\n   * @default false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Which version of Fargate to use when running this container\n   *\n   * @default LATEST\n   */\n  readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n\n  /**\n   * The size for ephemeral storage.\n   *\n   * @default - 20 GiB\n   */\n  readonly ephemeralStorageSize?: Size;\n}\n\n/**\n * Props to configure an EcsFargateContainerDefinition\n */\nexport interface EcsFargateContainerDefinitionProps extends EcsContainerDefinitionProps {\n  /**\n   * Indicates whether the job has a public IP address.\n   * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n   * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html\n   *\n   * @default false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Which version of Fargate to use when running this container\n   *\n   * @default LATEST\n   */\n  readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n\n  /**\n   * The size for ephemeral storage.\n   *\n   * @default - 20 GiB\n   */\n  readonly ephemeralStorageSize?: Size;\n}\n\n/**\n * A container orchestrated by ECS that uses Fargate resources\n */\nexport class EcsFargateContainerDefinition extends EcsContainerDefinitionBase implements IEcsFargateContainerDefinition {\n  public readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n  public readonly assignPublicIp?: boolean;\n  public readonly ephemeralStorageSize?: Size;\n\n  constructor(scope: Construct, id: string, props: EcsFargateContainerDefinitionProps) {\n    super(scope, id, props);\n    this.assignPublicIp = props.assignPublicIp;\n    this.fargatePlatformVersion = props.fargatePlatformVersion;\n    this.ephemeralStorageSize = props.ephemeralStorageSize;\n\n    // validates ephemeralStorageSize is within limits\n    if (props.ephemeralStorageSize) {\n      if (props.ephemeralStorageSize.toGibibytes() > 200) {\n        throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} > 200 GB`);\n      } else if (props.ephemeralStorageSize.toGibibytes() < 21) {\n        throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} < 21 GB`);\n      }\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      ...super._renderContainerDefinition(),\n      ephemeralStorage: this.ephemeralStorageSize? {\n        sizeInGiB: this.ephemeralStorageSize?.toGibibytes(),\n      } : undefined,\n      fargatePlatformConfiguration: {\n        platformVersion: this.fargatePlatformVersion?.toString(),\n      },\n      networkConfiguration: {\n        assignPublicIp: this.assignPublicIp ? 'ENABLED' : 'DISABLED',\n      },\n    };\n  };\n}\n\nfunction createExecutionRole(scope: Construct, id: string, logging: boolean): iam.IRole {\n  const execRole = new iam.Role(scope, id, {\n    assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n    // needed for cross-account access with TagParameterContainerImage\n    roleName: PhysicalName.GENERATE_IF_NEEDED,\n  });\n\n  if (!logging) {\n    // all jobs will fail without this if they produce any output at all when no logging is specified\n    LogGroup.fromLogGroupName(scope, 'batchDefaultLogGroup', '/aws/batch/job').grantWrite(execRole);\n  }\n\n  return execRole;\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts new file mode 100644 index 0000000000000..f387b11752d75 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts @@ -0,0 +1,67 @@ +import { Construct } from 'constructs'; +import { IEcsContainerDefinition } from './ecs-container-definition'; +import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; +import * as iam from 'aws-cdk-lib/aws-iam'; +import { IJobQueue } from './job-queue'; +/** + * A JobDefinition that uses ECS orchestration + */ +interface IEcsJobDefinition extends IJobDefinition { + /** + * The container that this job will run + */ + readonly container: IEcsContainerDefinition; + /** + * Whether to propogate tags from the JobDefinition + * to the ECS task that Batch spawns + * + * @default false + */ + readonly propagateTags?: boolean; +} +/** + * @internal + */ +export declare enum Compatibility { + EC2 = "EC2", + FARGATE = "FARGATE" +} +/** + * Props for EcsJobDefinition + */ +export interface EcsJobDefinitionProps extends JobDefinitionProps { + /** + * The container that this job will run + */ + readonly container: IEcsContainerDefinition; + /** + * Whether to propogate tags from the JobDefinition + * to the ECS task that Batch spawns + * + * @default false + */ + readonly propagateTags?: boolean; +} +/** + * A JobDefinition that uses ECS orchestration + * + * @resource AWS::Batch::JobDefinition + */ +export declare class EcsJobDefinition extends JobDefinitionBase implements IEcsJobDefinition { + /** + * Import a JobDefinition by its arn. + */ + static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition; + private static getJobDefinitionName; + readonly container: IEcsContainerDefinition; + readonly propagateTags?: boolean; + readonly jobDefinitionArn: string; + readonly jobDefinitionName: string; + constructor(scope: Construct, id: string, props: EcsJobDefinitionProps); + /** + * Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue` + */ + grantSubmitJob(identity: iam.IGrantable, queue: IJobQueue): void; + private renderPlatformCapabilities; +} +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js new file mode 100644 index 0000000000000..e10f4f02ae1a9 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js @@ -0,0 +1,102 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EcsJobDefinition = exports.Compatibility = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +const ecs_container_definition_1 = require("./ecs-container-definition"); +const job_definition_base_1 = require("./job-definition-base"); +const iam = require("aws-cdk-lib/aws-iam"); +/** + * @internal + */ +var Compatibility; +(function (Compatibility) { + Compatibility["EC2"] = "EC2"; + Compatibility["FARGATE"] = "FARGATE"; +})(Compatibility || (exports.Compatibility = Compatibility = {})); +/** + * A JobDefinition that uses ECS orchestration + * + * @resource AWS::Batch::JobDefinition + */ +class EcsJobDefinition extends job_definition_base_1.JobDefinitionBase { + /** + * Import a JobDefinition by its arn. + */ + static fromJobDefinitionArn(scope, id, jobDefinitionArn) { + class Import extends job_definition_base_1.JobDefinitionBase { + constructor() { + super(...arguments); + this.jobDefinitionArn = jobDefinitionArn; + this.jobDefinitionName = EcsJobDefinition.getJobDefinitionName(this, jobDefinitionArn); + this.enabled = true; + this.container = {}; + } + } + return new Import(scope, id); + } + static getJobDefinitionName(scope, jobDefinitionArn) { + const resourceName = core_1.Stack.of(scope).splitArn(jobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + return resourceName.split(':')[0]; + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsJobDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EcsJobDefinition); + } + throw error; + } + this.container = props.container; + this.propagateTags = props?.propagateTags; + const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { + ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), + type: 'container', + jobDefinitionName: props.jobDefinitionName, + containerProperties: this.container?._renderContainerDefinition(), + platformCapabilities: this.renderPlatformCapabilities(), + propagateTags: this.propagateTags, + }); + this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { + service: 'batch', + resource: 'job-definition', + resourceName: this.physicalName, + }); + this.jobDefinitionName = EcsJobDefinition.getJobDefinitionName(scope, this.jobDefinitionArn); + } + /** + * Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue` + */ + grantSubmitJob(identity, queue) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_IJobQueue(queue); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.grantSubmitJob); + } + throw error; + } + iam.Grant.addToPrincipal({ + actions: ['batch:SubmitJob'], + grantee: identity, + resourceArns: [this.jobDefinitionArn, queue.jobQueueArn], + }); + } + renderPlatformCapabilities() { + if (this.container instanceof ecs_container_definition_1.EcsEc2ContainerDefinition) { + return [Compatibility.EC2]; + } + return [Compatibility.FARGATE]; + } +} +exports.EcsJobDefinition = EcsJobDefinition; +_a = JSII_RTTI_SYMBOL_1; +EcsJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EcsJobDefinition", version: "0.0.0" }; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZWNzLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDJDQUFvRDtBQUVwRCxxREFBeUQ7QUFDekQseUVBQWdHO0FBQ2hHLCtEQUEySDtBQUMzSCwyQ0FBMkM7QUFxQjNDOztHQUVHO0FBQ0gsSUFBWSxhQUdYO0FBSEQsV0FBWSxhQUFhO0lBQ3ZCLDRCQUFXLENBQUE7SUFDWCxvQ0FBbUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsYUFBYSw2QkFBYixhQUFhLFFBR3hCO0FBb0JEOzs7O0dBSUc7QUFDSCxNQUFhLGdCQUFpQixTQUFRLHVDQUFpQjtJQUNyRDs7T0FFRztJQUNJLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxnQkFBd0I7UUFDdkYsTUFBTSxNQUFPLFNBQVEsdUNBQWlCO1lBQXRDOztnQkFDa0IscUJBQWdCLEdBQUcsZ0JBQWdCLENBQUM7Z0JBQ3BDLHNCQUFpQixHQUFHLGdCQUFnQixDQUFDLG9CQUFvQixDQUFDLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO2dCQUNsRixZQUFPLEdBQUcsSUFBSSxDQUFDO2dCQUMvQixjQUFTLEdBQUcsRUFBUyxDQUFDO1lBQ3hCLENBQUM7U0FBQTtRQUVELE9BQU8sSUFBSSxNQUFNLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0tBQzlCO0lBRU8sTUFBTSxDQUFDLG9CQUFvQixDQUFDLEtBQWdCLEVBQUUsZ0JBQXdCO1FBQzVFLE1BQU0sWUFBWSxHQUFHLFlBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsUUFBUSxDQUFDLGdCQUFnQixFQUFFLGdCQUFTLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxZQUFhLENBQUM7UUFDN0csT0FBTyxZQUFZLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ25DO0lBUUQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUE0QjtRQUNwRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQzs7Ozs7OytDQTNCZixnQkFBZ0I7Ozs7UUE2QnpCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQztRQUNqQyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssRUFBRSxhQUFhLENBQUM7UUFFMUMsTUFBTSxRQUFRLEdBQUcsSUFBSSw0QkFBZ0IsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ3RELEdBQUcsSUFBQSxpREFBMkIsRUFBQyxJQUFJLENBQUM7WUFDcEMsSUFBSSxFQUFFLFdBQVc7WUFDakIsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGlCQUFpQjtZQUMxQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLDBCQUEwQixFQUFFO1lBQ2pFLG9CQUFvQixFQUFFLElBQUksQ0FBQywwQkFBMEIsRUFBRTtZQUN2RCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7U0FDbEMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ2pFLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLFFBQVEsRUFBRSxnQkFBZ0I7WUFDMUIsWUFBWSxFQUFFLElBQUksQ0FBQyxZQUFZO1NBQ2hDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxpQkFBaUIsR0FBRyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7S0FDOUY7SUFFRDs7TUFFRTtJQUNLLGNBQWMsQ0FBQyxRQUF3QixFQUFFLEtBQWdCOzs7Ozs7Ozs7O1FBQzlELEdBQUcsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDO1lBQ3ZCLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO1lBQzVCLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsV0FBVyxDQUFDO1NBQ3pELENBQUMsQ0FBQztLQUNKO0lBRU8sMEJBQTBCO1FBQ2hDLElBQUksSUFBSSxDQUFDLFNBQVMsWUFBWSxvREFBeUIsRUFBRTtZQUN2RCxPQUFPLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzVCO1FBRUQsT0FBTyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUNoQzs7QUFsRUgsNENBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXJuRm9ybWF0LCBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliL2NvcmUnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBDZm5Kb2JEZWZpbml0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWJhdGNoJztcbmltcG9ydCB7IEVjc0VjMkNvbnRhaW5lckRlZmluaXRpb24sIElFY3NDb250YWluZXJEZWZpbml0aW9uIH0gZnJvbSAnLi9lY3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuaW1wb3J0IHsgYmFzZUpvYkRlZmluaXRpb25Qcm9wZXJ0aWVzLCBJSm9iRGVmaW5pdGlvbiwgSm9iRGVmaW5pdGlvbkJhc2UsIEpvYkRlZmluaXRpb25Qcm9wcyB9IGZyb20gJy4vam9iLWRlZmluaXRpb24tYmFzZSc7XG5pbXBvcnQgKiBhcyBpYW0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWlhbSc7XG5pbXBvcnQgeyBJSm9iUXVldWUgfSBmcm9tICcuL2pvYi1xdWV1ZSc7XG5cbi8qKlxuICogQSBKb2JEZWZpbml0aW9uIHRoYXQgdXNlcyBFQ1Mgb3JjaGVzdHJhdGlvblxuICovXG5pbnRlcmZhY2UgSUVjc0pvYkRlZmluaXRpb24gZXh0ZW5kcyBJSm9iRGVmaW5pdGlvbiB7XG4gIC8qKlxuICAgKiBUaGUgY29udGFpbmVyIHRoYXQgdGhpcyBqb2Igd2lsbCBydW5cbiAgICovXG4gIHJlYWRvbmx5IGNvbnRhaW5lcjogSUVjc0NvbnRhaW5lckRlZmluaXRpb25cblxuICAvKipcbiAgICogV2hldGhlciB0byBwcm9wb2dhdGUgdGFncyBmcm9tIHRoZSBKb2JEZWZpbml0aW9uXG4gICAqIHRvIHRoZSBFQ1MgdGFzayB0aGF0IEJhdGNoIHNwYXduc1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcGFnYXRlVGFncz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBlbnVtIENvbXBhdGliaWxpdHkge1xuICBFQzIgPSAnRUMyJyxcbiAgRkFSR0FURSA9ICdGQVJHQVRFJyxcbn1cblxuLyoqXG4gKiBQcm9wcyBmb3IgRWNzSm9iRGVmaW5pdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVjc0pvYkRlZmluaXRpb25Qcm9wcyBleHRlbmRzIEpvYkRlZmluaXRpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgY29udGFpbmVyIHRoYXQgdGhpcyBqb2Igd2lsbCBydW5cbiAgICovXG4gIHJlYWRvbmx5IGNvbnRhaW5lcjogSUVjc0NvbnRhaW5lckRlZmluaXRpb25cblxuICAvKipcbiAgICogV2hldGhlciB0byBwcm9wb2dhdGUgdGFncyBmcm9tIHRoZSBKb2JEZWZpbml0aW9uXG4gICAqIHRvIHRoZSBFQ1MgdGFzayB0aGF0IEJhdGNoIHNwYXduc1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcGFnYXRlVGFncz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBKb2JEZWZpbml0aW9uIHRoYXQgdXNlcyBFQ1Mgb3JjaGVzdHJhdGlvblxuICpcbiAqIEByZXNvdXJjZSBBV1M6OkJhdGNoOjpKb2JEZWZpbml0aW9uXG4gKi9cbmV4cG9ydCBjbGFzcyBFY3NKb2JEZWZpbml0aW9uIGV4dGVuZHMgSm9iRGVmaW5pdGlvbkJhc2UgaW1wbGVtZW50cyBJRWNzSm9iRGVmaW5pdGlvbiB7XG4gIC8qKlxuICAgKiBJbXBvcnQgYSBKb2JEZWZpbml0aW9uIGJ5IGl0cyBhcm4uXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21Kb2JEZWZpbml0aW9uQXJuKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIGpvYkRlZmluaXRpb25Bcm46IHN0cmluZyk6IElKb2JEZWZpbml0aW9uIHtcbiAgICBjbGFzcyBJbXBvcnQgZXh0ZW5kcyBKb2JEZWZpbml0aW9uQmFzZSBpbXBsZW1lbnRzIElFY3NKb2JEZWZpbml0aW9uIHtcbiAgICAgIHB1YmxpYyByZWFkb25seSBqb2JEZWZpbml0aW9uQXJuID0gam9iRGVmaW5pdGlvbkFybjtcbiAgICAgIHB1YmxpYyByZWFkb25seSBqb2JEZWZpbml0aW9uTmFtZSA9IEVjc0pvYkRlZmluaXRpb24uZ2V0Sm9iRGVmaW5pdGlvbk5hbWUodGhpcywgam9iRGVmaW5pdGlvbkFybik7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgZW5hYmxlZCA9IHRydWU7XG4gICAgICBjb250YWluZXIgPSB7fSBhcyBhbnk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBJbXBvcnQoc2NvcGUsIGlkKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGdldEpvYkRlZmluaXRpb25OYW1lKHNjb3BlOiBDb25zdHJ1Y3QsIGpvYkRlZmluaXRpb25Bcm46IHN0cmluZykge1xuICAgIGNvbnN0IHJlc291cmNlTmFtZSA9IFN0YWNrLm9mKHNjb3BlKS5zcGxpdEFybihqb2JEZWZpbml0aW9uQXJuLCBBcm5Gb3JtYXQuU0xBU0hfUkVTT1VSQ0VfTkFNRSkucmVzb3VyY2VOYW1lITtcbiAgICByZXR1cm4gcmVzb3VyY2VOYW1lLnNwbGl0KCc6JylbMF07XG4gIH1cblxuICByZWFkb25seSBjb250YWluZXI6IElFY3NDb250YWluZXJEZWZpbml0aW9uXG4gIHB1YmxpYyByZWFkb25seSBwcm9wYWdhdGVUYWdzPzogYm9vbGVhbjtcblxuICBwdWJsaWMgcmVhZG9ubHkgam9iRGVmaW5pdGlvbkFybjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgam9iRGVmaW5pdGlvbk5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRWNzSm9iRGVmaW5pdGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCBwcm9wcyk7XG5cbiAgICB0aGlzLmNvbnRhaW5lciA9IHByb3BzLmNvbnRhaW5lcjtcbiAgICB0aGlzLnByb3BhZ2F0ZVRhZ3MgPSBwcm9wcz8ucHJvcGFnYXRlVGFncztcblxuICAgIGNvbnN0IHJlc291cmNlID0gbmV3IENmbkpvYkRlZmluaXRpb24odGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgLi4uYmFzZUpvYkRlZmluaXRpb25Qcm9wZXJ0aWVzKHRoaXMpLFxuICAgICAgdHlwZTogJ2NvbnRhaW5lcicsXG4gICAgICBqb2JEZWZpbml0aW9uTmFtZTogcHJvcHMuam9iRGVmaW5pdGlvbk5hbWUsXG4gICAgICBjb250YWluZXJQcm9wZXJ0aWVzOiB0aGlzLmNvbnRhaW5lcj8uX3JlbmRlckNvbnRhaW5lckRlZmluaXRpb24oKSxcbiAgICAgIHBsYXRmb3JtQ2FwYWJpbGl0aWVzOiB0aGlzLnJlbmRlclBsYXRmb3JtQ2FwYWJpbGl0aWVzKCksXG4gICAgICBwcm9wYWdhdGVUYWdzOiB0aGlzLnByb3BhZ2F0ZVRhZ3MsXG4gICAgfSk7XG5cbiAgICB0aGlzLmpvYkRlZmluaXRpb25Bcm4gPSB0aGlzLmdldFJlc291cmNlQXJuQXR0cmlidXRlKHJlc291cmNlLnJlZiwge1xuICAgICAgc2VydmljZTogJ2JhdGNoJyxcbiAgICAgIHJlc291cmNlOiAnam9iLWRlZmluaXRpb24nLFxuICAgICAgcmVzb3VyY2VOYW1lOiB0aGlzLnBoeXNpY2FsTmFtZSxcbiAgICB9KTtcbiAgICB0aGlzLmpvYkRlZmluaXRpb25OYW1lID0gRWNzSm9iRGVmaW5pdGlvbi5nZXRKb2JEZWZpbml0aW9uTmFtZShzY29wZSwgdGhpcy5qb2JEZWZpbml0aW9uQXJuKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHcmFudHMgdGhlIGBiYXRjaDpzdWJtaXRKb2JgIHBlcm1pc3Npb24gdG8gdGhlIGlkZW50aXR5IG9uIGJvdGggdGhpcyBqb2IgZGVmaW5pdGlvbiBhbmQgdGhlIGBxdWV1ZWBcbiAgKi9cbiAgcHVibGljIGdyYW50U3VibWl0Sm9iKGlkZW50aXR5OiBpYW0uSUdyYW50YWJsZSwgcXVldWU6IElKb2JRdWV1ZSkge1xuICAgIGlhbS5HcmFudC5hZGRUb1ByaW5jaXBhbCh7XG4gICAgICBhY3Rpb25zOiBbJ2JhdGNoOlN1Ym1pdEpvYiddLFxuICAgICAgZ3JhbnRlZTogaWRlbnRpdHksXG4gICAgICByZXNvdXJjZUFybnM6IFt0aGlzLmpvYkRlZmluaXRpb25Bcm4sIHF1ZXVlLmpvYlF1ZXVlQXJuXSxcbiAgICB9KTtcbiAgfVxuXG4gIHByaXZhdGUgcmVuZGVyUGxhdGZvcm1DYXBhYmlsaXRpZXMoKSB7XG4gICAgaWYgKHRoaXMuY29udGFpbmVyIGluc3RhbmNlb2YgRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbikge1xuICAgICAgcmV0dXJuIFtDb21wYXRpYmlsaXR5LkVDMl07XG4gICAgfVxuXG4gICAgcmV0dXJuIFtDb21wYXRpYmlsaXR5LkZBUkdBVEVdO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts new file mode 100644 index 0000000000000..4e12fa25a1851 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts @@ -0,0 +1,728 @@ +import * as ecs from 'aws-cdk-lib/aws-ecs'; +import { Size } from 'aws-cdk-lib/core'; +import { Construct, IConstruct } from 'constructs'; +import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; +/** + * A container that can be run with EKS orchestration on EC2 resources + */ +export interface IEksContainerDefinition extends IConstruct { + /** + * The image that this container will run + */ + readonly image: ecs.ContainerImage; + /** + * An array of arguments to the entrypoint. + * If this isn't specified, the CMD of the container image is used. + * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes. + * Environment variable references are expanded using the container's environment. + * If the referenced environment variable doesn't exist, the reference in the command isn't changed. + * For example, if the reference is to "$(NAME1)" and the NAME1 environment variable doesn't exist, + * the command string will remain "$(NAME1)." $$ is replaced with $, and the resulting string isn't expanded. + * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists. + * + * @see https://docs.docker.com/engine/reference/builder/#cmd + * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ + */ + readonly args?: string[]; + /** + * The entrypoint for the container. This isn't run within a shell. + * If this isn't specified, the `ENTRYPOINT` of the container image is used. + * Environment variable references are expanded using the container's environment. + * If the referenced environment variable doesn't exist, the reference in the command isn't changed. + * For example, if the reference is to `"$(NAME1)"` and the `NAME1` environment variable doesn't exist, + * the command string will remain `"$(NAME1)."` `$$` is replaced with `$` and the resulting string isn't expanded. + * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists. + + * The entrypoint can't be updated. + * + * @see https://docs.docker.com/engine/reference/builder/#entrypoint + * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ + * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint + */ + readonly command?: string[]; + /** + * The environment variables to pass to this container. + * + * *Note*: Environment variables cannot start with "AWS_BATCH". + * This naming convention is reserved for variables that AWS Batch sets. + */ + readonly env?: { + [key: string]: string; + }; + /** + * The image pull policy for this container + * + * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images + * + * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise + */ + readonly imagePullPolicy?: ImagePullPolicy; + /** + * The name of this container + * + * @default: `'Default'` + */ + readonly name?: string; + /** + * The amount (in MiB) of memory to present to the container. + * If your container attempts to exceed the allocated memory, it will be terminated. + * + * Must be larger that 4 MiB + * + * At least one of `memoryLimit` and `memoryReservation` is required + * + * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible + * for the specific instance type that you are using. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html + * + * @default - No memory limit + */ + readonly memoryLimit?: Size; + /** + * The soft limit (in MiB) of memory to reserve for the container. + * Your container will be given at least this much memory, but may consume more. + * + * Must be larger that 4 MiB + * + * When system memory is under heavy contention, Docker attempts to keep the + * container memory to this soft limit. However, your container can consume more + * memory when it needs to, up to either the hard limit specified with the memory + * parameter (if applicable), or all of the available memory on the container + * instance, whichever comes first. + * + * At least one of `memoryLimit` and `memoryReservation` is required. + * If both are specified, then `memoryLimit` must be equal to `memoryReservation` + * + * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible + * for the specific instance type that you are using. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html + * + * @default - No memory reserved + */ + readonly memoryReservation?: Size; + /** + * The hard limit of CPUs to present to this container. + * Must be an even multiple of 0.25 + * + * If your container attempts to exceed this limit, it will be terminated. + * + * At least one of `cpuReservation` and `cpuLimit` is required. + * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No CPU limit + */ + readonly cpuLimit?: number; + /** + * The soft limit of CPUs to reserve for the container + * Must be an even multiple of 0.25 + * + * The container will given at least this many CPUs, but may consume more. + * + * At least one of `cpuReservation` and `cpuLimit` is required. + * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No CPUs reserved + */ + readonly cpuReservation?: number; + /** + * The hard limit of GPUs to present to this container. + * + * If your container attempts to exceed this limit, it will be terminated. + * + * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No GPU limit + */ + readonly gpuLimit?: number; + /** + * The soft limit of CPUs to reserve for the container + * Must be an even multiple of 0.25 + * + * The container will given at least this many CPUs, but may consume more. + * + * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No GPUs reserved + */ + readonly gpuReservation?: number; + /** + * If specified, gives this container elevated permissions on the host container instance. + * The level of permissions are similar to the root user permissions. + * + * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems + * + * @default false + */ + readonly privileged?: boolean; + /** + * If specified, gives this container readonly access to its root file system. + * + * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems + * + * @default false + */ + readonly readonlyRootFilesystem?: boolean; + /** + * If specified, the container is run as the specified group ID (`gid`). + * If this parameter isn't specified, the default is the group that's specified in the image metadata. + * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default none + */ + readonly runAsGroup?: number; + /** + * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced. + * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default - the container is *not* required to run as a non-root user + */ + readonly runAsRoot?: boolean; + /** + * If specified, this container is run as the specified user ID (`uid`). + * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default - the user that is specified in the image metadata. + */ + readonly runAsUser?: number; + /** + * The Volumes to mount to this container. + * Automatically added to the Pod. + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/ + */ + readonly volumes: EksVolume[]; + /** + * Mount a Volume to this container. Automatically added to the Pod. + */ + addVolume(volume: EksVolume): void; +} +/** + * Determines when the image is pulled from the registry to launch a container + */ +export declare enum ImagePullPolicy { + /** + * Every time the kubelet launches a container, + * the kubelet queries the container image registry to resolve the name to an image digest. + * If the kubelet has a container image with that exact digest cached locally, + * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest, + * and uses that image to launch the container. + * + * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier + */ + ALWAYS = "Always", + /** + * The image is pulled only if it is not already present locally + */ + IF_NOT_PRESENT = "IfNotPresent", + /** + * The kubelet does not try fetching the image. + * If the image is somehow already present locally, + * the kubelet attempts to start the container; otherwise, startup fails. + * See pre-pulled images for more details. + * + * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images + */ + NEVER = "Never" +} +/** + * Props to configure an EksContainerDefinition + */ +export interface EksContainerDefinitionProps { + /** + * The image that this container will run + */ + readonly image: ecs.ContainerImage; + /** + * An array of arguments to the entrypoint. + * If this isn't specified, the CMD of the container image is used. + * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes. + * Environment variable references are expanded using the container's environment. + * If the referenced environment variable doesn't exist, the reference in the command isn't changed. + * For example, if the reference is to "$(NAME1)" and the NAME1 environment variable doesn't exist, + * the command string will remain "$(NAME1)." $$ is replaced with $, and the resulting string isn't expanded. + * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists. + * + * @see https://docs.docker.com/engine/reference/builder/#cmd + * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ + * + * @default - no args + */ + readonly args?: string[]; + /** + * The entrypoint for the container. This isn't run within a shell. + * If this isn't specified, the `ENTRYPOINT` of the container image is used. + * Environment variable references are expanded using the container's environment. + * If the referenced environment variable doesn't exist, the reference in the command isn't changed. + * For example, if the reference is to `"$(NAME1)"` and the `NAME1` environment variable doesn't exist, + * the command string will remain `"$(NAME1)."` `$$` is replaced with `$` and the resulting string isn't expanded. + * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists. + + * The entrypoint can't be updated. + * + * @see https://docs.docker.com/engine/reference/builder/#entrypoint + * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ + * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint + * + * @default - no command + */ + readonly command?: string[]; + /** + * The environment variables to pass to this container. + * + * *Note*: Environment variables cannot start with "AWS_BATCH". + * This naming convention is reserved for variables that AWS Batch sets. + * + * @default - no environment variables + */ + readonly env?: { + [key: string]: string; + }; + /** + * The image pull policy for this container + * + * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images + * + * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise + */ + readonly imagePullPolicy?: ImagePullPolicy; + /** + * The name of this container + * + * @default: `'Default'` + */ + readonly name?: string; + /** + * The amount (in MiB) of memory to present to the container. + * If your container attempts to exceed the allocated memory, it will be terminated. + * + * Must be larger that 4 MiB + * + * At least one of `memoryLimit` and `memoryReservation` is required + * + * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible + * for the specific instance type that you are using. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html + * + * @default - No memory limit + */ + readonly memoryLimit?: Size; + /** + * The soft limit (in MiB) of memory to reserve for the container. + * Your container will be given at least this much memory, but may consume more. + * + * Must be larger that 4 MiB + * + * When system memory is under heavy contention, Docker attempts to keep the + * container memory to this soft limit. However, your container can consume more + * memory when it needs to, up to either the hard limit specified with the memory + * parameter (if applicable), or all of the available memory on the container + * instance, whichever comes first. + * + * At least one of `memoryLimit` and `memoryReservation` is required. + * If both are specified, then `memoryLimit` must be equal to `memoryReservation` + * + * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible + * for the specific instance type that you are using. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html + * + * @default - No memory reserved + */ + readonly memoryReservation?: Size; + /** + * The hard limit of CPUs to present to this container. + * Must be an even multiple of 0.25 + * + * If your container attempts to exceed this limit, it will be terminated. + * + * At least one of `cpuReservation` and `cpuLimit` is required. + * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No CPU limit + */ + readonly cpuLimit?: number; + /** + * The soft limit of CPUs to reserve for the container + * Must be an even multiple of 0.25 + * + * The container will given at least this many CPUs, but may consume more. + * + * At least one of `cpuReservation` and `cpuLimit` is required. + * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No CPUs reserved + */ + readonly cpuReservation?: number; + /** + * The hard limit of GPUs to present to this container. + * + * If your container attempts to exceed this limit, it will be terminated. + * + * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No GPU limit + */ + readonly gpuLimit?: number; + /** + * The soft limit of CPUs to reserve for the container + * Must be an even multiple of 0.25 + * + * The container will given at least this many CPUs, but may consume more. + * + * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. + * + * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ + * + * @default - No GPUs reserved + */ + readonly gpuReservation?: number; + /** + * If specified, gives this container elevated permissions on the host container instance. + * The level of permissions are similar to the root user permissions. + * + * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems + * + * @default false + */ + readonly privileged?: boolean; + /** + * If specified, gives this container readonly access to its root file system. + * + * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems + * + * @default false + */ + readonly readonlyRootFilesystem?: boolean; + /** + * If specified, the container is run as the specified group ID (`gid`). + * If this parameter isn't specified, the default is the group that's specified in the image metadata. + * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default none + */ + readonly runAsGroup?: number; + /** + * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced. + * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default - the container is *not* required to run as a non-root user + */ + readonly runAsRoot?: boolean; + /** + * If specified, this container is run as the specified user ID (`uid`). + * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. + * + * *Note*: this is only compatible with Kubernetes < v1.25 + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups + * + * @default - the user that is specified in the image metadata. + */ + readonly runAsUser?: number; + /** + * The Volumes to mount to this container. + * Automatically added to the Pod. + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/ + * + * @default - no volumes + */ + readonly volumes?: EksVolume[]; +} +/** + * A container that can be run with EKS orchestration on EC2 resources + */ +export declare class EksContainerDefinition extends Construct implements IEksContainerDefinition { + readonly image: ecs.ContainerImage; + readonly args?: string[]; + readonly command?: string[]; + readonly env?: { + [key: string]: string; + }; + readonly imagePullPolicy?: ImagePullPolicy; + readonly name?: string; + readonly memoryLimit?: Size; + readonly memoryReservation?: Size; + readonly cpuLimit?: number; + readonly cpuReservation?: number; + readonly gpuLimit?: number; + readonly gpuReservation?: number; + readonly privileged?: boolean; + readonly readonlyRootFilesystem?: boolean; + readonly runAsGroup?: number; + readonly runAsRoot?: boolean; + readonly runAsUser?: number; + readonly volumes: EksVolume[]; + private readonly imageConfig; + constructor(scope: Construct, id: string, props: EksContainerDefinitionProps); + addVolume(volume: EksVolume): void; + /** + * + * @internal + */ + _renderContainerDefinition(): CfnJobDefinition.EksContainerProperty; +} +/** + * Options to configure an EksVolume + */ +export interface EksVolumeOptions { + /** + * The name of this volume. + * The name must be a valid DNS subdomain name. + * + * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names + */ + readonly name: string; + /** + * The path on the container where the volume is mounted. + * + * @default - the volume is not mounted + */ + readonly mountPath?: string; + /** + * If specified, the container has readonly access to the volume. + * Otherwise, the container has read/write access. + * + * @default false + */ + readonly readonly?: boolean; +} +/** + * A Volume that can be mounted to a container supported by EKS + */ +export declare abstract class EksVolume { + /** + * Creates a Kubernetes EmptyDir volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir + */ + static emptyDir(options: EmptyDirVolumeOptions): EmptyDirVolume; + /** + * Creates a Kubernetes HostPath volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ + static hostPath(options: HostPathVolumeOptions): HostPathVolume; + /** + * Creates a Kubernetes Secret volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret + */ + static secret(options: SecretPathVolumeOptions): SecretPathVolume; + /** + * The name of this volume. + * The name must be a valid DNS subdomain name. + * + * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names + */ + readonly name: string; + /** + * The path on the container where the container is mounted. + * + * @default - the container is not mounted + */ + readonly containerPath?: string; + /** + * If specified, the container has readonly access to the volume. + * Otherwise, the container has read/write access. + * + * @default false + */ + readonly readonly?: boolean; + constructor(options: EksVolumeOptions); +} +/** + * Options for a Kubernetes EmptyDir volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir + */ +export interface EmptyDirVolumeOptions extends EksVolumeOptions { + /** + * The storage type to use for this Volume. + * + * @default `EmptyDirMediumType.DISK` + */ + readonly medium?: EmptyDirMediumType; + /** + * The maximum size for this Volume + * + * @default - no size limit + */ + readonly sizeLimit?: Size; +} +/** + * What medium the volume will live in + */ +export declare enum EmptyDirMediumType { + /** + * Use the disk storage of the node. + * Items written here will survive node reboots. + */ + DISK = "", + /** + * Use the `tmpfs` volume that is backed by RAM of the node. + * Items written here will *not* survive node reboots. + */ + MEMORY = "Memory" +} +/** + * A Kubernetes EmptyDir volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir + */ +export declare class EmptyDirVolume extends EksVolume { + /** + * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise + */ + static isEmptyDirVolume(x: any): x is EmptyDirVolume; + /** + * The storage type to use for this Volume. + * + * @default `EmptyDirMediumType.DISK` + */ + readonly medium?: EmptyDirMediumType; + /** + * The maximum size for this Volume + * + * @default - no size limit + */ + readonly sizeLimit?: Size; + constructor(options: EmptyDirVolumeOptions); +} +/** + * Options for a kubernetes HostPath volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ +export interface HostPathVolumeOptions extends EksVolumeOptions { + /** + * The path of the file or directory on the host to mount into containers on the pod. + * + * *Note*: HothPath Volumes present many security risks, and should be avoided when possible. + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ + readonly hostPath: string; +} +/** + * A Kubernetes HostPath volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ +export declare class HostPathVolume extends EksVolume { + /** + * returns `true` if `x` is a HostPathVolume, `false` otherwise + */ + static isHostPathVolume(x: any): x is HostPathVolume; + /** + * The path of the file or directory on the host to mount into containers on the pod. + * + * *Note*: HothPath Volumes present many security risks, and should be avoided when possible. + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ + readonly path: string; + constructor(options: HostPathVolumeOptions); +} +/** + * Options for a Kubernetes SecretPath Volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret + */ +export interface SecretPathVolumeOptions extends EksVolumeOptions { + /** + * The name of the secret. + * Must be a valid DNS subdomain name. + * + * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names + */ + readonly secretName: string; + /** + * Specifies whether the secret or the secret's keys must be defined + * + * @default true + */ + readonly optional?: boolean; +} +/** + * Specifies the configuration of a Kubernetes secret volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret + */ +export declare class SecretPathVolume extends EksVolume { + /** + * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise + */ + static isSecretPathVolume(x: any): x is SecretPathVolume; + /** + * The name of the secret. + * Must be a valid DNS subdomain name. + * + * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names + */ + readonly secretName: string; + /** + * Specifies whether the secret or the secret's keys must be defined + * + * @default true + */ + readonly optional?: boolean; + constructor(options: SecretPathVolumeOptions); +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js new file mode 100644 index 0000000000000..bd9b7beec7a4d --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js @@ -0,0 +1,338 @@ +"use strict"; +var _a, _b, _c, _d, _e; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.SecretPathVolume = exports.HostPathVolume = exports.EmptyDirVolume = exports.EmptyDirMediumType = exports.EksVolume = exports.EksContainerDefinition = exports.ImagePullPolicy = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const constructs_1 = require("constructs"); +const EMPTY_DIR_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.EmptyDirVolume'); +const HOST_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.HostPathVolume'); +const SECRET_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.SecretVolume'); +/** + * Determines when the image is pulled from the registry to launch a container + */ +var ImagePullPolicy; +(function (ImagePullPolicy) { + /** + * Every time the kubelet launches a container, + * the kubelet queries the container image registry to resolve the name to an image digest. + * If the kubelet has a container image with that exact digest cached locally, + * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest, + * and uses that image to launch the container. + * + * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier + */ + ImagePullPolicy["ALWAYS"] = "Always"; + /** + * The image is pulled only if it is not already present locally + */ + ImagePullPolicy["IF_NOT_PRESENT"] = "IfNotPresent"; + /** + * The kubelet does not try fetching the image. + * If the image is somehow already present locally, + * the kubelet attempts to start the container; otherwise, startup fails. + * See pre-pulled images for more details. + * + * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images + */ + ImagePullPolicy["NEVER"] = "Never"; +})(ImagePullPolicy || (exports.ImagePullPolicy = ImagePullPolicy = {})); +/** + * A container that can be run with EKS orchestration on EC2 resources + */ +class EksContainerDefinition extends constructs_1.Construct { + constructor(scope, id, props) { + super(scope, id); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksContainerDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EksContainerDefinition); + } + throw error; + } + this.image = props.image; + this.args = props.args; + this.command = props.command; + this.env = props.env; + this.imagePullPolicy = props.imagePullPolicy; + this.name = props.name; + this.memoryLimit = props.memoryLimit; + this.memoryReservation = props.memoryReservation; + this.cpuLimit = props.cpuLimit; + this.cpuReservation = props.cpuReservation; + this.gpuLimit = props.gpuLimit; + this.gpuReservation = props.gpuReservation; + this.privileged = props.privileged; + this.readonlyRootFilesystem = props.readonlyRootFilesystem; + this.runAsGroup = props.runAsGroup; + this.runAsRoot = props.runAsRoot; + this.runAsUser = props.runAsUser; + this.volumes = props.volumes ?? []; + this.imageConfig = props.image.bind(this, this); + } + addVolume(volume) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksVolume(volume); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addVolume); + } + throw error; + } + this.volumes.push(volume); + } + /** + * + * @internal + */ + _renderContainerDefinition() { + return { + image: this.imageConfig.imageName, + command: this.command, + args: this.args, + env: Object.keys(this.env ?? {}).map((key) => { + return { + name: key, + value: this.env[key], + }; + }), + name: this.name, + imagePullPolicy: this.imagePullPolicy, + resources: { + limits: { + 'cpu': this.cpuLimit, + 'memory': this.memoryLimit ? this.memoryLimit.toMebibytes() + 'Mi' : undefined, + 'nvidia.com/gpu': this.gpuLimit, + }, + requests: { + 'cpu': this.cpuReservation, + 'memory': this.memoryReservation ? this.memoryReservation.toMebibytes() + 'Mi' : undefined, + 'nvidia.com/gpu': this.gpuReservation, + }, + }, + securityContext: { + privileged: this.privileged, + readOnlyRootFilesystem: this.readonlyRootFilesystem, + runAsGroup: this.runAsGroup, + runAsNonRoot: !this.runAsRoot, + runAsUser: this.runAsUser, + }, + volumeMounts: core_1.Lazy.any({ + produce: () => { + if (this.volumes.length === 0) { + return undefined; + } + return this.volumes.map((volume) => { + return { + name: volume.name, + mountPath: volume.containerPath, + readOnly: volume.readonly, + }; + }); + }, + }), + }; + } + ; +} +exports.EksContainerDefinition = EksContainerDefinition; +_a = JSII_RTTI_SYMBOL_1; +EksContainerDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EksContainerDefinition", version: "0.0.0" }; +/** + * A Volume that can be mounted to a container supported by EKS + */ +class EksVolume { + /** + * Creates a Kubernetes EmptyDir volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir + */ + static emptyDir(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.emptyDir); + } + throw error; + } + return new EmptyDirVolume(options); + } + /** + * Creates a Kubernetes HostPath volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ + static hostPath(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostPathVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.hostPath); + } + throw error; + } + return new HostPathVolume(options); + } + /** + * Creates a Kubernetes Secret volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret + */ + static secret(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.secret); + } + throw error; + } + return new SecretPathVolume(options); + } + constructor(options) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EksVolume); + } + throw error; + } + this.name = options.name; + this.containerPath = options.mountPath; + this.readonly = options.readonly; + } +} +exports.EksVolume = EksVolume; +_b = JSII_RTTI_SYMBOL_1; +EksVolume[_b] = { fqn: "@aws-cdk/aws-batch-alpha.EksVolume", version: "0.0.0" }; +/** + * What medium the volume will live in + */ +var EmptyDirMediumType; +(function (EmptyDirMediumType) { + /** + * Use the disk storage of the node. + * Items written here will survive node reboots. + */ + EmptyDirMediumType["DISK"] = ""; + /** + * Use the `tmpfs` volume that is backed by RAM of the node. + * Items written here will *not* survive node reboots. + */ + EmptyDirMediumType["MEMORY"] = "Memory"; +})(EmptyDirMediumType || (exports.EmptyDirMediumType = EmptyDirMediumType = {})); +/** + * A Kubernetes EmptyDir volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir + */ +class EmptyDirVolume extends EksVolume { + /** + * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise + */ + static isEmptyDirVolume(x) { + return x !== null && typeof (x) === 'object' && EMPTY_DIR_VOLUME_SYMBOL in x; + } + constructor(options) { + super(options); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EmptyDirVolume); + } + throw error; + } + this.medium = options.medium; + this.sizeLimit = options.sizeLimit; + } +} +exports.EmptyDirVolume = EmptyDirVolume; +_c = JSII_RTTI_SYMBOL_1; +EmptyDirVolume[_c] = { fqn: "@aws-cdk/aws-batch-alpha.EmptyDirVolume", version: "0.0.0" }; +Object.defineProperty(EmptyDirVolume.prototype, EMPTY_DIR_VOLUME_SYMBOL, { + value: true, + enumerable: false, + writable: false, +}); +/** + * A Kubernetes HostPath volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath + */ +class HostPathVolume extends EksVolume { + /** + * returns `true` if `x` is a HostPathVolume, `false` otherwise + */ + static isHostPathVolume(x) { + return x !== null && typeof (x) === 'object' && HOST_PATH_VOLUME_SYMBOL in x; + } + constructor(options) { + super(options); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostPathVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, HostPathVolume); + } + throw error; + } + this.path = options.hostPath; + } +} +exports.HostPathVolume = HostPathVolume; +_d = JSII_RTTI_SYMBOL_1; +HostPathVolume[_d] = { fqn: "@aws-cdk/aws-batch-alpha.HostPathVolume", version: "0.0.0" }; +Object.defineProperty(HostPathVolume.prototype, HOST_PATH_VOLUME_SYMBOL, { + value: true, + enumerable: false, + writable: false, +}); +/** + * Specifies the configuration of a Kubernetes secret volume + * + * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret + */ +class SecretPathVolume extends EksVolume { + /** + * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise + */ + static isSecretPathVolume(x) { + return x !== null && typeof (x) === 'object' && SECRET_PATH_VOLUME_SYMBOL in x; + } + constructor(options) { + super(options); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(options); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, SecretPathVolume); + } + throw error; + } + this.secretName = options.secretName; + this.optional = options.optional ?? true; + } +} +exports.SecretPathVolume = SecretPathVolume; +_e = JSII_RTTI_SYMBOL_1; +SecretPathVolume[_e] = { fqn: "@aws-cdk/aws-batch-alpha.SecretPathVolume", version: "0.0.0" }; +Object.defineProperty(SecretPathVolume.prototype, SECRET_PATH_VOLUME_SYMBOL, { + value: true, + enumerable: false, + writable: false, +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-container-definition.js","sourceRoot":"","sources":["eks-container-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Lazy, Size } from 'aws-cdk-lib/core';\nimport { Construct, IConstruct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\n\nconst EMPTY_DIR_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.EmptyDirVolume');\nconst HOST_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.HostPathVolume');\nconst SECRET_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.SecretVolume');\n\n/**\n * A container that can be run with EKS orchestration on EC2 resources\n */\nexport interface IEksContainerDefinition extends IConstruct {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * An array of arguments to the entrypoint.\n   * If this isn't specified, the CMD of the container image is used.\n   * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\n   * the command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\n   * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   */\n  readonly args?: string[];\n\n  /**\n   * The entrypoint for the container. This isn't run within a shell.\n   * If this isn't specified, the `ENTRYPOINT` of the container image is used.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\n   * the command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\n   * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\n   * The entrypoint can't be updated.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#entrypoint\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to this container.\n   *\n   * *Note*: Environment variables cannot start with \"AWS_BATCH\".\n   * This naming convention is reserved for variables that AWS Batch sets.\n   */\n  readonly env?: { [key:string]: string };\n\n  /**\n   * The image pull policy for this container\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images\n   *\n   * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise\n   */\n  readonly imagePullPolicy?: ImagePullPolicy;\n\n  /**\n   * The name of this container\n   *\n   * @default: `'Default'`\n   */\n  readonly name?: string;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   * If your container attempts to exceed the allocated memory, it will be terminated.\n   *\n   * Must be larger that 4 MiB\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory limit\n   */\n  readonly memoryLimit?: Size;\n\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   * Your container will be given at least this much memory, but may consume more.\n   *\n   * Must be larger that 4 MiB\n   *\n   * When system memory is under heavy contention, Docker attempts to keep the\n   * container memory to this soft limit. However, your container can consume more\n   * memory when it needs to, up to either the hard limit specified with the memory\n   * parameter (if applicable), or all of the available memory on the container\n   * instance, whichever comes first.\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required.\n   * If both are specified, then `memoryLimit` must be equal to `memoryReservation`\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory reserved\n   */\n  readonly memoryReservation?: Size;\n\n  /**\n   * The hard limit of CPUs to present to this container.\n   * Must be an even multiple of 0.25\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPU limit\n   */\n  readonly cpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPUs reserved\n   */\n  readonly cpuReservation?: number;\n\n  /**\n   * The hard limit of GPUs to present to this container.\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPU limit\n   */\n  readonly gpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPUs reserved\n   */\n  readonly gpuReservation?: number;\n\n  /**\n   * If specified, gives this container elevated permissions on the host container instance.\n   * The level of permissions are similar to the root user permissions.\n   *\n   * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * If specified, gives this container readonly access to its root file system.\n   *\n   * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * If specified, the container is run as the specified group ID (`gid`).\n   * If this parameter isn't specified, the default is the group that's specified in the image metadata.\n   * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default none\n   */\n  readonly runAsGroup?: number;\n\n  /**\n   * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced.\n   * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the container is *not* required to run as a non-root user\n   */\n  readonly runAsRoot?: boolean;\n\n  /**\n   * If specified, this container is run as the specified user ID (`uid`).\n   * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the user that is specified in the image metadata.\n   */\n  readonly runAsUser?: number;\n\n  /**\n   * The Volumes to mount to this container.\n   * Automatically added to the Pod.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/\n   */\n  readonly volumes: EksVolume[];\n\n  /**\n   * Mount a Volume to this container. Automatically added to the Pod.\n   */\n  addVolume(volume: EksVolume): void;\n}\n\n/**\n * Determines when the image is pulled from the registry to launch a container\n */\nexport enum ImagePullPolicy {\n  /**\n   * Every time the kubelet launches a container,\n   * the kubelet queries the container image registry to resolve the name to an image digest.\n   * If the kubelet has a container image with that exact digest cached locally,\n   * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest,\n   * and uses that image to launch the container.\n   *\n   * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier\n   */\n  ALWAYS = 'Always',\n\n  /**\n   * The image is pulled only if it is not already present locally\n   */\n  IF_NOT_PRESENT = 'IfNotPresent',\n\n  /**\n   * The kubelet does not try fetching the image.\n   * If the image is somehow already present locally,\n   * the kubelet attempts to start the container; otherwise, startup fails.\n   * See pre-pulled images for more details.\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images\n   */\n  NEVER = 'Never',\n}\n\n/**\n * Props to configure an EksContainerDefinition\n */\nexport interface EksContainerDefinitionProps {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * An array of arguments to the entrypoint.\n   * If this isn't specified, the CMD of the container image is used.\n   * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\n   * the command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\n   * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   *\n   * @default - no args\n   */\n  readonly args?: string[];\n\n  /**\n   * The entrypoint for the container. This isn't run within a shell.\n   * If this isn't specified, the `ENTRYPOINT` of the container image is used.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\n   * the command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\n   * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\n   * The entrypoint can't be updated.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#entrypoint\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint\n   *\n   * @default - no command\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to this container.\n   *\n   * *Note*: Environment variables cannot start with \"AWS_BATCH\".\n   * This naming convention is reserved for variables that AWS Batch sets.\n   *\n   * @default - no environment variables\n   */\n  readonly env?: { [key:string]: string };\n\n  /**\n   * The image pull policy for this container\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images\n   *\n   * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise\n   */\n  readonly imagePullPolicy?: ImagePullPolicy;\n\n  /**\n   * The name of this container\n   *\n   * @default: `'Default'`\n   */\n  readonly name?: string;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   * If your container attempts to exceed the allocated memory, it will be terminated.\n   *\n   * Must be larger that 4 MiB\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory limit\n   */\n  readonly memoryLimit?: Size;\n\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   * Your container will be given at least this much memory, but may consume more.\n   *\n   * Must be larger that 4 MiB\n   *\n   * When system memory is under heavy contention, Docker attempts to keep the\n   * container memory to this soft limit. However, your container can consume more\n   * memory when it needs to, up to either the hard limit specified with the memory\n   * parameter (if applicable), or all of the available memory on the container\n   * instance, whichever comes first.\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required.\n   * If both are specified, then `memoryLimit` must be equal to `memoryReservation`\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory reserved\n   */\n  readonly memoryReservation?: Size;\n\n  /**\n   * The hard limit of CPUs to present to this container.\n   * Must be an even multiple of 0.25\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPU limit\n   */\n  readonly cpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPUs reserved\n   */\n  readonly cpuReservation?: number;\n\n  /**\n   * The hard limit of GPUs to present to this container.\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPU limit\n   */\n  readonly gpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPUs reserved\n   */\n  readonly gpuReservation?: number;\n\n  /**\n   * If specified, gives this container elevated permissions on the host container instance.\n   * The level of permissions are similar to the root user permissions.\n   *\n   * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * If specified, gives this container readonly access to its root file system.\n   *\n   * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * If specified, the container is run as the specified group ID (`gid`).\n   * If this parameter isn't specified, the default is the group that's specified in the image metadata.\n   * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default none\n   */\n  readonly runAsGroup?: number;\n\n  /**\n   * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced.\n   * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the container is *not* required to run as a non-root user\n   */\n  readonly runAsRoot?: boolean;\n\n  /**\n   * If specified, this container is run as the specified user ID (`uid`).\n   * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the user that is specified in the image metadata.\n   */\n  readonly runAsUser?: number;\n\n  /**\n   * The Volumes to mount to this container.\n   * Automatically added to the Pod.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/\n   *\n   * @default - no volumes\n   */\n  readonly volumes?: EksVolume[];\n}\n\n/**\n * A container that can be run with EKS orchestration on EC2 resources\n */\nexport class EksContainerDefinition extends Construct implements IEksContainerDefinition {\n  public readonly image: ecs.ContainerImage;\n  public readonly args?: string[];\n  public readonly command?: string[];\n  public readonly env?: { [key:string]: string };\n  public readonly imagePullPolicy?: ImagePullPolicy;\n  public readonly name?: string;\n  public readonly memoryLimit?: Size;\n  public readonly memoryReservation?: Size;\n  public readonly cpuLimit?: number;\n  public readonly cpuReservation?: number;\n  public readonly gpuLimit?: number;\n  public readonly gpuReservation?: number;\n  public readonly privileged?: boolean;\n  public readonly readonlyRootFilesystem?: boolean;\n  public readonly runAsGroup?: number;\n  public readonly runAsRoot?: boolean;\n  public readonly runAsUser?: number;\n  public readonly volumes: EksVolume[];\n\n  private readonly imageConfig: ecs.ContainerImageConfig;\n\n  constructor(scope: Construct, id: string, props: EksContainerDefinitionProps) {\n    super(scope, id);\n\n    this.image = props.image;\n    this.args = props.args;\n    this.command = props.command;\n    this.env = props.env;\n    this.imagePullPolicy = props.imagePullPolicy;\n    this.name = props.name;\n    this.memoryLimit = props.memoryLimit;\n    this.memoryReservation = props.memoryReservation;\n    this.cpuLimit = props.cpuLimit;\n    this.cpuReservation = props.cpuReservation;\n    this.gpuLimit = props.gpuLimit;\n    this.gpuReservation = props.gpuReservation;\n    this.privileged = props.privileged;\n    this.readonlyRootFilesystem = props.readonlyRootFilesystem;\n    this.runAsGroup = props.runAsGroup;\n    this.runAsRoot = props.runAsRoot;\n    this.runAsUser = props.runAsUser;\n    this.volumes = props.volumes ?? [];\n    this.imageConfig = props.image.bind(this, this as any);\n  }\n\n  addVolume(volume: EksVolume) {\n    this.volumes.push(volume);\n  }\n\n  /**\n   *\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.EksContainerProperty {\n    return {\n      image: this.imageConfig.imageName,\n      command: this.command,\n      args: this.args,\n      env: Object.keys(this.env ?? {}).map((key) => {\n        return {\n          name: key,\n          value: this.env![key],\n        };\n      }),\n      name: this.name,\n      imagePullPolicy: this.imagePullPolicy,\n      resources: {\n        limits: {\n          'cpu': this.cpuLimit,\n          'memory': this.memoryLimit ? this.memoryLimit.toMebibytes() + 'Mi' : undefined,\n          'nvidia.com/gpu': this.gpuLimit,\n        },\n        requests: {\n          'cpu': this.cpuReservation,\n          'memory': this.memoryReservation ? this.memoryReservation.toMebibytes() + 'Mi' : undefined,\n          'nvidia.com/gpu': this.gpuReservation,\n        },\n      },\n      securityContext: {\n        privileged: this.privileged,\n        readOnlyRootFilesystem: this.readonlyRootFilesystem,\n        runAsGroup: this.runAsGroup,\n        runAsNonRoot: !this.runAsRoot,\n        runAsUser: this.runAsUser,\n      },\n      volumeMounts: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n          return this.volumes.map((volume) => {\n            return {\n              name: volume.name,\n              mountPath: volume.containerPath,\n              readOnly: volume.readonly,\n            };\n          });\n        },\n      }),\n    };\n  };\n}\n\n/**\n * Options to configure an EksVolume\n */\nexport interface EksVolumeOptions {\n  /**\n   * The name of this volume.\n   * The name must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly name: string;\n\n  /**\n   * The path on the container where the volume is mounted.\n   *\n   * @default - the volume is not mounted\n   */\n  readonly mountPath?: string;\n\n  /**\n   * If specified, the container has readonly access to the volume.\n   * Otherwise, the container has read/write access.\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n}\n\n/**\n * A Volume that can be mounted to a container supported by EKS\n */\nexport abstract class EksVolume {\n  /**\n   * Creates a Kubernetes EmptyDir volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n   */\n  static emptyDir(options: EmptyDirVolumeOptions) {\n    return new EmptyDirVolume(options);\n  }\n  /**\n   * Creates a Kubernetes HostPath volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  static hostPath(options: HostPathVolumeOptions) {\n    return new HostPathVolume(options);\n  }\n  /**\n   * Creates a Kubernetes Secret volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n   */\n  static secret(options: SecretPathVolumeOptions) {\n    return new SecretPathVolume(options);\n  }\n\n  /**\n   * The name of this volume.\n   * The name must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly name: string;\n\n  /**\n   * The path on the container where the container is mounted.\n   *\n   * @default - the container is not mounted\n   */\n  readonly containerPath?: string;\n\n  /**\n   * If specified, the container has readonly access to the volume.\n   * Otherwise, the container has read/write access.\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n\n  constructor(options: EksVolumeOptions) {\n    this.name = options.name;\n    this.containerPath = options.mountPath;\n    this.readonly = options.readonly;\n  }\n}\n\n/**\n * Options for a Kubernetes EmptyDir volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n */\nexport interface EmptyDirVolumeOptions extends EksVolumeOptions {\n  /**\n   * The storage type to use for this Volume.\n   *\n   * @default `EmptyDirMediumType.DISK`\n   */\n  readonly medium?: EmptyDirMediumType;\n\n  /**\n   * The maximum size for this Volume\n   *\n   * @default - no size limit\n   */\n  readonly sizeLimit?: Size\n}\n\n/**\n * What medium the volume will live in\n */\nexport enum EmptyDirMediumType {\n  /**\n   * Use the disk storage of the node.\n   * Items written here will survive node reboots.\n   */\n  DISK = '',\n\n  /**\n   * Use the `tmpfs` volume that is backed by RAM of the node.\n   * Items written here will *not* survive node reboots.\n   */\n  MEMORY = 'Memory',\n}\n\n/**\n * A Kubernetes EmptyDir volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n */\nexport class EmptyDirVolume extends EksVolume {\n  /**\n   * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise\n   */\n  public static isEmptyDirVolume(x: any) : x is EmptyDirVolume {\n    return x !== null && typeof(x) === 'object' && EMPTY_DIR_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The storage type to use for this Volume.\n   *\n   * @default `EmptyDirMediumType.DISK`\n   */\n  readonly medium?: EmptyDirMediumType;\n\n  /**\n   * The maximum size for this Volume\n   *\n   * @default - no size limit\n   */\n  readonly sizeLimit?: Size;\n\n  constructor(options: EmptyDirVolumeOptions) {\n    super(options);\n    this.medium = options.medium;\n    this.sizeLimit = options.sizeLimit;\n  }\n}\n\nObject.defineProperty(EmptyDirVolume.prototype, EMPTY_DIR_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for a kubernetes HostPath volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n */\nexport interface HostPathVolumeOptions extends EksVolumeOptions {\n  /**\n   * The path of the file or directory on the host to mount into containers on the pod.\n   *\n   * *Note*: HothPath Volumes present many security risks, and should be avoided when possible.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  readonly hostPath: string;\n}\n\n/**\n * A Kubernetes HostPath volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n */\nexport class HostPathVolume extends EksVolume {\n  /**\n   * returns `true` if `x` is a HostPathVolume, `false` otherwise\n   */\n  public static isHostPathVolume(x: any) : x is HostPathVolume {\n    return x !== null && typeof(x) === 'object' && HOST_PATH_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The path of the file or directory on the host to mount into containers on the pod.\n   *\n   * *Note*: HothPath Volumes present many security risks, and should be avoided when possible.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  public readonly path: string;\n\n  constructor(options: HostPathVolumeOptions) {\n    super(options);\n    this.path = options.hostPath;\n  }\n}\n\nObject.defineProperty(HostPathVolume.prototype, HOST_PATH_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for a Kubernetes SecretPath Volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n */\nexport interface SecretPathVolumeOptions extends EksVolumeOptions {\n  /**\n   * The name of the secret.\n   * Must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly secretName: string;\n\n  /**\n   * Specifies whether the secret or the secret's keys must be defined\n   *\n   * @default true\n   */\n  readonly optional?: boolean;\n}\n\n/**\n * Specifies the configuration of a Kubernetes secret volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n */\nexport class SecretPathVolume extends EksVolume {\n  /**\n   * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise\n   */\n  public static isSecretPathVolume(x: any) : x is SecretPathVolume {\n    return x !== null && typeof(x) === 'object' && SECRET_PATH_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The name of the secret.\n   * Must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly secretName: string;\n\n  /**\n   * Specifies whether the secret or the secret's keys must be defined\n   *\n   * @default true\n   */\n  readonly optional?: boolean;\n\n  constructor(options: SecretPathVolumeOptions) {\n    super(options);\n    this.secretName = options.secretName;\n    this.optional = options.optional ?? true;\n  }\n}\n\nObject.defineProperty(SecretPathVolume.prototype, SECRET_PATH_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts new file mode 100644 index 0000000000000..02e0bf442017d --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts @@ -0,0 +1,123 @@ +import { Construct } from 'constructs'; +import { EksContainerDefinition } from './eks-container-definition'; +import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; +/** + * A JobDefinition that uses Eks orchestration + */ +export interface IEksJobDefinition extends IJobDefinition { + /** + * The container this Job Definition will run + */ + readonly container: EksContainerDefinition; + /** + * The DNS Policy of the pod used by this Job Definition + * + * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy + * + * @default `DnsPolicy.CLUSTER_FIRST` + */ + readonly dnsPolicy?: DnsPolicy; + /** + * If specified, the Pod used by this Job Definition will use the host's network IP address. + * Otherwise, the Kubernetes pod networking model is enabled. + * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections. + * + * @default true + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces + * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking + */ + readonly useHostNetwork?: boolean; + /** + * The name of the service account that's used to run the container. + * service accounts are Kubernetes method of identification and authentication, + * roughly analogous to IAM users. + * + * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html + * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ + * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html + * + * @default - the default service account of the container + */ + readonly serviceAccount?: string; +} +/** + * Props for EksJobDefinition + */ +export interface EksJobDefinitionProps extends JobDefinitionProps { + /** + * The container this Job Definition will run + */ + readonly container: EksContainerDefinition; + /** + * The DNS Policy of the pod used by this Job Definition + * + * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy + * + * @default `DnsPolicy.CLUSTER_FIRST` + */ + readonly dnsPolicy?: DnsPolicy; + /** + * If specified, the Pod used by this Job Definition will use the host's network IP address. + * Otherwise, the Kubernetes pod networking model is enabled. + * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections. + * + * @default true + * + * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces + * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking + */ + readonly useHostNetwork?: boolean; + /** + * The name of the service account that's used to run the container. + * service accounts are Kubernetes method of identification and authentication, + * roughly analogous to IAM users. + * + * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html + * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ + * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html + * + * @default - the default service account of the container + */ + readonly serviceAccount?: string; +} +/** + * The DNS Policy for the pod used by the Job Definition + * + * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy + */ +export declare enum DnsPolicy { + /** + * The Pod inherits the name resolution configuration from the node that the Pods run on + */ + DEFAULT = "Default", + /** + * Any DNS query that does not match the configured cluster domain suffix, such as `"www.kubernetes.io"`, + * is forwarded to an upstream nameserver by the DNS server. + * Cluster administrators may have extra stub-domain and upstream DNS servers configured. + */ + CLUSTER_FIRST = "ClusterFirst", + /** + * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`. + * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy. + */ + CLUSTER_FIRST_WITH_HOST_NET = "ClusterFirstWithHostNet" +} +/** + * A JobDefinition that uses Eks orchestration + * + * @resource AWS::Batch::JobDefinition + */ +export declare class EksJobDefinition extends JobDefinitionBase implements IEksJobDefinition { + /** + * Import an EksJobDefinition by its arn + */ + static fromEksJobDefinitionArn(scope: Construct, id: string, eksJobDefinitionArn: string): IEksJobDefinition; + readonly container: EksContainerDefinition; + readonly dnsPolicy?: DnsPolicy; + readonly useHostNetwork?: boolean; + readonly serviceAccount?: string; + readonly jobDefinitionArn: string; + readonly jobDefinitionName: string; + constructor(scope: Construct, id: string, props: EksJobDefinitionProps); +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js new file mode 100644 index 0000000000000..cb23b62ee18c9 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js @@ -0,0 +1,134 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.EksJobDefinition = exports.DnsPolicy = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +const eks_container_definition_1 = require("./eks-container-definition"); +const job_definition_base_1 = require("./job-definition-base"); +/** + * The DNS Policy for the pod used by the Job Definition + * + * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy + */ +var DnsPolicy; +(function (DnsPolicy) { + /** + * The Pod inherits the name resolution configuration from the node that the Pods run on + */ + DnsPolicy["DEFAULT"] = "Default"; + /** + * Any DNS query that does not match the configured cluster domain suffix, such as `"www.kubernetes.io"`, + * is forwarded to an upstream nameserver by the DNS server. + * Cluster administrators may have extra stub-domain and upstream DNS servers configured. + */ + DnsPolicy["CLUSTER_FIRST"] = "ClusterFirst"; + /** + * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`. + * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy. + */ + DnsPolicy["CLUSTER_FIRST_WITH_HOST_NET"] = "ClusterFirstWithHostNet"; +})(DnsPolicy || (exports.DnsPolicy = DnsPolicy = {})); +/** + * A JobDefinition that uses Eks orchestration + * + * @resource AWS::Batch::JobDefinition + */ +class EksJobDefinition extends job_definition_base_1.JobDefinitionBase { + /** + * Import an EksJobDefinition by its arn + */ + static fromEksJobDefinitionArn(scope, id, eksJobDefinitionArn) { + const stack = core_1.Stack.of(scope); + const jobDefinitionName = stack.splitArn(eksJobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + class Import extends job_definition_base_1.JobDefinitionBase { + constructor() { + super(...arguments); + this.jobDefinitionArn = eksJobDefinitionArn; + this.jobDefinitionName = jobDefinitionName; + this.enabled = true; + this.container = {}; + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksJobDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, EksJobDefinition); + } + throw error; + } + this.container = props.container; + this.dnsPolicy = props.dnsPolicy; + this.useHostNetwork = props.useHostNetwork; + this.serviceAccount = props.serviceAccount; + const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { + ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), + type: 'container', + jobDefinitionName: props.jobDefinitionName, + eksProperties: { + podProperties: { + containers: [ + this.container._renderContainerDefinition(), + ], + dnsPolicy: this.dnsPolicy, + hostNetwork: this.useHostNetwork, + serviceAccountName: this.serviceAccount, + volumes: core_1.Lazy.any({ + produce: () => { + if (this.container.volumes.length === 0) { + return undefined; + } + return this.container.volumes.map((volume) => { + if (eks_container_definition_1.EmptyDirVolume.isEmptyDirVolume(volume)) { + return { + name: volume.name, + emptyDir: { + medium: volume.medium, + sizeLimit: volume.sizeLimit ? volume.sizeLimit.toMebibytes().toString() + 'Mi' : undefined, + }, + }; + } + if (eks_container_definition_1.HostPathVolume.isHostPathVolume(volume)) { + return { + name: volume.name, + hostPath: { + path: volume.path, + }, + }; + } + if (eks_container_definition_1.SecretPathVolume.isSecretPathVolume(volume)) { + return { + name: volume.name, + secret: { + optional: volume.optional, + secretName: volume.secretName, + }, + }; + } + throw new Error('unknown volume type'); + }); + }, + }), + }, + }, + }); + this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { + service: 'batch', + resource: 'job-definition', + resourceName: this.physicalName, + }); + this.jobDefinitionName = this.getResourceNameAttribute(resource.ref); + } +} +exports.EksJobDefinition = EksJobDefinition; +_a = JSII_RTTI_SYMBOL_1; +EksJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EksJobDefinition", version: "0.0.0" }; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-job-definition.js","sourceRoot":"","sources":["eks-job-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArnFormat, Lazy, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { EksContainerDefinition, EmptyDirVolume, HostPathVolume, SecretPathVolume } from './eks-container-definition';\nimport { baseJobDefinitionProperties, IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base';\n\n/**\n * A JobDefinition that uses Eks orchestration\n */\nexport interface IEksJobDefinition extends IJobDefinition {\n  /**\n   * The container this Job Definition will run\n   */\n  readonly container: EksContainerDefinition;\n\n  /**\n   * The DNS Policy of the pod used by this Job Definition\n   *\n   * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n   *\n   * @default `DnsPolicy.CLUSTER_FIRST`\n   */\n  readonly dnsPolicy?: DnsPolicy;\n\n  /**\n   * If specified, the Pod used by this Job Definition will use the host's network IP address.\n   * Otherwise, the Kubernetes pod networking model is enabled.\n   * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.\n   *\n   * @default true\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking\n   */\n  readonly useHostNetwork?: boolean;\n\n  /**\n   * The name of the service account that's used to run the container.\n   * service accounts are Kubernetes method of identification and authentication,\n   * roughly analogous to IAM users.\n   *\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html\n   * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html\n   *\n   * @default - the default service account of the container\n   */\n  readonly serviceAccount?: string;\n}\n\n/**\n * Props for EksJobDefinition\n */\nexport interface EksJobDefinitionProps extends JobDefinitionProps {\n  /**\n   * The container this Job Definition will run\n   */\n  readonly container: EksContainerDefinition;\n\n  /**\n   * The DNS Policy of the pod used by this Job Definition\n   *\n   * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n   *\n   * @default `DnsPolicy.CLUSTER_FIRST`\n   */\n  readonly dnsPolicy?: DnsPolicy;\n\n  /**\n   * If specified, the Pod used by this Job Definition will use the host's network IP address.\n   * Otherwise, the Kubernetes pod networking model is enabled.\n   * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.\n   *\n   * @default true\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking\n   */\n  readonly useHostNetwork?: boolean;\n\n  /**\n   * The name of the service account that's used to run the container.\n   * service accounts are Kubernetes method of identification and authentication,\n   * roughly analogous to IAM users.\n   *\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html\n   * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html\n   *\n   * @default - the default service account of the container\n   */\n  readonly serviceAccount?: string;\n}\n\n/**\n * The DNS Policy for the pod used by the Job Definition\n *\n * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n */\nexport enum DnsPolicy {\n  /**\n   * The Pod inherits the name resolution configuration from the node that the Pods run on\n   */\n  DEFAULT = 'Default',\n\n  /**\n   * Any DNS query that does not match the configured cluster domain suffix, such as `\"www.kubernetes.io\"`,\n   * is forwarded to an upstream nameserver by the DNS server.\n   * Cluster administrators may have extra stub-domain and upstream DNS servers configured.\n   */\n  CLUSTER_FIRST = 'ClusterFirst',\n\n  /**\n   * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`.\n   * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy.\n   */\n  CLUSTER_FIRST_WITH_HOST_NET = 'ClusterFirstWithHostNet',\n}\n\n/**\n * A JobDefinition that uses Eks orchestration\n *\n * @resource AWS::Batch::JobDefinition\n */\nexport class EksJobDefinition extends JobDefinitionBase implements IEksJobDefinition {\n  /**\n   * Import an EksJobDefinition by its arn\n   */\n  public static fromEksJobDefinitionArn(scope: Construct, id: string, eksJobDefinitionArn: string): IEksJobDefinition {\n    const stack = Stack.of(scope);\n    const jobDefinitionName = stack.splitArn(eksJobDefinitionArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends JobDefinitionBase implements IJobDefinition {\n      public readonly jobDefinitionArn = eksJobDefinitionArn;\n      public readonly jobDefinitionName = jobDefinitionName;\n      public readonly enabled = true;\n      public readonly container = {} as any;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly container: EksContainerDefinition;\n  public readonly dnsPolicy?: DnsPolicy;\n  public readonly useHostNetwork?: boolean;\n  public readonly serviceAccount?: string;\n\n  public readonly jobDefinitionArn: string;\n  public readonly jobDefinitionName: string;\n\n  constructor(scope: Construct, id: string, props: EksJobDefinitionProps) {\n    super(scope, id, props);\n\n    this.container = props.container;\n    this.dnsPolicy = props.dnsPolicy;\n    this.useHostNetwork = props.useHostNetwork;\n    this.serviceAccount = props.serviceAccount;\n\n    const resource = new CfnJobDefinition(this, 'Resource', {\n      ...baseJobDefinitionProperties(this),\n      type: 'container',\n      jobDefinitionName: props.jobDefinitionName,\n      eksProperties: {\n        podProperties: {\n          containers: [\n            this.container._renderContainerDefinition(),\n          ],\n          dnsPolicy: this.dnsPolicy,\n          hostNetwork: this.useHostNetwork,\n          serviceAccountName: this.serviceAccount,\n          volumes: Lazy.any({\n            produce: () => {\n              if (this.container.volumes.length === 0) {\n                return undefined;\n              }\n              return this.container.volumes.map((volume) => {\n                if (EmptyDirVolume.isEmptyDirVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    emptyDir: {\n                      medium: volume.medium,\n                      sizeLimit: volume.sizeLimit ? volume.sizeLimit.toMebibytes().toString() + 'Mi' : undefined,\n                    },\n                  };\n                }\n                if (HostPathVolume.isHostPathVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    hostPath: {\n                      path: volume.path,\n                    },\n                  };\n                }\n                if (SecretPathVolume.isSecretPathVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    secret: {\n                      optional: volume.optional,\n                      secretName: volume.secretName,\n                    },\n                  };\n                }\n\n                throw new Error('unknown volume type');\n              });\n            },\n          }),\n        },\n      },\n    });\n    this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, {\n      service: 'batch',\n      resource: 'job-definition',\n      resourceName: this.physicalName,\n    });\n    this.jobDefinitionName = this.getResourceNameAttribute(resource.ref);\n  }\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts new file mode 100644 index 0000000000000..ffad48bef4c02 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts @@ -0,0 +1,12 @@ +export * from './ecs-job-definition'; +export { IComputeEnvironment, ComputeEnvironmentProps } from './compute-environment-base'; +export * from './eks-job-definition'; +export * from './ecs-container-definition'; +export * from './eks-container-definition'; +export * from './job-definition-base'; +export * from './job-queue'; +export * from './linux-parameters'; +export * from './managed-compute-environment'; +export * from './multinode-job-definition'; +export * from './scheduling-policy'; +export * from './unmanaged-compute-environment'; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/index.js b/packages/@aws-cdk/aws-batch-alpha/lib/index.js new file mode 100644 index 0000000000000..586a60b134365 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/index.js @@ -0,0 +1,29 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __exportStar = (this && this.__exportStar) || function(m, exports) { + for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +// AWS::Batch CloudFormation Resources: +__exportStar(require("./ecs-job-definition"), exports); +__exportStar(require("./eks-job-definition"), exports); +__exportStar(require("./ecs-container-definition"), exports); +__exportStar(require("./eks-container-definition"), exports); +__exportStar(require("./job-definition-base"), exports); +__exportStar(require("./job-queue"), exports); +__exportStar(require("./linux-parameters"), exports); +__exportStar(require("./managed-compute-environment"), exports); +__exportStar(require("./multinode-job-definition"), exports); +__exportStar(require("./scheduling-policy"), exports); +__exportStar(require("./unmanaged-compute-environment"), exports); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdUNBQXVDO0FBQ3ZDLHVEQUFxQztBQUVyQyx1REFBcUM7QUFDckMsNkRBQTJDO0FBQzNDLDZEQUEyQztBQUMzQyx3REFBc0M7QUFDdEMsOENBQTRCO0FBQzVCLHFEQUFtQztBQUNuQyxnRUFBOEM7QUFDOUMsNkRBQTJDO0FBQzNDLHNEQUFvQztBQUNwQyxrRUFBZ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBV1M6OkJhdGNoIENsb3VkRm9ybWF0aW9uIFJlc291cmNlczpcbmV4cG9ydCAqIGZyb20gJy4vZWNzLWpvYi1kZWZpbml0aW9uJztcbmV4cG9ydCB7IElDb21wdXRlRW52aXJvbm1lbnQsIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIH0gZnJvbSAnLi9jb21wdXRlLWVudmlyb25tZW50LWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9la3Mtam9iLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9lY3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9la3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9qb2ItZGVmaW5pdGlvbi1iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vam9iLXF1ZXVlJztcbmV4cG9ydCAqIGZyb20gJy4vbGludXgtcGFyYW1ldGVycyc7XG5leHBvcnQgKiBmcm9tICcuL21hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudCc7XG5leHBvcnQgKiBmcm9tICcuL211bHRpbm9kZS1qb2ItZGVmaW5pdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3NjaGVkdWxpbmctcG9saWN5JztcbmV4cG9ydCAqIGZyb20gJy4vdW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQnOyJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts new file mode 100644 index 0000000000000..27ab7a53f3600 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts @@ -0,0 +1,217 @@ +import { Duration, IResource, Resource } from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +import { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch'; +/** + * Represents a JobDefinition + */ +export interface IJobDefinition extends IResource { + /** + * The ARN of this job definition + * + * @attribute + */ + readonly jobDefinitionArn: string; + /** + * The name of this job definition + * + * @attribute + */ + readonly jobDefinitionName: string; + /** + * The default parameters passed to the container + * These parameters can be referenced in the `command` that + * you give to the container + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters + * + * @default none + */ + readonly parameters?: { + [key: string]: any; + }; + /** + * The number of times to retry a job. + * The job is retried on failure the same number of attempts as the value. + * + * @default 1 + */ + readonly retryAttempts?: number; + /** + * Defines the retry behavior for this job + * + * @default - no `RetryStrategy` + */ + readonly retryStrategies: RetryStrategy[]; + /** + * The priority of this Job. Only used in Fairshare Scheduling + * to decide which job to run first when there are multiple jobs + * with the same share identifier. + * + * @default none + */ + readonly schedulingPriority?: number; + /** + * The timeout time for jobs that are submitted with this job definition. + * After the amount of time you specify passes, + * Batch terminates your jobs if they aren't finished. + * + * @default - no timeout + */ + readonly timeout?: Duration; + /** + * Add a RetryStrategy to this JobDefinition + */ + addRetryStrategy(strategy: RetryStrategy): void; +} +/** + * Props common to all JobDefinitions + */ +export interface JobDefinitionProps { + /** + * The name of this job definition + * + * @default - generated by CloudFormation + */ + readonly jobDefinitionName?: string; + /** + * The default parameters passed to the container + * These parameters can be referenced in the `command` that + * you give to the container + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters + * + * @default none + */ + readonly parameters?: { + [key: string]: any; + }; + /** + * The number of times to retry a job. + * The job is retried on failure the same number of attempts as the value. + * + * @default 1 + */ + readonly retryAttempts?: number; + /** + * Defines the retry behavior for this job + * + * @default - no `RetryStrategy` + */ + readonly retryStrategies?: RetryStrategy[]; + /** + * The priority of this Job. Only used in Fairshare Scheduling + * to decide which job to run first when there are multiple jobs + * with the same share identifier. + * + * @default none + */ + readonly schedulingPriority?: number; + /** + * The timeout time for jobs that are submitted with this job definition. + * After the amount of time you specify passes, + * Batch terminates your jobs if they aren't finished. + * + * @default - no timeout + */ + readonly timeout?: Duration; +} +/** + * Define how Jobs using this JobDefinition respond to different exit conditions + */ +export declare class RetryStrategy { + /** + * Create a new RetryStrategy + */ + static of(action: Action, on: Reason): RetryStrategy; + /** + * The action to take when the job exits with the Reason specified + */ + readonly action: Action; + /** + * If the job exits with this Reason it will trigger the specified Action + */ + readonly on: Reason; + constructor(action: Action, on: Reason); +} +/** + * The Action to take when all specified conditions in a RetryStrategy are met + */ +export declare enum Action { + /** + * The job will not retry + */ + EXIT = "EXIT", + /** + * The job will retry. It can be retried up to the number of times specified in `retryAttempts`. + */ + RETRY = "RETRY" +} +/** + * The corresponding Action will only be taken if *all* of the conditions specified here are met. + */ +export interface CustomReason { + /** + * A glob string that will match on the job exit code. For example, `'40*'` will match 400, 404, 40123456789012 + * + * @default - will not match on the exit code + */ + readonly onExitCode?: string; + /** + * A glob string that will match on the statusReason returned by the exiting job. + * For example, `'Host EC2*'` indicates that the spot instance has been reclaimed. + * + * @default - will not match on the status reason + */ + readonly onStatusReason?: string; + /** + * A glob string that will match on the reason returned by the exiting job + * For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled. + * + * @default - will not match on the reason + */ + readonly onReason?: string; +} +/** + * Common job exit reasons + */ +export declare class Reason { + /** + * Will match any non-zero exit code + */ + static readonly NON_ZERO_EXIT_CODE: Reason; + /** + * Will only match if the Docker container could not be pulled + */ + static readonly CANNOT_PULL_CONTAINER: Reason; + /** + * Will only match if the Spot instance executing the job was reclaimed + */ + static readonly SPOT_INSTANCE_RECLAIMED: Reason; + /** + * A custom Reason that can match on multiple conditions. + * Note that all specified conditions must be met for this reason to match. + */ + static custom(customReasonProps: CustomReason): Reason; +} +/** + * Abstract base class for JobDefinitions + * + * @internal + */ +export declare abstract class JobDefinitionBase extends Resource implements IJobDefinition { + abstract readonly jobDefinitionArn: string; + abstract readonly jobDefinitionName: string; + readonly parameters?: { + [key: string]: any; + }; + readonly retryAttempts?: number; + readonly retryStrategies: RetryStrategy[]; + readonly schedulingPriority?: number; + readonly timeout?: Duration; + constructor(scope: Construct, id: string, props?: JobDefinitionProps); + addRetryStrategy(strategy: RetryStrategy): void; +} +/** + * @internal + */ +export declare function baseJobDefinitionProperties(baseJobDefinition: JobDefinitionBase): CfnJobDefinitionProps; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js new file mode 100644 index 0000000000000..14745de9bb71c --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js @@ -0,0 +1,153 @@ +"use strict"; +var _a, _b; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.baseJobDefinitionProperties = exports.JobDefinitionBase = exports.Reason = exports.Action = exports.RetryStrategy = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +/** + * Define how Jobs using this JobDefinition respond to different exit conditions + */ +class RetryStrategy { + /** + * Create a new RetryStrategy + */ + static of(action, on) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Action(action); + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Reason(on); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.of); + } + throw error; + } + return new RetryStrategy(action, on); + } + constructor(action, on) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Action(action); + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Reason(on); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, RetryStrategy); + } + throw error; + } + this.action = action; + this.on = on; + } +} +exports.RetryStrategy = RetryStrategy; +_a = JSII_RTTI_SYMBOL_1; +RetryStrategy[_a] = { fqn: "@aws-cdk/aws-batch-alpha.RetryStrategy", version: "0.0.0" }; +/** + * The Action to take when all specified conditions in a RetryStrategy are met + */ +var Action; +(function (Action) { + /** + * The job will not retry + */ + Action["EXIT"] = "EXIT"; + /** + * The job will retry. It can be retried up to the number of times specified in `retryAttempts`. + */ + Action["RETRY"] = "RETRY"; +})(Action || (exports.Action = Action = {})); +/** + * Common job exit reasons + */ +class Reason { + /** + * A custom Reason that can match on multiple conditions. + * Note that all specified conditions must be met for this reason to match. + */ + static custom(customReasonProps) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_CustomReason(customReasonProps); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.custom); + } + throw error; + } + return customReasonProps; + } +} +exports.Reason = Reason; +_b = JSII_RTTI_SYMBOL_1; +Reason[_b] = { fqn: "@aws-cdk/aws-batch-alpha.Reason", version: "0.0.0" }; +/** + * Will match any non-zero exit code + */ +Reason.NON_ZERO_EXIT_CODE = { + onExitCode: '*', +}; +/** + * Will only match if the Docker container could not be pulled + */ +Reason.CANNOT_PULL_CONTAINER = { + onReason: 'CannotPullContainerError:*', +}; +/** + * Will only match if the Spot instance executing the job was reclaimed + */ +Reason.SPOT_INSTANCE_RECLAIMED = { + onStatusReason: 'Host EC2*', +}; +/** + * Abstract base class for JobDefinitions + * + * @internal + */ +class JobDefinitionBase extends core_1.Resource { + constructor(scope, id, props) { + super(scope, id, { + physicalName: props?.jobDefinitionName, + }); + this.parameters = props?.parameters; + this.retryAttempts = props?.retryAttempts; + this.retryStrategies = props?.retryStrategies ?? []; + this.schedulingPriority = props?.schedulingPriority; + this.timeout = props?.timeout; + } + addRetryStrategy(strategy) { + this.retryStrategies.push(strategy); + } +} +exports.JobDefinitionBase = JobDefinitionBase; +/** + * @internal + */ +function baseJobDefinitionProperties(baseJobDefinition) { + return { + parameters: baseJobDefinition.parameters, + retryStrategy: { + attempts: baseJobDefinition.retryAttempts, + evaluateOnExit: core_1.Lazy.any({ + produce: () => { + if (baseJobDefinition.retryStrategies.length === 0) { + return undefined; + } + return baseJobDefinition.retryStrategies.map((strategy) => { + return { + action: strategy.action, + ...strategy.on, + }; + }); + }, + }), + }, + schedulingPriority: baseJobDefinition.schedulingPriority, + timeout: { + attemptDurationSeconds: baseJobDefinition.timeout?.toSeconds(), + }, + type: 'dummy', + }; +} +exports.baseJobDefinitionProperties = baseJobDefinitionProperties; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-definition-base.js","sourceRoot":"","sources":["job-definition-base.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAuE;AAgIvE;;GAEG;AACH,MAAa,aAAa;IACxB;;OAEG;IACI,MAAM,CAAC,EAAE,CAAC,MAAc,EAAE,EAAU;;;;;;;;;;;QACzC,OAAO,IAAI,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;KACtC;IAYD,YAAY,MAAc,EAAE,EAAU;;;;;;;+CAlB3B,aAAa;;;;QAmBtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;KACd;;AArBH,sCAsBC;;;AAED;;GAEG;AACH,IAAY,MASX;AATD,WAAY,MAAM;IAChB;;OAEG;IACH,uBAAa,CAAA;IACb;;OAEG;IACH,yBAAe,CAAA;AACjB,CAAC,EATW,MAAM,sBAAN,MAAM,QASjB;AA8BD;;GAEG;AACH,MAAa,MAAM;IAsBjB;;;OAGG;IACH,MAAM,CAAC,MAAM,CAAC,iBAA+B;;;;;;;;;;QAC3C,OAAO,iBAAiB,CAAC;KAC1B;;AA5BH,wBA6BC;;;AA5BC;;GAEG;AACa,yBAAkB,GAAW;IAC3C,UAAU,EAAE,GAAG;CAChB,CAAC;AAEF;;GAEG;AACa,4BAAqB,GAAW;IAC9C,QAAQ,EAAE,4BAA4B;CACvC,CAAA;AAED;;GAEG;AACa,8BAAuB,GAAW;IAChD,cAAc,EAAE,WAAW;CAC5B,CAAA;AAWH;;;;GAIG;AACH,MAAsB,iBAAkB,SAAQ,eAAQ;IAUtD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,EAAE,iBAAiB;SACvC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,KAAK,EAAE,UAAU,CAAC;QACpC,IAAI,CAAC,aAAa,GAAG,KAAK,EAAE,aAAa,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,eAAe,IAAI,EAAE,CAAC;QACpD,IAAI,CAAC,kBAAkB,GAAG,KAAK,EAAE,kBAAkB,CAAC;QACpD,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,OAAO,CAAC;KAC/B;IAED,gBAAgB,CAAC,QAAuB;QACtC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACrC;CACF;AAzBD,8CAyBC;AAED;;GAEG;AACH,SAAgB,2BAA2B,CAAC,iBAAoC;IAC9E,OAAO;QACL,UAAU,EAAE,iBAAiB,CAAC,UAAU;QACxC,aAAa,EAAE;YACb,QAAQ,EAAE,iBAAiB,CAAC,aAAa;YACzC,cAAc,EAAE,WAAI,CAAC,GAAG,CAAC;gBACvB,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,iBAAiB,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;wBAClD,OAAO,SAAS,CAAC;qBAClB;oBACD,OAAO,iBAAiB,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;wBACxD,OAAO;4BACL,MAAM,EAAE,QAAQ,CAAC,MAAM;4BACvB,GAAG,QAAQ,CAAC,EAAE;yBACf,CAAC;oBACJ,CAAC,CAAC,CAAC;gBACL,CAAC;aACF,CAAC;SACH;QACD,kBAAkB,EAAE,iBAAiB,CAAC,kBAAkB;QACxD,OAAO,EAAE;YACP,sBAAsB,EAAE,iBAAiB,CAAC,OAAO,EAAE,SAAS,EAAE;SAC/D;QACD,IAAI,EAAE,OAAO;KACd,CAAC;AACJ,CAAC;AAzBD,kEAyBC","sourcesContent":["import { Duration, IResource, Lazy, Resource } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\n/**\n * Represents a JobDefinition\n */\nexport interface IJobDefinition extends IResource {\n  /**\n   * The ARN of this job definition\n   *\n   * @attribute\n   */\n  readonly jobDefinitionArn: string;\n\n  /**\n   * The name of this job definition\n   *\n   * @attribute\n   */\n  readonly jobDefinitionName: string;\n\n  /**\n   * The default parameters passed to the container\n   * These parameters can be referenced in the `command` that\n   * you give to the container\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters\n   *\n   * @default none\n   */\n  readonly parameters?: { [key:string]: any };\n\n  /**\n   * The number of times to retry a job.\n   * The job is retried on failure the same number of attempts as the value.\n   *\n   * @default 1\n   */\n  readonly retryAttempts?: number;\n\n  /**\n   * Defines the retry behavior for this job\n   *\n   * @default - no `RetryStrategy`\n   */\n  readonly retryStrategies: RetryStrategy[];\n\n  /**\n   * The priority of this Job. Only used in Fairshare Scheduling\n   * to decide which job to run first when there are multiple jobs\n   * with the same share identifier.\n   *\n   * @default none\n   */\n  readonly schedulingPriority?: number;\n\n  /**\n   * The timeout time for jobs that are submitted with this job definition.\n   * After the amount of time you specify passes,\n   * Batch terminates your jobs if they aren't finished.\n   *\n   * @default - no timeout\n   */\n  readonly timeout?: Duration;\n\n  /**\n   * Add a RetryStrategy to this JobDefinition\n   */\n  addRetryStrategy(strategy: RetryStrategy): void;\n}\n\n/**\n * Props common to all JobDefinitions\n */\nexport interface JobDefinitionProps {\n  /**\n   * The name of this job definition\n   *\n   * @default - generated by CloudFormation\n   */\n  readonly jobDefinitionName?: string;\n\n  /**\n   * The default parameters passed to the container\n   * These parameters can be referenced in the `command` that\n   * you give to the container\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters\n   *\n   * @default none\n   */\n  readonly parameters?: { [key:string]: any };\n\n  /**\n   * The number of times to retry a job.\n   * The job is retried on failure the same number of attempts as the value.\n   *\n   * @default 1\n   */\n  readonly retryAttempts?: number;\n\n  /**\n   * Defines the retry behavior for this job\n   *\n   * @default - no `RetryStrategy`\n   */\n  readonly retryStrategies?: RetryStrategy[];\n\n  /**\n   * The priority of this Job. Only used in Fairshare Scheduling\n   * to decide which job to run first when there are multiple jobs\n   * with the same share identifier.\n   *\n   * @default none\n   */\n  readonly schedulingPriority?: number;\n\n  /**\n   * The timeout time for jobs that are submitted with this job definition.\n   * After the amount of time you specify passes,\n   * Batch terminates your jobs if they aren't finished.\n   *\n   * @default - no timeout\n   */\n  readonly timeout?: Duration;\n}\n\n/**\n * Define how Jobs using this JobDefinition respond to different exit conditions\n */\nexport class RetryStrategy {\n  /**\n   * Create a new RetryStrategy\n   */\n  public static of(action: Action, on: Reason) {\n    return new RetryStrategy(action, on);\n  }\n\n  /**\n   * The action to take when the job exits with the Reason specified\n   */\n  public readonly action: Action;\n\n  /**\n   * If the job exits with this Reason it will trigger the specified Action\n   */\n  public readonly on: Reason;\n\n  constructor(action: Action, on: Reason) {\n    this.action = action;\n    this.on = on;\n  }\n}\n\n/**\n * The Action to take when all specified conditions in a RetryStrategy are met\n */\nexport enum Action {\n  /**\n   * The job will not retry\n   */\n  EXIT = 'EXIT',\n  /**\n   * The job will retry. It can be retried up to the number of times specified in `retryAttempts`.\n   */\n  RETRY = 'RETRY',\n}\n\n/**\n * The corresponding Action will only be taken if *all* of the conditions specified here are met.\n */\nexport interface CustomReason {\n  /**\n   * A glob string that will match on the job exit code. For example, `'40*'` will match 400, 404, 40123456789012\n   *\n   * @default - will not match on the exit code\n   */\n  readonly onExitCode?: string;\n\n  /**\n   * A glob string that will match on the statusReason returned by the exiting job.\n   * For example, `'Host EC2*'` indicates that the spot instance has been reclaimed.\n   *\n   * @default - will not match on the status reason\n   */\n  readonly onStatusReason?: string;\n\n  /**\n   * A glob string that will match on the reason returned by the exiting job\n   * For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled.\n   *\n   * @default - will not match on the reason\n   */\n  readonly onReason?: string;\n}\n\n/**\n * Common job exit reasons\n */\nexport class Reason {\n  /**\n   * Will match any non-zero exit code\n   */\n  static readonly NON_ZERO_EXIT_CODE: Reason = {\n    onExitCode: '*',\n  };\n\n  /**\n   * Will only match if the Docker container could not be pulled\n   */\n  static readonly CANNOT_PULL_CONTAINER: Reason = {\n    onReason: 'CannotPullContainerError:*',\n  }\n\n  /**\n   * Will only match if the Spot instance executing the job was reclaimed\n   */\n  static readonly SPOT_INSTANCE_RECLAIMED: Reason = {\n    onStatusReason: 'Host EC2*',\n  }\n\n  /**\n   * A custom Reason that can match on multiple conditions.\n   * Note that all specified conditions must be met for this reason to match.\n   */\n  static custom(customReasonProps: CustomReason): Reason {\n    return customReasonProps;\n  }\n}\n\n/**\n * Abstract base class for JobDefinitions\n *\n * @internal\n */\nexport abstract class JobDefinitionBase extends Resource implements IJobDefinition {\n  public readonly abstract jobDefinitionArn: string;\n  public readonly abstract jobDefinitionName: string;\n\n  public readonly parameters?: { [key:string]: any };\n  public readonly retryAttempts?: number;\n  public readonly retryStrategies: RetryStrategy[];\n  public readonly schedulingPriority?: number;\n  public readonly timeout?: Duration;\n\n  constructor(scope: Construct, id: string, props?: JobDefinitionProps) {\n    super(scope, id, {\n      physicalName: props?.jobDefinitionName,\n    });\n\n    this.parameters = props?.parameters;\n    this.retryAttempts = props?.retryAttempts;\n    this.retryStrategies = props?.retryStrategies ?? [];\n    this.schedulingPriority = props?.schedulingPriority;\n    this.timeout = props?.timeout;\n  }\n\n  addRetryStrategy(strategy: RetryStrategy): void {\n    this.retryStrategies.push(strategy);\n  }\n}\n\n/**\n * @internal\n */\nexport function baseJobDefinitionProperties(baseJobDefinition: JobDefinitionBase): CfnJobDefinitionProps {\n  return {\n    parameters: baseJobDefinition.parameters,\n    retryStrategy: {\n      attempts: baseJobDefinition.retryAttempts,\n      evaluateOnExit: Lazy.any({\n        produce: () => {\n          if (baseJobDefinition.retryStrategies.length === 0) {\n            return undefined;\n          }\n          return baseJobDefinition.retryStrategies.map((strategy) => {\n            return {\n              action: strategy.action,\n              ...strategy.on,\n            };\n          });\n        },\n      }),\n    },\n    schedulingPriority: baseJobDefinition.schedulingPriority,\n    timeout: {\n      attemptDurationSeconds: baseJobDefinition.timeout?.toSeconds(),\n    },\n    type: 'dummy',\n  };\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts new file mode 100644 index 0000000000000..d72695ba8bdbb --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts @@ -0,0 +1,140 @@ +import { IResource, Resource } from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +import { IComputeEnvironment } from './compute-environment-base'; +import { ISchedulingPolicy } from './scheduling-policy'; +/** + * Represents a JobQueue + */ +export interface IJobQueue extends IResource { + /** + * The name of the job queue. It can be up to 128 letters long. + * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_) + * + * @attribute + */ + readonly jobQueueName: string; + /** + * The ARN of this job queue + * + * @attribute + */ + readonly jobQueueArn: string; + /** + * The set of compute environments mapped to a job queue and their order relative to each other. + * The job scheduler uses this parameter to determine which compute environment runs a specific job. + * Compute environments must be in the VALID state before you can associate them with a job queue. + * You can associate up to three compute environments with a job queue. + * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT); + * EC2 and Fargate compute environments can't be mixed. + * + * *Note*: All compute environments that are associated with a job queue must share the same architecture. + * AWS Batch doesn't support mixing compute environment architecture types in a single job queue. + */ + readonly computeEnvironments: OrderedComputeEnvironment[]; + /** + * The priority of the job queue. + * Job queues with a higher priority are evaluated first when associated with the same compute environment. + * Priority is determined in descending order. + * For example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1. + */ + readonly priority: number; + /** + * If the job queue is enabled, it is able to accept jobs. + * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish. + * + * @default true + */ + readonly enabled?: boolean; + /** + * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs. + * + * @default - no scheduling policy + */ + readonly schedulingPolicy?: ISchedulingPolicy; + /** + * Add a `ComputeEnvironment` to this Queue. + * The Queue will prefer lower-order `ComputeEnvironment`s. + */ + addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void; +} +/** + * Props to configure a JobQueue + */ +export interface JobQueueProps { + /** + * The set of compute environments mapped to a job queue and their order relative to each other. + * The job scheduler uses this parameter to determine which compute environment runs a specific job. + * Compute environments must be in the VALID state before you can associate them with a job queue. + * You can associate up to three compute environments with a job queue. + * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT); + * EC2 and Fargate compute environments can't be mixed. + * + * *Note*: All compute environments that are associated with a job queue must share the same architecture. + * AWS Batch doesn't support mixing compute environment architecture types in a single job queue. + * + * @default none + */ + readonly computeEnvironments?: OrderedComputeEnvironment[]; + /** + * The priority of the job queue. + * Job queues with a higher priority are evaluated first when associated with the same compute environment. + * Priority is determined in descending order. + * For example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1. + * + * @default 1 + */ + readonly priority?: number; + /** + * The name of the job queue. It can be up to 128 letters long. + * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_) + * + * @default - no name + */ + readonly jobQueueName?: string; + /** + * If the job queue is enabled, it is able to accept jobs. + * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish. + * + * @default true + */ + readonly enabled?: boolean; + /** + * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs. + * + * @default - no scheduling policy + */ + readonly schedulingPolicy?: ISchedulingPolicy; +} +/** + * Assigns an order to a ComputeEnvironment. + * The JobQueue will prioritize the lowest-order ComputeEnvironment. + */ +export interface OrderedComputeEnvironment { + /** + * The ComputeEnvironment to link to this JobQueue + */ + readonly computeEnvironment: IComputeEnvironment; + /** + * The order associated with `computeEnvironment` + */ + readonly order: number; +} +/** + * JobQueues can receive Jobs, which are removed from the queue when + * sent to the linked ComputeEnvironment(s) to be executed. + * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked. + */ +export declare class JobQueue extends Resource implements IJobQueue { + /** + * refer to an existing JobQueue by its arn + */ + static fromJobQueueArn(scope: Construct, id: string, jobQueueArn: string): IJobQueue; + readonly computeEnvironments: OrderedComputeEnvironment[]; + readonly priority: number; + readonly enabled?: boolean; + readonly schedulingPolicy?: ISchedulingPolicy; + readonly jobQueueArn: string; + readonly jobQueueName: string; + constructor(scope: Construct, id: string, props?: JobQueueProps); + addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void; +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js new file mode 100644 index 0000000000000..a769e9e07cb5e --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js @@ -0,0 +1,102 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.JobQueue = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +/** + * JobQueues can receive Jobs, which are removed from the queue when + * sent to the linked ComputeEnvironment(s) to be executed. + * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked. + */ +class JobQueue extends core_1.Resource { + /** + * refer to an existing JobQueue by its arn + */ + static fromJobQueueArn(scope, id, jobQueueArn) { + const stack = core_1.Stack.of(scope); + class Import extends core_1.Resource { + constructor() { + super(...arguments); + this.computeEnvironments = []; + this.priority = 1; + this.jobQueueArn = jobQueueArn; + this.jobQueueName = stack.splitArn(jobQueueArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + } + addComputeEnvironment(_computeEnvironment, _order) { + throw new Error(`cannot add ComputeEnvironments to imported JobQueue '${id}'`); + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, { + physicalName: props?.jobQueueName, + }); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_JobQueueProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, JobQueue); + } + throw error; + } + this.computeEnvironments = props?.computeEnvironments ?? []; + this.priority = props?.priority ?? 1; + this.enabled = props?.enabled; + this.schedulingPolicy = props?.schedulingPolicy; + const resource = new aws_batch_1.CfnJobQueue(this, 'Resource', { + computeEnvironmentOrder: core_1.Lazy.any({ + produce: () => this.computeEnvironments.map((ce) => { + return { + computeEnvironment: ce.computeEnvironment.computeEnvironmentArn, + order: ce.order, + }; + }), + }), + priority: this.priority, + jobQueueName: props?.jobQueueName, + state: (this.enabled ?? true) ? 'ENABLED' : 'DISABLED', + schedulingPolicyArn: this.schedulingPolicy?.schedulingPolicyArn, + }); + this.jobQueueArn = this.getResourceArnAttribute(resource.attrJobQueueArn, { + service: 'batch', + resource: 'job-queue', + resourceName: this.physicalName, + }); + this.jobQueueName = core_1.Stack.of(this).splitArn(this.jobQueueArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + this.node.addValidation({ validate: () => validateOrderedComputeEnvironments(this.computeEnvironments) }); + } + addComputeEnvironment(computeEnvironment, order) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_IComputeEnvironment(computeEnvironment); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addComputeEnvironment); + } + throw error; + } + this.computeEnvironments.push({ + computeEnvironment, + order, + }); + } +} +exports.JobQueue = JobQueue; +_a = JSII_RTTI_SYMBOL_1; +JobQueue[_a] = { fqn: "@aws-cdk/aws-batch-alpha.JobQueue", version: "0.0.0" }; +function validateOrderedComputeEnvironments(computeEnvironments) { + const seenOrders = []; + for (const ce of computeEnvironments) { + if (seenOrders.includes(ce.order)) { + return ['assigns the same order to different ComputeEnvironments']; + } + seenOrders.push(ce.order); + } + return seenOrders.length === 0 ? ['This JobQueue does not link any ComputeEnvironments'] : []; +} +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-queue.js","sourceRoot":"","sources":["job-queue.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArnFormat, IResource, Lazy, Resource, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobQueue } from 'aws-cdk-lib/aws-batch';\nimport { IComputeEnvironment } from './compute-environment-base';\nimport { ISchedulingPolicy } from './scheduling-policy';\n\n/**\n * Represents a JobQueue\n */\nexport interface IJobQueue extends IResource {\n  /**\n   * The name of the job queue. It can be up to 128 letters long.\n   * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)\n   *\n   * @attribute\n   */\n  readonly jobQueueName: string\n\n  /**\n   * The ARN of this job queue\n   *\n   * @attribute\n   */\n  readonly jobQueueArn: string;\n\n  /**\n   * The set of compute environments mapped to a job queue and their order relative to each other.\n   * The job scheduler uses this parameter to determine which compute environment runs a specific job.\n   * Compute environments must be in the VALID state before you can associate them with a job queue.\n   * You can associate up to three compute environments with a job queue.\n   * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\n   * EC2 and Fargate compute environments can't be mixed.\n   *\n   * *Note*: All compute environments that are associated with a job queue must share the same architecture.\n   * AWS Batch doesn't support mixing compute environment architecture types in a single job queue.\n   */\n  readonly computeEnvironments: OrderedComputeEnvironment[]\n\n  /**\n   * The priority of the job queue.\n   * Job queues with a higher priority are evaluated first when associated with the same compute environment.\n   * Priority is determined in descending order.\n   * For example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.\n   */\n  readonly priority: number\n\n  /**\n   * If the job queue is enabled, it is able to accept jobs.\n   * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.\n   *\n   * @default true\n   */\n  readonly enabled?: boolean\n\n  /**\n   * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs.\n   *\n   * @default - no scheduling policy\n   */\n  readonly schedulingPolicy?: ISchedulingPolicy\n\n  /**\n   * Add a `ComputeEnvironment` to this Queue.\n   * The Queue will prefer lower-order `ComputeEnvironment`s.\n   */\n  addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void;\n}\n\n/**\n * Props to configure a JobQueue\n */\nexport interface JobQueueProps {\n  /**\n   * The set of compute environments mapped to a job queue and their order relative to each other.\n   * The job scheduler uses this parameter to determine which compute environment runs a specific job.\n   * Compute environments must be in the VALID state before you can associate them with a job queue.\n   * You can associate up to three compute environments with a job queue.\n   * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\n   * EC2 and Fargate compute environments can't be mixed.\n   *\n   * *Note*: All compute environments that are associated with a job queue must share the same architecture.\n   * AWS Batch doesn't support mixing compute environment architecture types in a single job queue.\n   *\n   * @default none\n   */\n  readonly computeEnvironments?: OrderedComputeEnvironment[]\n\n  /**\n   * The priority of the job queue.\n   * Job queues with a higher priority are evaluated first when associated with the same compute environment.\n   * Priority is determined in descending order.\n   * For example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1.\n   *\n   * @default 1\n   */\n  readonly priority?: number\n\n  /**\n   * The name of the job queue. It can be up to 128 letters long.\n   * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)\n   *\n   * @default - no name\n   */\n  readonly jobQueueName?: string\n\n  /**\n   * If the job queue is enabled, it is able to accept jobs.\n   * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.\n   *\n   * @default true\n   */\n  readonly enabled?: boolean\n\n  /**\n   * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs.\n   *\n   * @default - no scheduling policy\n   */\n  readonly schedulingPolicy?: ISchedulingPolicy\n}\n\n/**\n * Assigns an order to a ComputeEnvironment.\n * The JobQueue will prioritize the lowest-order ComputeEnvironment.\n */\nexport interface OrderedComputeEnvironment {\n  /**\n   * The ComputeEnvironment to link to this JobQueue\n   */\n  readonly computeEnvironment: IComputeEnvironment;\n\n  /**\n   * The order associated with `computeEnvironment`\n   */\n  readonly order: number;\n}\n\n/**\n * JobQueues can receive Jobs, which are removed from the queue when\n * sent to the linked ComputeEnvironment(s) to be executed.\n * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked.\n */\nexport class JobQueue extends Resource implements IJobQueue {\n  /**\n   * refer to an existing JobQueue by its arn\n   */\n  public static fromJobQueueArn(scope: Construct, id: string, jobQueueArn: string): IJobQueue {\n    const stack = Stack.of(scope);\n    class Import extends Resource implements IJobQueue {\n      public readonly computeEnvironments = [];\n      public readonly priority = 1;\n      public readonly jobQueueArn = jobQueueArn;\n      public readonly jobQueueName = stack.splitArn(jobQueueArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n      public addComputeEnvironment(_computeEnvironment: IComputeEnvironment, _order: number): void {\n        throw new Error(`cannot add ComputeEnvironments to imported JobQueue '${id}'`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeEnvironments: OrderedComputeEnvironment[]\n  public readonly priority: number\n  public readonly enabled?: boolean\n  public readonly schedulingPolicy?: ISchedulingPolicy\n\n  public readonly jobQueueArn: string;\n  public readonly jobQueueName: string;\n\n  constructor(scope: Construct, id: string, props?: JobQueueProps) {\n    super(scope, id, {\n      physicalName: props?.jobQueueName,\n    });\n\n    this.computeEnvironments = props?.computeEnvironments ?? [];\n    this.priority = props?.priority ?? 1;\n    this.enabled = props?.enabled;\n    this.schedulingPolicy = props?.schedulingPolicy;\n\n    const resource = new CfnJobQueue(this, 'Resource', {\n      computeEnvironmentOrder: Lazy.any({\n        produce: () => this.computeEnvironments.map((ce) => {\n          return {\n            computeEnvironment: ce.computeEnvironment.computeEnvironmentArn,\n            order: ce.order,\n          };\n        }),\n      }),\n      priority: this.priority,\n      jobQueueName: props?.jobQueueName,\n      state: (this.enabled ?? true) ? 'ENABLED' : 'DISABLED',\n      schedulingPolicyArn: this.schedulingPolicy?.schedulingPolicyArn,\n    });\n\n    this.jobQueueArn = this.getResourceArnAttribute(resource.attrJobQueueArn, {\n      service: 'batch',\n      resource: 'job-queue',\n      resourceName: this.physicalName,\n    });\n    this.jobQueueName = Stack.of(this).splitArn(this.jobQueueArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    this.node.addValidation({ validate: () => validateOrderedComputeEnvironments(this.computeEnvironments) });\n  }\n\n  addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void {\n    this.computeEnvironments.push({\n      computeEnvironment,\n      order,\n    });\n  }\n}\n\nfunction validateOrderedComputeEnvironments(computeEnvironments: OrderedComputeEnvironment[]): string[] {\n  const seenOrders: number[] = [];\n\n  for (const ce of computeEnvironments) {\n    if (seenOrders.includes(ce.order)) {\n      return ['assigns the same order to different ComputeEnvironments'];\n    }\n    seenOrders.push(ce.order);\n  }\n\n  return seenOrders.length === 0 ? ['This JobQueue does not link any ComputeEnvironments'] : [];\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts new file mode 100644 index 0000000000000..e9336be95bd7a --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts @@ -0,0 +1,196 @@ +import * as cdk from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; +/** + * The properties for defining Linux-specific options that are applied to the container. + */ +export interface LinuxParametersProps { + /** + * Specifies whether to run an init process inside the container that forwards signals and reaps processes. + * + * @default false + */ + readonly initProcessEnabled?: boolean; + /** + * The value for the size of the /dev/shm volume. + * + * @default No shared memory. + */ + readonly sharedMemorySize?: cdk.Size; + /** + * The total amount of swap memory a container can use. This parameter + * will be translated to the --memory-swap option to docker run. + * + * This parameter is only supported when you are using the EC2 launch type. + * Accepted values are positive integers. + * + * @default No swap. + */ + readonly maxSwap?: cdk.Size; + /** + * This allows you to tune a container's memory swappiness behavior. This parameter + * maps to the --memory-swappiness option to docker run. The swappiness relates + * to the kernel's tendency to swap memory. A value of 0 will cause swapping to + * not happen unless absolutely necessary. A value of 100 will cause pages to + * be swapped very aggressively. + * + * This parameter is only supported when you are using the EC2 launch type. + * Accepted values are whole numbers between 0 and 100. If a value is not + * specified for maxSwap then this parameter is ignored. + * + * @default 60 + */ + readonly swappiness?: number; +} +/** + * Linux-specific options that are applied to the container. + */ +export declare class LinuxParameters extends Construct { + /** + * Whether the init process is enabled + */ + protected readonly initProcessEnabled?: boolean; + /** + * The shared memory size (in MiB). Not valid for Fargate launch type + */ + protected readonly sharedMemorySize?: cdk.Size; + /** + * The max swap memory + */ + protected readonly maxSwap?: cdk.Size; + /** + * The swappiness behavior + */ + protected readonly swappiness?: number; + /** + * Device mounts + */ + protected readonly devices: Device[]; + /** + * TmpFs mounts + */ + protected readonly tmpfs: Tmpfs[]; + /** + * Constructs a new instance of the LinuxParameters class. + */ + constructor(scope: Construct, id: string, props?: LinuxParametersProps); + private validateProps; + /** + * Adds one or more host devices to a container. + */ + addDevices(...device: Device[]): void; + /** + * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container. + * + * Only works with EC2 launch type. + */ + addTmpfs(...tmpfs: Tmpfs[]): void; + /** + * Renders the Linux parameters to the Batch version of this resource, + * which does not have 'capabilities' and requires tmpfs.containerPath to be defined. + */ + renderLinuxParameters(): CfnJobDefinition.LinuxParametersProperty; +} +/** + * A container instance host device. + */ +export interface Device { + /** + * The path inside the container at which to expose the host device. + * + * @default Same path as the host + */ + readonly containerPath?: string; + /** + * The path for the device on the host container instance. + */ + readonly hostPath: string; + /** + * The explicit permissions to provide to the container for the device. + * By default, the container has permissions for read, write, and mknod for the device. + * + * @default Readonly + */ + readonly permissions?: DevicePermission[]; +} +/** + * The details of a tmpfs mount for a container. + */ +export interface Tmpfs { + /** + * The absolute file path where the tmpfs volume is to be mounted. + */ + readonly containerPath: string; + /** + * The size (in MiB) of the tmpfs volume. + */ + readonly size: cdk.Size; + /** + * The list of tmpfs volume mount options. For more information, see + * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html). + * + * @default none + */ + readonly mountOptions?: TmpfsMountOption[]; +} +/** + * Permissions for device access + */ +export declare enum DevicePermission { + /** + * Read + */ + READ = "read", + /** + * Write + */ + WRITE = "write", + /** + * Make a node + */ + MKNOD = "mknod" +} +/** + * The supported options for a tmpfs mount for a container. + */ +export declare enum TmpfsMountOption { + DEFAULTS = "defaults", + RO = "ro", + RW = "rw", + SUID = "suid", + NOSUID = "nosuid", + DEV = "dev", + NODEV = "nodev", + EXEC = "exec", + NOEXEC = "noexec", + SYNC = "sync", + ASYNC = "async", + DIRSYNC = "dirsync", + REMOUNT = "remount", + MAND = "mand", + NOMAND = "nomand", + ATIME = "atime", + NOATIME = "noatime", + DIRATIME = "diratime", + NODIRATIME = "nodiratime", + BIND = "bind", + RBIND = "rbind", + UNBINDABLE = "unbindable", + RUNBINDABLE = "runbindable", + PRIVATE = "private", + RPRIVATE = "rprivate", + SHARED = "shared", + RSHARED = "rshared", + SLAVE = "slave", + RSLAVE = "rslave", + RELATIME = "relatime", + NORELATIME = "norelatime", + STRICTATIME = "strictatime", + NOSTRICTATIME = "nostrictatime", + MODE = "mode", + UID = "uid", + GID = "gid", + NR_INODES = "nr_inodes", + NR_BLOCKS = "nr_blocks", + MPOL = "mpol" +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js new file mode 100644 index 0000000000000..2a00173e4d6da --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js @@ -0,0 +1,175 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.TmpfsMountOption = exports.DevicePermission = exports.LinuxParameters = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const cdk = require("aws-cdk-lib/core"); +const constructs_1 = require("constructs"); +/** + * Linux-specific options that are applied to the container. + */ +class LinuxParameters extends constructs_1.Construct { + /** + * Constructs a new instance of the LinuxParameters class. + */ + constructor(scope, id, props = {}) { + super(scope, id); + /** + * Device mounts + */ + this.devices = new Array(); + /** + * TmpFs mounts + */ + this.tmpfs = new Array(); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_LinuxParametersProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, LinuxParameters); + } + throw error; + } + this.validateProps(props); + this.sharedMemorySize = props.sharedMemorySize; + this.initProcessEnabled = props.initProcessEnabled; + this.maxSwap = props.maxSwap; + this.swappiness = props.maxSwap ? props.swappiness : undefined; + } + validateProps(props) { + if (!cdk.Token.isUnresolved(props.swappiness) && + props.swappiness !== undefined && + (!Number.isInteger(props.swappiness) || props.swappiness < 0 || props.swappiness > 100)) { + throw new Error(`swappiness: Must be an integer between 0 and 100; received ${props.swappiness}.`); + } + } + /** + * Adds one or more host devices to a container. + */ + addDevices(...device) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Device(device); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addDevices); + } + throw error; + } + this.devices.push(...device); + } + /** + * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container. + * + * Only works with EC2 launch type. + */ + addTmpfs(...tmpfs) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Tmpfs(tmpfs); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addTmpfs); + } + throw error; + } + this.tmpfs.push(...tmpfs); + } + /** + * Renders the Linux parameters to the Batch version of this resource, + * which does not have 'capabilities' and requires tmpfs.containerPath to be defined. + */ + renderLinuxParameters() { + return { + initProcessEnabled: this.initProcessEnabled, + sharedMemorySize: this.sharedMemorySize?.toMebibytes(), + maxSwap: this.maxSwap?.toMebibytes(), + swappiness: this.swappiness, + devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }), + tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }), + }; + } +} +exports.LinuxParameters = LinuxParameters; +_a = JSII_RTTI_SYMBOL_1; +LinuxParameters[_a] = { fqn: "@aws-cdk/aws-batch-alpha.LinuxParameters", version: "0.0.0" }; +/** + * Permissions for device access + */ +var DevicePermission; +(function (DevicePermission) { + /** + * Read + */ + DevicePermission["READ"] = "read"; + /** + * Write + */ + DevicePermission["WRITE"] = "write"; + /** + * Make a node + */ + DevicePermission["MKNOD"] = "mknod"; +})(DevicePermission || (exports.DevicePermission = DevicePermission = {})); +/** + * The supported options for a tmpfs mount for a container. + */ +var TmpfsMountOption; +(function (TmpfsMountOption) { + TmpfsMountOption["DEFAULTS"] = "defaults"; + TmpfsMountOption["RO"] = "ro"; + TmpfsMountOption["RW"] = "rw"; + TmpfsMountOption["SUID"] = "suid"; + TmpfsMountOption["NOSUID"] = "nosuid"; + TmpfsMountOption["DEV"] = "dev"; + TmpfsMountOption["NODEV"] = "nodev"; + TmpfsMountOption["EXEC"] = "exec"; + TmpfsMountOption["NOEXEC"] = "noexec"; + TmpfsMountOption["SYNC"] = "sync"; + TmpfsMountOption["ASYNC"] = "async"; + TmpfsMountOption["DIRSYNC"] = "dirsync"; + TmpfsMountOption["REMOUNT"] = "remount"; + TmpfsMountOption["MAND"] = "mand"; + TmpfsMountOption["NOMAND"] = "nomand"; + TmpfsMountOption["ATIME"] = "atime"; + TmpfsMountOption["NOATIME"] = "noatime"; + TmpfsMountOption["DIRATIME"] = "diratime"; + TmpfsMountOption["NODIRATIME"] = "nodiratime"; + TmpfsMountOption["BIND"] = "bind"; + TmpfsMountOption["RBIND"] = "rbind"; + TmpfsMountOption["UNBINDABLE"] = "unbindable"; + TmpfsMountOption["RUNBINDABLE"] = "runbindable"; + TmpfsMountOption["PRIVATE"] = "private"; + TmpfsMountOption["RPRIVATE"] = "rprivate"; + TmpfsMountOption["SHARED"] = "shared"; + TmpfsMountOption["RSHARED"] = "rshared"; + TmpfsMountOption["SLAVE"] = "slave"; + TmpfsMountOption["RSLAVE"] = "rslave"; + TmpfsMountOption["RELATIME"] = "relatime"; + TmpfsMountOption["NORELATIME"] = "norelatime"; + TmpfsMountOption["STRICTATIME"] = "strictatime"; + TmpfsMountOption["NOSTRICTATIME"] = "nostrictatime"; + TmpfsMountOption["MODE"] = "mode"; + TmpfsMountOption["UID"] = "uid"; + TmpfsMountOption["GID"] = "gid"; + TmpfsMountOption["NR_INODES"] = "nr_inodes"; + TmpfsMountOption["NR_BLOCKS"] = "nr_blocks"; + TmpfsMountOption["MPOL"] = "mpol"; +})(TmpfsMountOption || (exports.TmpfsMountOption = TmpfsMountOption = {})); +function renderTmpfs(tmpfs) { + return { + containerPath: tmpfs.containerPath, + size: tmpfs.size.toMebibytes(), + mountOptions: tmpfs.mountOptions, + }; +} +function renderDevice(device) { + return { + containerPath: device.containerPath, + hostPath: device.hostPath, + permissions: device.permissions, + }; +} +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-parameters.js","sourceRoot":"","sources":["linux-parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\n\n/**\n * The properties for defining Linux-specific options that are applied to the container.\n */\nexport interface LinuxParametersProps {\n  /**\n   * Specifies whether to run an init process inside the container that forwards signals and reaps processes.\n   *\n   * @default false\n   */\n  readonly initProcessEnabled?: boolean;\n\n  /**\n   * The value for the size of the /dev/shm volume.\n   *\n   * @default No shared memory.\n   */\n  readonly sharedMemorySize?: cdk.Size;\n\n  /**\n   * The total amount of swap memory a container can use. This parameter\n   * will be translated to the --memory-swap option to docker run.\n   *\n   * This parameter is only supported when you are using the EC2 launch type.\n   * Accepted values are positive integers.\n   *\n   * @default No swap.\n   */\n  readonly maxSwap?: cdk.Size;\n\n  /**\n    * This allows you to tune a container's memory swappiness behavior. This parameter\n    * maps to the --memory-swappiness option to docker run. The swappiness relates\n    * to the kernel's tendency to swap memory. A value of 0 will cause swapping to\n    * not happen unless absolutely necessary. A value of 100 will cause pages to\n    * be swapped very aggressively.\n    *\n    * This parameter is only supported when you are using the EC2 launch type.\n    * Accepted values are whole numbers between 0 and 100. If a value is not\n    * specified for maxSwap then this parameter is ignored.\n    *\n    * @default 60\n    */\n  readonly swappiness?: number;\n}\n\n/**\n * Linux-specific options that are applied to the container.\n */\nexport class LinuxParameters extends Construct {\n  /**\n   * Whether the init process is enabled\n   */\n  protected readonly initProcessEnabled?: boolean;\n\n  /**\n   * The shared memory size (in MiB). Not valid for Fargate launch type\n   */\n  protected readonly sharedMemorySize?: cdk.Size;\n\n  /**\n   * The max swap memory\n   */\n  protected readonly maxSwap?: cdk.Size;\n\n  /**\n   * The swappiness behavior\n   */\n  protected readonly swappiness?: number;\n\n  /**\n   * Device mounts\n   */\n  protected readonly devices = new Array<Device>();\n\n  /**\n   * TmpFs mounts\n   */\n  protected readonly tmpfs = new Array<Tmpfs>();\n\n  /**\n   * Constructs a new instance of the LinuxParameters class.\n   */\n  constructor(scope: Construct, id: string, props: LinuxParametersProps = {}) {\n    super(scope, id);\n\n    this.validateProps(props);\n\n    this.sharedMemorySize = props.sharedMemorySize;\n    this.initProcessEnabled = props.initProcessEnabled;\n    this.maxSwap = props.maxSwap;\n    this.swappiness = props.maxSwap ? props.swappiness : undefined;\n  }\n\n  private validateProps(props: LinuxParametersProps) {\n    if (\n      !cdk.Token.isUnresolved(props.swappiness) &&\n      props.swappiness !== undefined &&\n      (!Number.isInteger(props.swappiness) || props.swappiness < 0 || props.swappiness > 100)\n    ) {\n      throw new Error(`swappiness: Must be an integer between 0 and 100; received ${props.swappiness}.`);\n    }\n  }\n\n  /**\n   * Adds one or more host devices to a container.\n   */\n  public addDevices(...device: Device[]) {\n    this.devices.push(...device);\n  }\n\n  /**\n   * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addTmpfs(...tmpfs: Tmpfs[]) {\n    this.tmpfs.push(...tmpfs);\n  }\n\n  /**\n   * Renders the Linux parameters to the Batch version of this resource,\n   * which does not have 'capabilities' and requires tmpfs.containerPath to be defined.\n   */\n  public renderLinuxParameters(): CfnJobDefinition.LinuxParametersProperty {\n    return {\n      initProcessEnabled: this.initProcessEnabled,\n      sharedMemorySize: this.sharedMemorySize?.toMebibytes(),\n      maxSwap: this.maxSwap?.toMebibytes(),\n      swappiness: this.swappiness,\n      devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),\n      tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }),\n    };\n  }\n}\n\n/**\n * A container instance host device.\n */\nexport interface Device {\n  /**\n   * The path inside the container at which to expose the host device.\n   *\n   * @default Same path as the host\n   */\n  readonly containerPath?: string,\n\n  /**\n   * The path for the device on the host container instance.\n   */\n  readonly hostPath: string,\n\n  /**\n   * The explicit permissions to provide to the container for the device.\n   * By default, the container has permissions for read, write, and mknod for the device.\n   *\n   * @default Readonly\n   */\n  readonly permissions?: DevicePermission[]\n}\n\n/**\n * The details of a tmpfs mount for a container.\n */\nexport interface Tmpfs {\n  /**\n   * The absolute file path where the tmpfs volume is to be mounted.\n   */\n  readonly containerPath: string,\n\n  /**\n   * The size (in MiB) of the tmpfs volume.\n   */\n  readonly size: cdk.Size,\n\n  /**\n   * The list of tmpfs volume mount options. For more information, see\n   * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).\n   *\n   * @default none\n   */\n  readonly mountOptions?: TmpfsMountOption[],\n}\n\n/**\n * Permissions for device access\n */\nexport enum DevicePermission {\n  /**\n   * Read\n   */\n  READ = 'read',\n\n  /**\n   * Write\n   */\n  WRITE = 'write',\n\n  /**\n   * Make a node\n   */\n  MKNOD = 'mknod',\n}\n\n/**\n * The supported options for a tmpfs mount for a container.\n */\nexport enum TmpfsMountOption {\n  DEFAULTS = 'defaults',\n  RO = 'ro',\n  RW = 'rw',\n  SUID = 'suid',\n  NOSUID = 'nosuid',\n  DEV = 'dev',\n  NODEV = 'nodev',\n  EXEC = 'exec',\n  NOEXEC = 'noexec',\n  SYNC = 'sync',\n  ASYNC = 'async',\n  DIRSYNC = 'dirsync',\n  REMOUNT = 'remount',\n  MAND = 'mand',\n  NOMAND = 'nomand',\n  ATIME = 'atime',\n  NOATIME = 'noatime',\n  DIRATIME = 'diratime',\n  NODIRATIME = 'nodiratime',\n  BIND = 'bind',\n  RBIND = 'rbind',\n  UNBINDABLE = 'unbindable',\n  RUNBINDABLE = 'runbindable',\n  PRIVATE = 'private',\n  RPRIVATE = 'rprivate',\n  SHARED = 'shared',\n  RSHARED = 'rshared',\n  SLAVE = 'slave',\n  RSLAVE = 'rslave',\n  RELATIME = 'relatime',\n  NORELATIME = 'norelatime',\n  STRICTATIME = 'strictatime',\n  NOSTRICTATIME = 'nostrictatime',\n  MODE = 'mode',\n  UID = 'uid',\n  GID = 'gid',\n  NR_INODES = 'nr_inodes',\n  NR_BLOCKS = 'nr_blocks',\n  MPOL = 'mpol'\n}\n\nfunction renderTmpfs(tmpfs: Tmpfs): CfnJobDefinition.TmpfsProperty {\n  return {\n    containerPath: tmpfs.containerPath,\n    size: tmpfs.size.toMebibytes(),\n    mountOptions: tmpfs.mountOptions,\n  };\n}\n\nfunction renderDevice(device: Device): CfnJobDefinition.DeviceProperty {\n  return {\n    containerPath: device.containerPath,\n    hostPath: device.hostPath,\n    permissions: device.permissions,\n  };\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts new file mode 100644 index 0000000000000..6578bdcb3fd27 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts @@ -0,0 +1,806 @@ +import * as ec2 from 'aws-cdk-lib/aws-ec2'; +import * as eks from 'aws-cdk-lib/aws-eks'; +import * as iam from 'aws-cdk-lib/aws-iam'; +import { Duration, ITaggable, TagManager } from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +import { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base'; +/** + * Represents a Managed ComputeEnvironment. Batch will provision EC2 Instances to + * meet the requirements of the jobs executing in this ComputeEnvironment. + */ +export interface IManagedComputeEnvironment extends IComputeEnvironment, ec2.IConnectable, ITaggable { + /** + * The maximum vCpus this `ManagedComputeEnvironment` can scale up to. + * + * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or + * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances, + * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes` + * or `instanceClasses`. + */ + readonly maxvCpus: number; + /** + * Specifies whether this Compute Environment is replaced if an update is made that requires + * replacing its instances. To enable more properties to be updated, + * set this property to `false`. When changing the value of this property to false, + * do not change any other properties at the same time. + * If other properties are changed at the same time, + * and the change needs to be rolled back but it can't, + * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state. + * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state. + * However, if you can continue to roll it back, + * you can return the stack to its original settings and then try to update it again. + * + * The properties which require a replacement of the Compute Environment are: + * + * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment + * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html + */ + readonly replaceComputeEnvironment?: boolean; + /** + * Whether or not to use spot instances. + * Spot instances are less expensive EC2 instances that can be + * reclaimed by EC2 at any time; your job will be given two minutes + * of notice before reclamation. + * + * @default false + */ + readonly spot?: boolean; + /** + * Only meaningful if `terminateOnUpdate` is `false`. If so, + * when an infrastructure update is triggered, any running jobs + * will be allowed to run until `updateTimeout` has expired. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html + * @default 30 minutes + */ + readonly updateTimeout?: Duration; + /** + * Whether or not any running jobs will be immediately terminated when an infrastructure update + * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's + * retry policy. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html + * + * @default false + */ + readonly terminateOnUpdate?: boolean; + /** + * The security groups this Compute Environment will launch instances in. + */ + readonly securityGroups: ec2.ISecurityGroup[]; + /** + * The VPC Subnets this Compute Environment will launch instances in. + */ + readonly vpcSubnets?: ec2.SubnetSelection; + /** + * Whether or not the AMI is updated to the latest one supported by Batch + * when an infrastructure update occurs. + * + * If you specify a specific AMI, this property will be ignored. + * + * @default true + */ + readonly updateToLatestImageVersion?: boolean; +} +/** + * Props for a ManagedComputeEnvironment + */ +export interface ManagedComputeEnvironmentProps extends ComputeEnvironmentProps { + /** + * The maximum vCpus this `ManagedComputeEnvironment` can scale up to. + * Each vCPU is equivalent to 1024 CPU shares. + * + * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or + * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances, + * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes` + * or `instanceClasses`. + * + * @default 256 + */ + readonly maxvCpus?: number; + /** + * Specifies whether this Compute Environment is replaced if an update is made that requires + * replacing its instances. To enable more properties to be updated, + * set this property to `false`. When changing the value of this property to false, + * do not change any other properties at the same time. + * If other properties are changed at the same time, + * and the change needs to be rolled back but it can't, + * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state. + * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state. + * However, if you can continue to roll it back, + * you can return the stack to its original settings and then try to update it again. + * + * The properties which require a replacement of the Compute Environment are: + * + * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment + * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html + * + * @default false + */ + readonly replaceComputeEnvironment?: boolean; + /** + * Whether or not to use spot instances. + * Spot instances are less expensive EC2 instances that can be + * reclaimed by EC2 at any time; your job will be given two minutes + * of notice before reclamation. + * + * @default false + */ + readonly spot?: boolean; + /** + * Only meaningful if `terminateOnUpdate` is `false`. If so, + * when an infrastructure update is triggered, any running jobs + * will be allowed to run until `updateTimeout` has expired. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html + * + * @default 30 minutes + */ + readonly updateTimeout?: Duration; + /** + * Whether or not any running jobs will be immediately terminated when an infrastructure update + * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's + * retry policy. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html + * + * @default false + */ + readonly terminateOnUpdate?: boolean; + /** + * VPC in which this Compute Environment will launch Instances + */ + readonly vpc: ec2.IVpc; + /** + * The security groups this Compute Environment will launch instances in. + * + * @default new security groups will be created + */ + readonly securityGroups?: ec2.ISecurityGroup[]; + /** + * The VPC Subnets this Compute Environment will launch instances in. + * + * @default new subnets will be created + */ + readonly vpcSubnets?: ec2.SubnetSelection; + /** + * Whether or not the AMI is updated to the latest one supported by Batch + * when an infrastructure update occurs. + * + * If you specify a specific AMI, this property will be ignored. + * + * @default true + */ + readonly updateToLatestImageVersion?: boolean; +} +/** + * Abstract base class for ManagedComputeEnvironments + * @internal + */ +export declare abstract class ManagedComputeEnvironmentBase extends ComputeEnvironmentBase implements IManagedComputeEnvironment { + readonly maxvCpus: number; + readonly replaceComputeEnvironment?: boolean; + readonly spot?: boolean; + readonly updateTimeout?: Duration; + readonly terminateOnUpdate?: boolean; + readonly securityGroups: ec2.ISecurityGroup[]; + readonly updateToLatestImageVersion?: boolean; + readonly tags: TagManager; + readonly connections: ec2.Connections; + constructor(scope: Construct, id: string, props: ManagedComputeEnvironmentProps); +} +/** + * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. + */ +export interface IManagedEc2EcsComputeEnvironment extends IManagedComputeEnvironment { + /** + * Configure which AMIs this Compute Environment can launch. + * + * Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches. + * + * @default + * - ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances + */ + readonly images?: EcsMachineImage[]; + /** + * The allocation strategy to use if not enough instances of + * the best fitting instance type can be allocated. + * + * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, + * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. + */ + readonly allocationStrategy?: AllocationStrategy; + /** + * The maximum percentage that a Spot Instance price can be when compared with the + * On-Demand price for that instance type before instances are launched. + * For example, if your maximum percentage is 20%, the Spot price must be + * less than 20% of the current On-Demand price for that Instance. + * You always pay the lowest market price and never more than your maximum percentage. + * For most use cases, Batch recommends leaving this field empty. + * + * @default - 100% + */ + readonly spotBidPercentage?: number; + /** + * The service-linked role that Spot Fleet needs to launch instances on your behalf. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html + * + * @default - a new Role will be created + */ + readonly spotFleetRole?: iam.IRole; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + */ + readonly instanceTypes: ec2.InstanceType[]; + /** + * The instance classes that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + * Batch will automatically choose the size. + */ + readonly instanceClasses: ec2.InstanceClass[]; + /** + * Whether or not to use batch's optimal instance type. + * The optimal instance type is equivalent to adding the + * C4, M4, and R4 instance classes. You can specify other instance classes + * (of the same architecture) in addition to the optimal instance classes. + * + * @default true + */ + readonly useOptimalInstanceClasses?: boolean; + /** + * The execution Role that instances launched by this Compute Environment will use. + * + * @default - a role will be created + */ + readonly instanceRole?: iam.IRole; + /** + * The Launch Template that this Compute Environment + * will use to provision EC2 Instances. + * + * *Note*: if `securityGroups` is specified on both your + * launch template and this Compute Environment, **the + * `securityGroup`s on the Compute Environment override the + * ones on the launch template. + * + * @default no launch template + */ + readonly launchTemplate?: ec2.ILaunchTemplate; + /** + * The minimum vCPUs that an environment should maintain, + * even if the compute environment is DISABLED. + * + * @default 0 + */ + readonly minvCpus?: number; + /** + * The EC2 placement group to associate with your compute resources. + * If you intend to submit multi-node parallel jobs to this Compute Environment, + * you should consider creating a cluster placement group and associate it with your compute resources. + * This keeps your multi-node parallel job on a logical grouping of instances + * within a single Availability Zone with high network flow potential. + * + * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html + * + * @default - no placement group + */ + readonly placementGroup?: ec2.IPlacementGroup; + /** + * Add an instance type to this compute environment + */ + addInstanceType(instanceType: ec2.InstanceType): void; + /** + * Add an instance class to this compute environment + */ + addInstanceClass(instanceClass: ec2.InstanceClass): void; +} +/** + * Base interface for containing all information needed to + * configure a MachineImage in Batch + */ +interface MachineImage { + /** + * The machine image to use + * + * @default - chosen by batch + */ + readonly image?: ec2.IMachineImage; +} +/** + * A Batch MachineImage that is compatible with ECS + */ +export interface EcsMachineImage extends MachineImage { + /** + * Tells Batch which instance type to launch this image on + * + * @default - 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances + */ + readonly imageType?: EcsMachineImageType; +} +/** + * A Batch MachineImage that is compatible with EKS + */ +export interface EksMachineImage extends MachineImage { + /** + * Tells Batch which instance type to launch this image on + * + * @default - 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances + */ + readonly imageType?: EksMachineImageType; +} +/** + * Maps the image to instance types + */ +export declare enum EcsMachineImageType { + /** + * Tells Batch that this machine image runs on non-GPU instances + */ + ECS_AL2 = "ECS_AL2", + /** + * Tells Batch that this machine image runs on GPU instances + */ + ECS_AL2_NVIDIA = "ECS_AL2_NVIDIA" +} +/** + * Maps the image to instance types + */ +export declare enum EksMachineImageType { + /** + * Tells Batch that this machine image runs on non-GPU instances + */ + EKS_AL2 = "EKS_AL2", + /** + * Tells Batch that this machine image runs on GPU instances + */ + EKS_AL2_NVIDIA = "EKS_AL2_NVIDIA" +} +/** + * Determines how this compute environment chooses instances to spawn + * + * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/ + */ +export declare enum AllocationStrategy { + /** + * Batch chooses the lowest-cost instance type that fits all the jobs in the queue. + * If instances of that type are not available, the queue will not choose a new type; + * instead, it will wait for the instance to become available. + * This can stall your `Queue`, with your compute environment only using part of its max capacity + * (or none at all) until the `BEST_FIT` instance becomes available. + * This allocation strategy keeps costs lower but can limit scaling. + * `BEST_FIT` isn't supported when updating compute environments + */ + BEST_FIT = "BEST_FIT", + /** + * This is the default Allocation Strategy if `spot` is `false` or unspecified. + * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements + * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`. + * However, if not all of the capacity can be filled with this instance type, + * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity. + * To make the most use of this allocation strategy, + * it is recommended to use as many instance classes as is feasible for your workload. + */ + BEST_FIT_PROGRESSIVE = "BEST_FIT_PROGRESSIVE", + /** + * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` + * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled). + * This will tell Batch to choose the instance types from the ones you’ve specified that have + * the most spot capacity available to minimize the chance of interruption. + * To get the most benefit from your spot instances, + * you should allow Batch to choose from as many different instance types as possible. + */ + SPOT_CAPACITY_OPTIMIZED = "SPOT_CAPACITY_OPTIMIZED", + /** + * The price and capacity optimized allocation strategy looks at both price and capacity + * to select the Spot Instance pools that are the least likely to be interrupted + * and have the lowest possible price. + * + * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances. + */ + SPOT_PRICE_CAPACITY_OPTIMIZED = "SPOT_PRICE_CAPACITY_OPTIMIZED" +} +/** + * Props for a ManagedEc2EcsComputeEnvironment + */ +export interface ManagedEc2EcsComputeEnvironmentProps extends ManagedComputeEnvironmentProps { + /** + * Whether or not to use batch's optimal instance type. + * The optimal instance type is equivalent to adding the + * C4, M4, and R4 instance classes. You can specify other instance classes + * (of the same architecture) in addition to the optimal instance classes. + * + * @default true + */ + readonly useOptimalInstanceClasses?: boolean; + /** + * Configure which AMIs this Compute Environment can launch. + * If you specify this property with only `image` specified, then the + * `imageType` will default to `ECS_AL2`. *If your image needs GPU resources, + * specify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly + * join the ComputeEnvironment*. + * + * @default + * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances + */ + readonly images?: EcsMachineImage[]; + /** + * The allocation strategy to use if not enough instances of + * the best fitting instance type can be allocated. + * + * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, + * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. + */ + readonly allocationStrategy?: AllocationStrategy; + /** + * The maximum percentage that a Spot Instance price can be when compared with the + * On-Demand price for that instance type before instances are launched. + * For example, if your maximum percentage is 20%, the Spot price must be + * less than 20% of the current On-Demand price for that Instance. + * You always pay the lowest market price and never more than your maximum percentage. + * For most use cases, Batch recommends leaving this field empty. + * + * Implies `spot == true` if set + * + * @default 100% + */ + readonly spotBidPercentage?: number; + /** + * The service-linked role that Spot Fleet needs to launch instances on your behalf. + * + * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html + * + * @default - a new role will be created + */ + readonly spotFleetRole?: iam.IRole; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + * + * @default - the instances Batch considers will be used (currently C4, M4, and R4) + */ + readonly instanceTypes?: ec2.InstanceType[]; + /** + * The instance classes that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + * Batch will automatically choose the instance size. + * + * @default - the instances Batch considers will be used (currently C4, M4, and R4) + */ + readonly instanceClasses?: ec2.InstanceClass[]; + /** + * The execution Role that instances launched by this Compute Environment will use. + * + * @default - a role will be created + */ + readonly instanceRole?: iam.IRole; + /** + * The Launch Template that this Compute Environment + * will use to provision EC2 Instances. + * + * *Note*: if `securityGroups` is specified on both your + * launch template and this Compute Environment, **the + * `securityGroup`s on the Compute Environment override the + * ones on the launch template. + * + * @default no launch template + */ + readonly launchTemplate?: ec2.ILaunchTemplate; + /** + * The minimum vCPUs that an environment should maintain, + * even if the compute environment is DISABLED. + * + * @default 0 + */ + readonly minvCpus?: number; + /** + * The EC2 placement group to associate with your compute resources. + * If you intend to submit multi-node parallel jobs to this Compute Environment, + * you should consider creating a cluster placement group and associate it with your compute resources. + * This keeps your multi-node parallel job on a logical grouping of instances + * within a single Availability Zone with high network flow potential. + * + * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html + * + * @default - no placement group + */ + readonly placementGroup?: ec2.IPlacementGroup; +} +/** + * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +export declare class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EcsComputeEnvironment { + /** + * refer to an existing ComputeEnvironment by its arn. + */ + static fromManagedEc2EcsComputeEnvironmentArn(scope: Construct, id: string, managedEc2EcsComputeEnvironmentArn: string): IManagedEc2EcsComputeEnvironment; + readonly computeEnvironmentArn: string; + readonly computeEnvironmentName: string; + readonly images?: EcsMachineImage[]; + readonly allocationStrategy?: AllocationStrategy; + readonly spotBidPercentage?: number; + readonly spotFleetRole?: iam.IRole; + readonly instanceTypes: ec2.InstanceType[]; + readonly instanceClasses: ec2.InstanceClass[]; + readonly instanceRole?: iam.IRole; + readonly launchTemplate?: ec2.ILaunchTemplate; + readonly minvCpus?: number; + readonly placementGroup?: ec2.IPlacementGroup; + private readonly instanceProfile; + constructor(scope: Construct, id: string, props: ManagedEc2EcsComputeEnvironmentProps); + addInstanceType(instanceType: ec2.InstanceType): void; + addInstanceClass(instanceClass: ec2.InstanceClass): void; +} +/** + * A ManagedComputeEnvironment that uses EKS orchestration on EC2 instances. + */ +interface IManagedEc2EksComputeEnvironment extends IManagedComputeEnvironment { + /** + * The namespace of the Cluster + * + * Cannot be 'default', start with 'kube-', or be longer than 64 characters. + * + * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ + */ + readonly kubernetesNamespace?: string; + /** + * The cluster that backs this Compute Environment. Required + * for Compute Environments running Kubernetes jobs. + * + * Please ensure that you have followed the steps at + * + * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html + * + * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster. + * If you do not follow the steps in the link, the deployment fail with a message that the + * compute environment did not stabilize. + */ + readonly eksCluster: eks.ICluster; + /** + * Configure which AMIs this Compute Environment can launch. + * + * @default + * EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances, + */ + readonly images?: EksMachineImage[]; + /** + * The allocation strategy to use if not enough instances of + * the best fitting instance type can be allocated. + * + * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, + * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. + */ + readonly allocationStrategy?: AllocationStrategy; + /** + * The maximum percentage that a Spot Instance price can be when compared with the + * On-Demand price for that instance type before instances are launched. + * For example, if your maximum percentage is 20%, the Spot price must be + * less than 20% of the current On-Demand price for that Instance. + * You always pay the lowest market price and never more than your maximum percentage. + * For most use cases, Batch recommends leaving this field empty. + * + * Implies `spot == true` if set + * + * @default - 100% + */ + readonly spotBidPercentage?: number; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + */ + readonly instanceTypes: ec2.InstanceType[]; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + */ + readonly instanceClasses: ec2.InstanceClass[]; + /** + * The execution Role that instances launched by this Compute Environment will use. + * + * @default - a role will be created + */ + readonly instanceRole?: iam.IRole; + /** + * The Launch Template that this Compute Environment + * will use to provision EC2 Instances. + * + * *Note*: if `securityGroups` is specified on both your + * launch template and this Compute Environment, **the + * `securityGroup`s on the Compute Environment override the + * ones on the launch template. + * + * @default - no launch template + */ + readonly launchTemplate?: ec2.ILaunchTemplate; + /** + * The minimum vCPUs that an environment should maintain, + * even if the compute environment is DISABLED. + * + * @default 0 + */ + readonly minvCpus?: number; + /** + * The EC2 placement group to associate with your compute resources. + * If you intend to submit multi-node parallel jobs to this Compute Environment, + * you should consider creating a cluster placement group and associate it with your compute resources. + * This keeps your multi-node parallel job on a logical grouping of instances + * within a single Availability Zone with high network flow potential. + * + * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html + * + * @default - no placement group + */ + readonly placementGroup?: ec2.IPlacementGroup; + /** + * Add an instance type to this compute environment + */ + addInstanceType(instanceType: ec2.InstanceType): void; + /** + * Add an instance class to this compute environment + */ + addInstanceClass(instanceClass: ec2.InstanceClass): void; +} +/** + * Props for a ManagedEc2EksComputeEnvironment + */ +export interface ManagedEc2EksComputeEnvironmentProps extends ManagedComputeEnvironmentProps { + /** + * The namespace of the Cluster + */ + readonly kubernetesNamespace: string; + /** + * The cluster that backs this Compute Environment. Required + * for Compute Environments running Kubernetes jobs. + * + * Please ensure that you have followed the steps at + * + * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html + * + * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster. + * If you do not follow the steps in the link, the deployment fail with a message that the + * compute environment did not stabilize. + */ + readonly eksCluster: eks.ICluster; + /** + * Whether or not to use batch's optimal instance type. + * The optimal instance type is equivalent to adding the + * C4, M4, and R4 instance classes. You can specify other instance classes + * (of the same architecture) in addition to the optimal instance classes. + * + * @default true + */ + readonly useOptimalInstanceClasses?: boolean; + /** + * Configure which AMIs this Compute Environment can launch. + * + * @default + * If `imageKubernetesVersion` is specified, + * - EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances, + * Otherwise, + * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances, + */ + readonly images?: EksMachineImage[]; + /** + * The allocation strategy to use if not enough instances of + * the best fitting instance type can be allocated. + * + * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, + * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. + */ + readonly allocationStrategy?: AllocationStrategy; + /** + * The maximum percentage that a Spot Instance price can be when compared with the + * On-Demand price for that instance type before instances are launched. + * For example, if your maximum percentage is 20%, the Spot price must be + * less than 20% of the current On-Demand price for that Instance. + * You always pay the lowest market price and never more than your maximum percentage. + * For most use cases, Batch recommends leaving this field empty. + * + * Implies `spot == true` if set + * + * @default - 100% + */ + readonly spotBidPercentage?: number; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + * + * @default - the instances Batch considers will be used (currently C4, M4, and R4) + */ + readonly instanceTypes?: ec2.InstanceType[]; + /** + * The instance types that this Compute Environment can launch. + * Which one is chosen depends on the `AllocationStrategy` used. + * Batch will automatically choose the instance size. + * + * @default - the instances Batch considers will be used (currently C4, M4, and R4) + */ + readonly instanceClasses?: ec2.InstanceClass[]; + /** + * The execution Role that instances launched by this Compute Environment will use. + * + * @default - a role will be created + */ + readonly instanceRole?: iam.IRole; + /** + * The Launch Template that this Compute Environment + * will use to provision EC2 Instances. + * + * *Note*: if `securityGroups` is specified on both your + * launch template and this Compute Environment, **the + * `securityGroup`s on the Compute Environment override the + * ones on the launch template.** + * + * @default - no launch template + */ + readonly launchTemplate?: ec2.ILaunchTemplate; + /** + * The minimum vCPUs that an environment should maintain, + * even if the compute environment is DISABLED. + * + * @default 0 + */ + readonly minvCpus?: number; + /** + * The EC2 placement group to associate with your compute resources. + * If you intend to submit multi-node parallel jobs to this Compute Environment, + * you should consider creating a cluster placement group and associate it with your compute resources. + * This keeps your multi-node parallel job on a logical grouping of instances + * within a single Availability Zone with high network flow potential. + * + * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html + * + * @default - no placement group + */ + readonly placementGroup?: ec2.IPlacementGroup; +} +/** + * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +export declare class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EksComputeEnvironment { + readonly kubernetesNamespace?: string; + readonly eksCluster: eks.ICluster; + readonly computeEnvironmentName: string; + readonly computeEnvironmentArn: string; + readonly images?: EksMachineImage[]; + readonly allocationStrategy?: AllocationStrategy; + readonly spotBidPercentage?: number; + readonly instanceTypes: ec2.InstanceType[]; + readonly instanceClasses: ec2.InstanceClass[]; + readonly instanceRole?: iam.IRole; + readonly launchTemplate?: ec2.ILaunchTemplate; + readonly minvCpus?: number; + readonly placementGroup?: ec2.IPlacementGroup; + private readonly instanceProfile; + constructor(scope: Construct, id: string, props: ManagedEc2EksComputeEnvironmentProps); + addInstanceType(instanceType: ec2.InstanceType): void; + addInstanceClass(instanceClass: ec2.InstanceClass): void; +} +/** + * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. + */ +export interface IFargateComputeEnvironment extends IManagedComputeEnvironment { +} +/** + * Props for a FargateComputeEnvironment + */ +export interface FargateComputeEnvironmentProps extends ManagedComputeEnvironmentProps { +} +/** + * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +export declare class FargateComputeEnvironment extends ManagedComputeEnvironmentBase implements IFargateComputeEnvironment { + /** + * Reference an existing FargateComputeEnvironment by its arn + */ + static fromFargateComputeEnvironmentArn(scope: Construct, id: string, fargateComputeEnvironmentArn: string): IFargateComputeEnvironment; + readonly computeEnvironmentName: string; + readonly computeEnvironmentArn: string; + constructor(scope: Construct, id: string, props: FargateComputeEnvironmentProps); +} +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js new file mode 100644 index 0000000000000..378fcc005e21b --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js @@ -0,0 +1,451 @@ +"use strict"; +var _a, _b, _c; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.FargateComputeEnvironment = exports.ManagedEc2EksComputeEnvironment = exports.ManagedEc2EcsComputeEnvironment = exports.AllocationStrategy = exports.EksMachineImageType = exports.EcsMachineImageType = exports.ManagedComputeEnvironmentBase = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const iam = require("aws-cdk-lib/aws-iam"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +const compute_environment_base_1 = require("./compute-environment-base"); +/** + * Abstract base class for ManagedComputeEnvironments + * @internal + */ +class ManagedComputeEnvironmentBase extends compute_environment_base_1.ComputeEnvironmentBase { + constructor(scope, id, props) { + super(scope, id, props); + this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); + this.maxvCpus = props.maxvCpus ?? DEFAULT_MAX_VCPUS; + this.replaceComputeEnvironment = props.replaceComputeEnvironment ?? false; + this.spot = props.spot; + this.updateTimeout = props.updateTimeout; + this.terminateOnUpdate = props.terminateOnUpdate; + this.updateToLatestImageVersion = props.updateToLatestImageVersion ?? true; + this.securityGroups = props.securityGroups ?? [ + new ec2.SecurityGroup(this, 'SecurityGroup', { + vpc: props.vpc, + }), + ]; + this.connections = new ec2.Connections({ + securityGroups: this.securityGroups, + }); + } +} +exports.ManagedComputeEnvironmentBase = ManagedComputeEnvironmentBase; +/** + * Maps the image to instance types + */ +var EcsMachineImageType; +(function (EcsMachineImageType) { + /** + * Tells Batch that this machine image runs on non-GPU instances + */ + EcsMachineImageType["ECS_AL2"] = "ECS_AL2"; + /** + * Tells Batch that this machine image runs on GPU instances + */ + EcsMachineImageType["ECS_AL2_NVIDIA"] = "ECS_AL2_NVIDIA"; +})(EcsMachineImageType || (exports.EcsMachineImageType = EcsMachineImageType = {})); +/** + * Maps the image to instance types + */ +var EksMachineImageType; +(function (EksMachineImageType) { + /** + * Tells Batch that this machine image runs on non-GPU instances + */ + EksMachineImageType["EKS_AL2"] = "EKS_AL2"; + /** + * Tells Batch that this machine image runs on GPU instances + */ + EksMachineImageType["EKS_AL2_NVIDIA"] = "EKS_AL2_NVIDIA"; +})(EksMachineImageType || (exports.EksMachineImageType = EksMachineImageType = {})); +/** + * Determines how this compute environment chooses instances to spawn + * + * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/ + */ +var AllocationStrategy; +(function (AllocationStrategy) { + /** + * Batch chooses the lowest-cost instance type that fits all the jobs in the queue. + * If instances of that type are not available, the queue will not choose a new type; + * instead, it will wait for the instance to become available. + * This can stall your `Queue`, with your compute environment only using part of its max capacity + * (or none at all) until the `BEST_FIT` instance becomes available. + * This allocation strategy keeps costs lower but can limit scaling. + * `BEST_FIT` isn't supported when updating compute environments + */ + AllocationStrategy["BEST_FIT"] = "BEST_FIT"; + /** + * This is the default Allocation Strategy if `spot` is `false` or unspecified. + * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements + * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`. + * However, if not all of the capacity can be filled with this instance type, + * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity. + * To make the most use of this allocation strategy, + * it is recommended to use as many instance classes as is feasible for your workload. + */ + AllocationStrategy["BEST_FIT_PROGRESSIVE"] = "BEST_FIT_PROGRESSIVE"; + /** + * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` + * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled). + * This will tell Batch to choose the instance types from the ones you’ve specified that have + * the most spot capacity available to minimize the chance of interruption. + * To get the most benefit from your spot instances, + * you should allow Batch to choose from as many different instance types as possible. + */ + AllocationStrategy["SPOT_CAPACITY_OPTIMIZED"] = "SPOT_CAPACITY_OPTIMIZED"; + /** + * The price and capacity optimized allocation strategy looks at both price and capacity + * to select the Spot Instance pools that are the least likely to be interrupted + * and have the lowest possible price. + * + * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances. + */ + AllocationStrategy["SPOT_PRICE_CAPACITY_OPTIMIZED"] = "SPOT_PRICE_CAPACITY_OPTIMIZED"; +})(AllocationStrategy || (exports.AllocationStrategy = AllocationStrategy = {})); +/** + * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase { + /** + * refer to an existing ComputeEnvironment by its arn. + */ + static fromManagedEc2EcsComputeEnvironmentArn(scope, id, managedEc2EcsComputeEnvironmentArn) { + const stack = core_1.Stack.of(scope); + const computeEnvironmentName = stack.splitArn(managedEc2EcsComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + class Import extends core_1.Resource { + constructor() { + super(...arguments); + this.computeEnvironmentArn = managedEc2EcsComputeEnvironmentArn; + this.computeEnvironmentName = computeEnvironmentName; + this.enabled = true; + this.instanceClasses = []; + this.instanceTypes = []; + this.maxvCpus = 1; + this.connections = {}; + this.securityGroups = []; + this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); + } + addInstanceClass(_instanceClass) { + throw new Error(`cannot add instance class to imported ComputeEnvironment '${id}'`); + } + addInstanceType(_instanceType) { + throw new Error(`cannot add instance type to imported ComputeEnvironment '${id}'`); + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, ManagedEc2EcsComputeEnvironment); + } + throw error; + } + this.images = props.images; + this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot); + this.spotBidPercentage = props.spotBidPercentage; + this.spotFleetRole = props.spotFleetRole ?? (this.spot && this.allocationStrategy === AllocationStrategy.BEST_FIT + ? createSpotFleetRole(this) + : undefined); + this.instanceTypes = props.instanceTypes ?? []; + this.instanceClasses = props.instanceClasses ?? []; + const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole); + this.instanceRole = instanceRole; + this.instanceProfile = instanceProfile; + this.launchTemplate = props.launchTemplate; + this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS; + this.placementGroup = props.placementGroup; + validateVCpus(id, this.minvCpus, this.maxvCpus); + validateSpotConfig(id, this.spot, this.spotBidPercentage, this.spotFleetRole); + const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); + const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { + ...baseManagedResourceProperties(this, subnetIds), + computeEnvironmentName: props.computeEnvironmentName, + computeResources: { + ...baseManagedResourceProperties(this, subnetIds).computeResources, + minvCpus: this.minvCpus, + instanceRole: this.instanceProfile.attrArn, + instanceTypes: core_1.Lazy.list({ + produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses), + }), + type: this.spot ? 'SPOT' : 'EC2', + spotIamFleetRole: this.spotFleetRole?.roleArn, + allocationStrategy: this.allocationStrategy, + bidPercentage: this.spotBidPercentage, + launchTemplate: this.launchTemplate ? { + launchTemplateId: this.launchTemplate?.launchTemplateId, + } : undefined, + ec2Configuration: this.images?.map((image) => { + return { + imageIdOverride: image.image?.getImage(this).imageId, + imageType: image.imageType ?? EcsMachineImageType.ECS_AL2, + }; + }), + placementGroup: this.placementGroup?.placementGroupName, + tags: this.tags.renderedTags, + }, + }); + this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); + this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { + service: 'batch', + resource: 'compute-environment', + resourceName: this.physicalName, + }); + this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }); + } + addInstanceType(instanceType) { + this.instanceTypes.push(instanceType); + } + addInstanceClass(instanceClass) { + this.instanceClasses.push(instanceClass); + } +} +exports.ManagedEc2EcsComputeEnvironment = ManagedEc2EcsComputeEnvironment; +_a = JSII_RTTI_SYMBOL_1; +ManagedEc2EcsComputeEnvironment[_a] = { fqn: "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment", version: "0.0.0" }; +/** + * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase { + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, ManagedEc2EksComputeEnvironment); + } + throw error; + } + this.kubernetesNamespace = props.kubernetesNamespace; + this.eksCluster = props.eksCluster; + this.images = props.images; + this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot); + if (this.allocationStrategy === AllocationStrategy.BEST_FIT) { + throw new Error(`ManagedEc2EksComputeEnvironment '${id}' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'`); + } + this.spotBidPercentage = props.spotBidPercentage; + this.instanceTypes = props.instanceTypes ?? []; + this.instanceClasses = props.instanceClasses ?? []; + const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole); + this.instanceRole = instanceRole; + this.instanceProfile = instanceProfile; + this.launchTemplate = props.launchTemplate; + this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS; + this.placementGroup = props.placementGroup; + validateVCpus(id, this.minvCpus, this.maxvCpus); + validateSpotConfig(id, this.spot, this.spotBidPercentage); + const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); + const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { + ...baseManagedResourceProperties(this, subnetIds), + computeEnvironmentName: props.computeEnvironmentName, + eksConfiguration: { + eksClusterArn: this.eksCluster.clusterArn, + kubernetesNamespace: this.kubernetesNamespace, + }, + computeResources: { + ...baseManagedResourceProperties(this, subnetIds).computeResources, + minvCpus: this.minvCpus, + instanceRole: this.instanceProfile.attrArn, + instanceTypes: core_1.Lazy.list({ produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }), + type: this.spot ? 'SPOT' : 'EC2', + allocationStrategy: this.allocationStrategy, + bidPercentage: this.spotBidPercentage, + launchTemplate: this.launchTemplate ? { + launchTemplateId: this.launchTemplate?.launchTemplateId, + } : undefined, + ec2Configuration: this.images?.map((image) => { + return { + imageIdOverride: image.image?.getImage(this).imageId, + imageType: image.imageType ?? EksMachineImageType.EKS_AL2, + }; + }), + placementGroup: this.placementGroup?.placementGroupName, + tags: this.tags.renderedTags, + }, + }); + this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); + this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { + service: 'batch', + resource: 'compute-environment', + resourceName: this.physicalName, + }); + this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }); + } + addInstanceType(instanceType) { + this.instanceTypes.push(instanceType); + } + addInstanceClass(instanceClass) { + this.instanceClasses.push(instanceClass); + } +} +exports.ManagedEc2EksComputeEnvironment = ManagedEc2EksComputeEnvironment; +_b = JSII_RTTI_SYMBOL_1; +ManagedEc2EksComputeEnvironment[_b] = { fqn: "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment", version: "0.0.0" }; +/** + * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. + * + * @resource AWS::Batch::ComputeEnvironment + */ +class FargateComputeEnvironment extends ManagedComputeEnvironmentBase { + /** + * Reference an existing FargateComputeEnvironment by its arn + */ + static fromFargateComputeEnvironmentArn(scope, id, fargateComputeEnvironmentArn) { + const stack = core_1.Stack.of(scope); + const computeEnvironmentName = stack.splitArn(fargateComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + class Import extends core_1.Resource { + constructor() { + super(...arguments); + this.computeEnvironmentArn = fargateComputeEnvironmentArn; + this.computeEnvironmentName = computeEnvironmentName; + this.enabled = true; + this.maxvCpus = 1; + this.connections = {}; + this.securityGroups = []; + this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, FargateComputeEnvironment); + } + throw error; + } + const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); + const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { + ...baseManagedResourceProperties(this, subnetIds), + computeEnvironmentName: props.computeEnvironmentName, + computeResources: { + ...baseManagedResourceProperties(this, subnetIds).computeResources, + type: this.spot ? 'FARGATE_SPOT' : 'FARGATE', + }, + }); + this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); + this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { + service: 'batch', + resource: 'compute-environment', + resourceName: this.physicalName, + }); + } +} +exports.FargateComputeEnvironment = FargateComputeEnvironment; +_c = JSII_RTTI_SYMBOL_1; +FargateComputeEnvironment[_c] = { fqn: "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment", version: "0.0.0" }; +function renderInstances(types, classes, useOptimalInstanceClasses) { + const instances = []; + for (const instanceType of types ?? []) { + instances.push(instanceType.toString()); + } + for (const instanceClass of classes ?? []) { + instances.push(instanceClass); + } + if (useOptimalInstanceClasses || useOptimalInstanceClasses === undefined) { + instances.push('optimal'); + } + return instances; +} +function createInstanceRoleAndProfile(scope, instanceRole) { + const result = {}; + result.instanceRole = instanceRole ?? new iam.Role(scope, 'InstanceProfileRole', { + assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'), + managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonEC2ContainerServiceforEC2Role')], + }); + result.instanceProfile = new iam.CfnInstanceProfile(scope, 'InstanceProfile', { + roles: [result.instanceRole.roleName], + }); + return result; +} +function createSpotFleetRole(scope) { + return new iam.Role(scope, 'SpotFleetRole', { + assumedBy: new iam.ServicePrincipal('spotfleet.amazonaws.com'), + }); +} +function determineAllocationStrategy(id, allocationStrategy, spot) { + let result = allocationStrategy; + if (!allocationStrategy) { + result = spot ? AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED : AllocationStrategy.BEST_FIT_PROGRESSIVE; + } + else if (allocationStrategy === AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED && !spot) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances`); + } + else if (allocationStrategy === AllocationStrategy.SPOT_CAPACITY_OPTIMIZED && !spot) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances`); + } + return result; +} +function validateInstances(types, classes, useOptimalInstanceClasses) { + if (renderInstances(types, classes, useOptimalInstanceClasses).length === 0) { + return ["Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes"]; + } + return []; +} +function validateSpotConfig(id, spot, spotBidPercentage, spotFleetRole) { + if (spotBidPercentage) { + if (!spot) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' without specifying 'spot'`); + } + else if (spotBidPercentage > 100) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' > 100`); + } + else if (spotBidPercentage < 0) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' < 0`); + } + } + if (spotFleetRole) { + if (!spot) { + throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotFleetRole' without specifying 'spot'`); + } + } +} +function validateVCpus(id, minvCpus, maxvCpus) { + if (minvCpus < 0) { + throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} < 0; 'minvCpus' cannot be less than zero`); + } + if (minvCpus > maxvCpus) { + throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} > 'maxvCpus' = ${maxvCpus}; 'minvCpus' cannot be greater than 'maxvCpus'`); + } +} +function baseManagedResourceProperties(baseComputeEnvironment, subnetIds) { + return { + serviceRole: baseComputeEnvironment.serviceRole?.roleArn, + state: baseComputeEnvironment.enabled ? 'ENABLED' : 'DISABLED', + computeResources: { + maxvCpus: baseComputeEnvironment.maxvCpus, + type: 'managed', + updateToLatestImageVersion: baseComputeEnvironment.updateToLatestImageVersion, + securityGroupIds: baseComputeEnvironment.securityGroups.map((securityGroup) => securityGroup.securityGroupId), + subnets: subnetIds, + }, + updatePolicy: { + terminateJobsOnUpdate: baseComputeEnvironment.terminateOnUpdate, + jobExecutionTimeoutMinutes: baseComputeEnvironment.updateTimeout?.toMinutes(), + }, + replaceComputeEnvironment: baseComputeEnvironment.replaceComputeEnvironment, + type: 'managed', + }; +} +const DEFAULT_MIN_VCPUS = 0; +const DEFAULT_MAX_VCPUS = 256; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-compute-environment.js","sourceRoot":"","sources":["managed-compute-environment.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as eks from 'aws-cdk-lib/aws-eks';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\nimport { ArnFormat, Duration, ITaggable, Lazy, Resource, Stack, TagManager, TagType } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnComputeEnvironment } from 'aws-cdk-lib/aws-batch';\nimport { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base';\n\n/**\n * Represents a Managed ComputeEnvironment. Batch will provision EC2 Instances to\n * meet the requirements of the jobs executing in this ComputeEnvironment.\n */\nexport interface IManagedComputeEnvironment extends IComputeEnvironment, ec2.IConnectable, ITaggable {\n  /**\n   * The maximum vCpus this `ManagedComputeEnvironment` can scale up to.\n   *\n   * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n   * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\n   * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\n   * or `instanceClasses`.\n   */\n  readonly maxvCpus: number;\n\n  /**\n   * Specifies whether this Compute Environment is replaced if an update is made that requires\n   * replacing its instances. To enable more properties to be updated,\n   * set this property to `false`. When changing the value of this property to false,\n   * do not change any other properties at the same time.\n   * If other properties are changed at the same time,\n   * and the change needs to be rolled back but it can't,\n   * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\n   * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\n   * However, if you can continue to roll it back,\n   * you can return the stack to its original settings and then try to update it again.\n   *\n   * The properties which require a replacement of the Compute Environment are:\n   *\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html\n   */\n  readonly replaceComputeEnvironment?: boolean;\n\n  /**\n   * Whether or not to use spot instances.\n   * Spot instances are less expensive EC2 instances that can be\n   * reclaimed by EC2 at any time; your job will be given two minutes\n   * of notice before reclamation.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Only meaningful if `terminateOnUpdate` is `false`. If so,\n   * when an infrastructure update is triggered, any running jobs\n   * will be allowed to run until `updateTimeout` has expired.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   * @default 30 minutes\n   */\n  readonly updateTimeout?: Duration;\n\n  /**\n   * Whether or not any running jobs will be immediately terminated when an infrastructure update\n   * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's\n   * retry policy.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default false\n   */\n  readonly terminateOnUpdate?: boolean;\n\n  /**\n   * The security groups this Compute Environment will launch instances in.\n   */\n  readonly securityGroups: ec2.ISecurityGroup[];\n\n  /**\n   * The VPC Subnets this Compute Environment will launch instances in.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * Whether or not the AMI is updated to the latest one supported by Batch\n   * when an infrastructure update occurs.\n   *\n   * If you specify a specific AMI, this property will be ignored.\n   *\n   * @default true\n   */\n  readonly updateToLatestImageVersion?: boolean;\n}\n\n/**\n * Props for a ManagedComputeEnvironment\n */\nexport interface ManagedComputeEnvironmentProps extends ComputeEnvironmentProps {\n  /**\n  * The maximum vCpus this `ManagedComputeEnvironment` can scale up to.\n  * Each vCPU is equivalent to 1024 CPU shares.\n  *\n  * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n  * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\n  * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\n  * or `instanceClasses`.\n  *\n  * @default 256\n  */\n  readonly maxvCpus?: number;\n\n  /**\n  * Specifies whether this Compute Environment is replaced if an update is made that requires\n  * replacing its instances. To enable more properties to be updated,\n  * set this property to `false`. When changing the value of this property to false,\n  * do not change any other properties at the same time.\n  * If other properties are changed at the same time,\n  * and the change needs to be rolled back but it can't,\n  * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\n  * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\n  * However, if you can continue to roll it back,\n  * you can return the stack to its original settings and then try to update it again.\n  *\n  * The properties which require a replacement of the Compute Environment are:\n  *\n  * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment\n  * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html\n  *\n  * @default false\n  */\n  readonly replaceComputeEnvironment?: boolean;\n\n  /**\n   * Whether or not to use spot instances.\n   * Spot instances are less expensive EC2 instances that can be\n   * reclaimed by EC2 at any time; your job will be given two minutes\n   * of notice before reclamation.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Only meaningful if `terminateOnUpdate` is `false`. If so,\n   * when an infrastructure update is triggered, any running jobs\n   * will be allowed to run until `updateTimeout` has expired.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default 30 minutes\n   */\n  readonly updateTimeout?: Duration;\n\n  /**\n   * Whether or not any running jobs will be immediately terminated when an infrastructure update\n   * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's\n   * retry policy.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default false\n   */\n  readonly terminateOnUpdate?: boolean;\n\n  /**\n   * VPC in which this Compute Environment will launch Instances\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n  * The security groups this Compute Environment will launch instances in.\n  *\n  * @default new security groups will be created\n  */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n  * The VPC Subnets this Compute Environment will launch instances in.\n  *\n  * @default new subnets will be created\n  */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n  * Whether or not the AMI is updated to the latest one supported by Batch\n  * when an infrastructure update occurs.\n  *\n  * If you specify a specific AMI, this property will be ignored.\n  *\n  * @default true\n  */\n  readonly updateToLatestImageVersion?: boolean;\n}\n\n/**\n * Abstract base class for ManagedComputeEnvironments\n * @internal\n */\nexport abstract class ManagedComputeEnvironmentBase extends ComputeEnvironmentBase implements IManagedComputeEnvironment {\n  public readonly maxvCpus: number;\n  public readonly replaceComputeEnvironment?: boolean;\n  public readonly spot?: boolean;\n  public readonly updateTimeout?: Duration;\n  public readonly terminateOnUpdate?: boolean;\n  public readonly securityGroups: ec2.ISecurityGroup[];\n  public readonly updateToLatestImageVersion?: boolean;\n  public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n\n  public readonly connections: ec2.Connections;\n\n  constructor(scope: Construct, id: string, props: ManagedComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.maxvCpus = props.maxvCpus ?? DEFAULT_MAX_VCPUS;\n    this.replaceComputeEnvironment = props.replaceComputeEnvironment ?? false;\n    this.spot = props.spot;\n    this.updateTimeout = props.updateTimeout;\n    this.terminateOnUpdate = props.terminateOnUpdate;\n    this.updateToLatestImageVersion = props.updateToLatestImageVersion ?? true;\n    this.securityGroups = props.securityGroups ?? [\n      new ec2.SecurityGroup(this, 'SecurityGroup', {\n        vpc: props.vpc,\n      }),\n    ];\n    this.connections = new ec2.Connections({\n      securityGroups: this.securityGroups,\n    });\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n */\nexport interface IManagedEc2EcsComputeEnvironment extends IManagedComputeEnvironment {\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.\n   *\n   * @default\n   * - ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances\n   */\n  readonly images?: EcsMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The service-linked role that Spot Fleet needs to launch instances on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html\n   *\n   * @default - a new Role will be created\n   */\n  readonly spotFleetRole?: iam.IRole;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceTypes: ec2.InstanceType[];\n\n  /**\n   * The instance classes that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the size.\n   */\n  readonly instanceClasses: ec2.InstanceClass[];\n\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n\n  /**\n   * Add an instance type to this compute environment\n   */\n  addInstanceType(instanceType: ec2.InstanceType): void;\n\n  /**\n   * Add an instance class to this compute environment\n   */\n  addInstanceClass(instanceClass: ec2.InstanceClass): void;\n}\n\n/**\n * Base interface for containing all information needed to\n * configure a MachineImage in Batch\n */\ninterface MachineImage {\n  /**\n   * The machine image to use\n   *\n   * @default - chosen by batch\n   */\n  readonly image?: ec2.IMachineImage;\n}\n\n/**\n * A Batch MachineImage that is compatible with ECS\n */\nexport interface EcsMachineImage extends MachineImage {\n  /**\n   * Tells Batch which instance type to launch this image on\n   *\n   * @default - 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances\n   */\n  readonly imageType?: EcsMachineImageType;\n}\n\n/**\n * A Batch MachineImage that is compatible with EKS\n */\nexport interface EksMachineImage extends MachineImage{\n  /**\n   * Tells Batch which instance type to launch this image on\n   *\n   * @default - 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances\n   */\n  readonly imageType?: EksMachineImageType;\n}\n\n/**\n * Maps the image to instance types\n */\nexport enum EcsMachineImageType {\n  /**\n   * Tells Batch that this machine image runs on non-GPU instances\n   */\n  ECS_AL2 = 'ECS_AL2',\n\n  /**\n   * Tells Batch that this machine image runs on GPU instances\n   */\n  ECS_AL2_NVIDIA = 'ECS_AL2_NVIDIA',\n}\n\n/**\n * Maps the image to instance types\n */\nexport enum EksMachineImageType {\n  /**\n   * Tells Batch that this machine image runs on non-GPU instances\n   */\n  EKS_AL2 = 'EKS_AL2',\n\n  /**\n   * Tells Batch that this machine image runs on GPU instances\n   */\n  EKS_AL2_NVIDIA = 'EKS_AL2_NVIDIA',\n}\n\n/**\n * Determines how this compute environment chooses instances to spawn\n *\n * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/\n */\nexport enum AllocationStrategy {\n  /**\n   * Batch chooses the lowest-cost instance type that fits all the jobs in the queue.\n   * If instances of that type are not available, the queue will not choose a new type;\n   * instead, it will wait for the instance to become available.\n   * This can stall your `Queue`, with your compute environment only using part of its max capacity\n   * (or none at all) until the `BEST_FIT` instance becomes available.\n   * This allocation strategy keeps costs lower but can limit scaling.\n   * `BEST_FIT` isn't supported when updating compute environments\n   */\n  BEST_FIT = 'BEST_FIT',\n\n  /**\n   * This is the default Allocation Strategy if `spot` is `false` or unspecified.\n   * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\n   * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\n   * However, if not all of the capacity can be filled with this instance type,\n   * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\n   * To make the most use of this allocation strategy,\n   * it is recommended to use as many instance classes as is feasible for your workload.\n   */\n  BEST_FIT_PROGRESSIVE = 'BEST_FIT_PROGRESSIVE',\n\n  /**\n   * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment`\n   * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled).\n   * This will tell Batch to choose the instance types from the ones you’ve specified that have\n   * the most spot capacity available to minimize the chance of interruption.\n   * To get the most benefit from your spot instances,\n   * you should allow Batch to choose from as many different instance types as possible.\n   */\n  SPOT_CAPACITY_OPTIMIZED = 'SPOT_CAPACITY_OPTIMIZED',\n\n  /**\n   * The price and capacity optimized allocation strategy looks at both price and capacity\n   * to select the Spot Instance pools that are the least likely to be interrupted\n   * and have the lowest possible price.\n   *\n   * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances.\n   */\n  SPOT_PRICE_CAPACITY_OPTIMIZED = 'SPOT_PRICE_CAPACITY_OPTIMIZED',\n}\n\n/**\n * Props for a ManagedEc2EcsComputeEnvironment\n */\nexport interface ManagedEc2EcsComputeEnvironmentProps extends ManagedComputeEnvironmentProps {\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   * If you specify this property with only `image` specified, then the\n   * `imageType` will default to `ECS_AL2`. *If your image needs GPU resources,\n   * specify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly\n   * join the ComputeEnvironment*.\n   *\n   * @default\n   * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances\n   */\n  readonly images?: EcsMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The service-linked role that Spot Fleet needs to launch instances on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html\n   *\n   * @default - a new role will be created\n   */\n  readonly spotFleetRole?: iam.IRole;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceTypes?: ec2.InstanceType[];\n\n  /**\n   * The instance classes that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the instance size.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceClasses?: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EcsComputeEnvironment {\n  /**\n   * refer to an existing ComputeEnvironment by its arn.\n   */\n  public static fromManagedEc2EcsComputeEnvironmentArn(\n    scope: Construct, id: string, managedEc2EcsComputeEnvironmentArn: string,\n  ): IManagedEc2EcsComputeEnvironment {\n    const stack = Stack.of(scope);\n    const computeEnvironmentName = stack.splitArn(managedEc2EcsComputeEnvironmentArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends Resource implements IManagedEc2EcsComputeEnvironment {\n      public readonly computeEnvironmentArn = managedEc2EcsComputeEnvironmentArn;\n      public readonly computeEnvironmentName = computeEnvironmentName;\n      public readonly enabled = true;\n      public readonly instanceClasses = [];\n      public readonly instanceTypes = [];\n      public readonly maxvCpus = 1;\n      public readonly connections = { } as any;\n      public readonly securityGroups = [];\n      public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n\n      public addInstanceClass(_instanceClass: ec2.InstanceClass): void {\n        throw new Error(`cannot add instance class to imported ComputeEnvironment '${id}'`);\n      }\n      public addInstanceType(_instanceType: ec2.InstanceType): void {\n        throw new Error(`cannot add instance type to imported ComputeEnvironment '${id}'`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n  public readonly computeEnvironmentArn: string;\n  public readonly computeEnvironmentName: string;\n\n  public readonly images?: EcsMachineImage[];\n  public readonly allocationStrategy?: AllocationStrategy;\n  public readonly spotBidPercentage?: number;\n  public readonly spotFleetRole?: iam.IRole;\n  public readonly instanceTypes: ec2.InstanceType[];\n  public readonly instanceClasses: ec2.InstanceClass[];\n  public readonly instanceRole?: iam.IRole;\n  public readonly launchTemplate?: ec2.ILaunchTemplate;\n  public readonly minvCpus?: number;\n  public readonly placementGroup?: ec2.IPlacementGroup;\n\n  private readonly instanceProfile: iam.CfnInstanceProfile;\n\n  constructor(scope: Construct, id: string, props: ManagedEc2EcsComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.images = props.images;\n    this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot);\n    this.spotBidPercentage = props.spotBidPercentage;\n\n    this.spotFleetRole = props.spotFleetRole ?? (\n      this.spot && this.allocationStrategy === AllocationStrategy.BEST_FIT\n        ? createSpotFleetRole(this)\n        : undefined\n    );\n\n    this.instanceTypes = props.instanceTypes ?? [];\n    this.instanceClasses = props.instanceClasses ?? [];\n\n    const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole);\n    this.instanceRole = instanceRole;\n    this.instanceProfile = instanceProfile;\n\n    this.launchTemplate = props.launchTemplate;\n    this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS;\n    this.placementGroup = props.placementGroup;\n\n    validateVCpus(id, this.minvCpus, this.maxvCpus);\n    validateSpotConfig(id, this.spot, this.spotBidPercentage, this.spotFleetRole);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        minvCpus: this.minvCpus,\n        instanceRole: this.instanceProfile.attrArn, // this is not a typo; this property actually takes a profile, not a standard role\n        instanceTypes: Lazy.list({\n          produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses),\n        }),\n        type: this.spot ? 'SPOT' : 'EC2',\n        spotIamFleetRole: this.spotFleetRole?.roleArn,\n        allocationStrategy: this.allocationStrategy,\n        bidPercentage: this.spotBidPercentage,\n        launchTemplate: this.launchTemplate ? {\n          launchTemplateId: this.launchTemplate?.launchTemplateId,\n        } : undefined,\n        ec2Configuration: this.images?.map((image) => {\n          return {\n            imageIdOverride: image.image?.getImage(this).imageId,\n            imageType: image.imageType ?? EcsMachineImageType.ECS_AL2,\n          };\n        }),\n        placementGroup: this.placementGroup?.placementGroupName,\n        tags: this.tags.renderedTags as any,\n      },\n    });\n\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n\n    this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) });\n  }\n\n  public addInstanceType(instanceType: ec2.InstanceType): void {\n    this.instanceTypes.push(instanceType);\n  }\n\n  public addInstanceClass(instanceClass: ec2.InstanceClass): void {\n    this.instanceClasses.push(instanceClass);\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses EKS orchestration on EC2 instances.\n */\ninterface IManagedEc2EksComputeEnvironment extends IManagedComputeEnvironment {\n  /**\n   * The namespace of the Cluster\n   *\n   * Cannot be 'default', start with 'kube-', or be longer than 64 characters.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/\n   */\n  readonly kubernetesNamespace?: string;\n\n  /**\n   * The cluster that backs this Compute Environment. Required\n   * for Compute Environments running Kubernetes jobs.\n   *\n   * Please ensure that you have followed the steps at\n   *\n   * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n   *\n   * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\n   * If you do not follow the steps in the link, the deployment fail with a message that the\n   * compute environment did not stabilize.\n   */\n  readonly eksCluster: eks.ICluster;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * @default\n   * EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\n   */\n  readonly images?: EksMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceTypes: ec2.InstanceType[];\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceClasses: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default - no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n\n  /**\n   * Add an instance type to this compute environment\n   */\n  addInstanceType(instanceType: ec2.InstanceType): void;\n\n  /**\n   * Add an instance class to this compute environment\n   */\n  addInstanceClass(instanceClass: ec2.InstanceClass): void;\n}\n\n/**\n * Props for a ManagedEc2EksComputeEnvironment\n */\nexport interface ManagedEc2EksComputeEnvironmentProps extends ManagedComputeEnvironmentProps {\n  /**\n   * The namespace of the Cluster\n   */\n  readonly kubernetesNamespace: string;\n\n  /**\n   * The cluster that backs this Compute Environment. Required\n   * for Compute Environments running Kubernetes jobs.\n   *\n   * Please ensure that you have followed the steps at\n   *\n   * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n   *\n   * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\n   * If you do not follow the steps in the link, the deployment fail with a message that the\n   * compute environment did not stabilize.\n   */\n  readonly eksCluster: eks.ICluster;\n\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * @default\n   * If `imageKubernetesVersion` is specified,\n   * - EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\n   * Otherwise,\n   * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances,\n   */\n  readonly images?: EksMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceTypes?: ec2.InstanceType[];\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the instance size.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceClasses?: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.**\n   *\n   * @default - no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EksComputeEnvironment {\n  public readonly kubernetesNamespace?: string;\n  public readonly eksCluster: eks.ICluster;\n\n  public readonly computeEnvironmentName: string;\n  public readonly computeEnvironmentArn: string;\n\n  public readonly images?: EksMachineImage[];\n  public readonly allocationStrategy?: AllocationStrategy;\n  public readonly spotBidPercentage?: number;\n  public readonly instanceTypes: ec2.InstanceType[];\n  public readonly instanceClasses: ec2.InstanceClass[];\n  public readonly instanceRole?: iam.IRole;\n  public readonly launchTemplate?: ec2.ILaunchTemplate;\n  public readonly minvCpus?: number;\n  public readonly placementGroup?: ec2.IPlacementGroup;\n\n  private readonly instanceProfile: iam.CfnInstanceProfile;\n\n  constructor(scope: Construct, id: string, props: ManagedEc2EksComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.kubernetesNamespace = props.kubernetesNamespace;\n    this.eksCluster = props.eksCluster;\n\n    this.images = props.images;\n    this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot);\n    if (this.allocationStrategy === AllocationStrategy.BEST_FIT) {\n      throw new Error(`ManagedEc2EksComputeEnvironment '${id}' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'`);\n    }\n    this.spotBidPercentage = props.spotBidPercentage;\n    this.instanceTypes = props.instanceTypes ?? [];\n    this.instanceClasses = props.instanceClasses ?? [];\n\n    const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole);\n    this.instanceRole = instanceRole;\n    this.instanceProfile = instanceProfile;\n\n    this.launchTemplate = props.launchTemplate;\n    this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS;\n    this.placementGroup = props.placementGroup;\n\n    validateVCpus(id, this.minvCpus, this.maxvCpus);\n    validateSpotConfig(id, this.spot, this.spotBidPercentage);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      eksConfiguration: {\n        eksClusterArn: this.eksCluster.clusterArn,\n        kubernetesNamespace: this.kubernetesNamespace,\n      },\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        minvCpus: this.minvCpus,\n        instanceRole: this.instanceProfile.attrArn, // this is not a typo; this property actually takes a profile, not a standard role\n        instanceTypes: Lazy.list({ produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }),\n        type: this.spot ? 'SPOT' : 'EC2',\n        allocationStrategy: this.allocationStrategy,\n        bidPercentage: this.spotBidPercentage,\n        launchTemplate: this.launchTemplate ? {\n          launchTemplateId: this.launchTemplate?.launchTemplateId,\n        } : undefined,\n        ec2Configuration: this.images?.map((image) => {\n          return {\n            imageIdOverride: image.image?.getImage(this).imageId,\n            imageType: image.imageType ?? EksMachineImageType.EKS_AL2,\n          };\n        }),\n        placementGroup: this.placementGroup?.placementGroupName,\n        tags: this.tags.renderedTags as any,\n      },\n    });\n\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n\n    this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) });\n  }\n\n  public addInstanceType(instanceType: ec2.InstanceType): void {\n    this.instanceTypes.push(instanceType);\n  }\n\n  public addInstanceClass(instanceClass: ec2.InstanceClass): void {\n    this.instanceClasses.push(instanceClass);\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances.\n */\nexport interface IFargateComputeEnvironment extends IManagedComputeEnvironment { }\n\n/**\n * Props for a FargateComputeEnvironment\n */\nexport interface FargateComputeEnvironmentProps extends ManagedComputeEnvironmentProps { }\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class FargateComputeEnvironment extends ManagedComputeEnvironmentBase implements IFargateComputeEnvironment {\n  /**\n   * Reference an existing FargateComputeEnvironment by its arn\n   */\n  public static fromFargateComputeEnvironmentArn(scope: Construct, id: string, fargateComputeEnvironmentArn: string): IFargateComputeEnvironment {\n    const stack = Stack.of(scope);\n    const computeEnvironmentName = stack.splitArn(fargateComputeEnvironmentArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends Resource implements IFargateComputeEnvironment {\n      public readonly computeEnvironmentArn = fargateComputeEnvironmentArn;\n      public readonly computeEnvironmentName = computeEnvironmentName;\n      public readonly enabled = true;\n      public readonly maxvCpus = 1;\n      public readonly connections = { } as any;\n      public readonly securityGroups = [];\n      public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeEnvironmentName: string;\n  public readonly computeEnvironmentArn: string;\n\n  constructor(scope: Construct, id: string, props: FargateComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        type: this.spot ? 'FARGATE_SPOT' : 'FARGATE',\n      },\n    });\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n  }\n}\n\nfunction renderInstances(types?: ec2.InstanceType[], classes?: ec2.InstanceClass[], useOptimalInstanceClasses?: boolean): string[] {\n  const instances = [];\n\n  for (const instanceType of types ?? []) {\n    instances.push(instanceType.toString());\n  }\n  for (const instanceClass of classes ?? []) {\n    instances.push(instanceClass);\n  }\n  if (useOptimalInstanceClasses || useOptimalInstanceClasses === undefined) {\n    instances.push('optimal');\n  }\n\n  return instances;\n}\n\nfunction createInstanceRoleAndProfile(scope: Construct, instanceRole?: iam.IRole) {\n  const result: any = {};\n\n  result.instanceRole = instanceRole ?? new iam.Role(scope, 'InstanceProfileRole', {\n    assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n    managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonEC2ContainerServiceforEC2Role')],\n  });\n\n  result.instanceProfile = new iam.CfnInstanceProfile(scope, 'InstanceProfile', {\n    roles: [result.instanceRole.roleName],\n  });\n\n  return result;\n}\n\nfunction createSpotFleetRole(scope: Construct): IRole {\n  return new iam.Role(scope, 'SpotFleetRole', {\n    assumedBy: new iam.ServicePrincipal('spotfleet.amazonaws.com'),\n  });\n}\n\nfunction determineAllocationStrategy(id: string, allocationStrategy?: AllocationStrategy, spot?: boolean): AllocationStrategy | undefined {\n  let result = allocationStrategy;\n  if (!allocationStrategy) {\n    result = spot ? AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED : AllocationStrategy.BEST_FIT_PROGRESSIVE;\n  } else if (allocationStrategy === AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED && !spot) {\n    throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances`);\n  } else if (allocationStrategy === AllocationStrategy.SPOT_CAPACITY_OPTIMIZED && !spot) {\n    throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances`);\n  }\n\n  return result;\n}\n\nfunction validateInstances(types?: ec2.InstanceType[], classes?: ec2.InstanceClass[], useOptimalInstanceClasses?: boolean): string[] {\n  if (renderInstances(types, classes, useOptimalInstanceClasses).length === 0) {\n    return [\"Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes\"];\n  }\n\n  return [];\n}\n\nfunction validateSpotConfig(id: string, spot?: boolean, spotBidPercentage?: number, spotFleetRole?: iam.IRole): void {\n  if (spotBidPercentage) {\n    if (!spot) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' without specifying 'spot'`);\n    } else if (spotBidPercentage > 100) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' > 100`);\n    } else if (spotBidPercentage < 0) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' < 0`);\n    }\n  }\n\n  if (spotFleetRole) {\n    if (!spot) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotFleetRole' without specifying 'spot'`);\n    }\n  }\n}\n\nfunction validateVCpus(id: string, minvCpus: number, maxvCpus: number): void {\n  if (minvCpus < 0) {\n    throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} < 0; 'minvCpus' cannot be less than zero`);\n  }\n  if (minvCpus > maxvCpus) {\n    throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} > 'maxvCpus' = ${maxvCpus}; 'minvCpus' cannot be greater than 'maxvCpus'`);\n  }\n}\n\nfunction baseManagedResourceProperties(baseComputeEnvironment: ManagedComputeEnvironmentBase, subnetIds: string[]) {\n  return {\n    serviceRole: baseComputeEnvironment.serviceRole?.roleArn,\n    state: baseComputeEnvironment.enabled ? 'ENABLED' : 'DISABLED',\n    computeResources: {\n      maxvCpus: baseComputeEnvironment.maxvCpus,\n      type: 'managed',\n      updateToLatestImageVersion: baseComputeEnvironment.updateToLatestImageVersion,\n      securityGroupIds: baseComputeEnvironment.securityGroups.map((securityGroup) => securityGroup.securityGroupId),\n      subnets: subnetIds,\n    },\n    updatePolicy: {\n      terminateJobsOnUpdate: baseComputeEnvironment.terminateOnUpdate,\n      jobExecutionTimeoutMinutes: baseComputeEnvironment.updateTimeout?.toMinutes(),\n    },\n    replaceComputeEnvironment: baseComputeEnvironment.replaceComputeEnvironment,\n    type: 'managed',\n  };\n}\n\nconst DEFAULT_MIN_VCPUS = 0;\nconst DEFAULT_MAX_VCPUS = 256;\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts new file mode 100644 index 0000000000000..460a7d679e9eb --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts @@ -0,0 +1,107 @@ +import * as ec2 from 'aws-cdk-lib/aws-ec2'; +import { Construct } from 'constructs'; +import { IEcsContainerDefinition } from './ecs-container-definition'; +import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; +interface IMultiNodeJobDefinition extends IJobDefinition { + /** + * The containers that this multinode job will run. + * + * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/ + */ + readonly containers: MultiNodeContainer[]; + /** + * The instance type that this job definition will run + */ + readonly instanceType: ec2.InstanceType; + /** + * The index of the main node in this job. + * The main node is responsible for orchestration. + * + * @default 0 + */ + readonly mainNode?: number; + /** + * Whether to propogate tags from the JobDefinition + * to the ECS task that Batch spawns + * + * @default false + */ + readonly propagateTags?: boolean; + /** + * Add a container to this multinode job + */ + addContainer(container: MultiNodeContainer): void; +} +/** + * Runs the container on nodes [startNode, endNode] + */ +export interface MultiNodeContainer { + /** + * The index of the first node to run this container + * + * The container is run on all nodes in the range [startNode, endNode] (inclusive) + */ + readonly startNode: number; + /** + * The index of the last node to run this container. + * + * The container is run on all nodes in the range [startNode, endNode] (inclusive) + */ + readonly endNode: number; + /** + * The container that this node range will run + */ + readonly container: IEcsContainerDefinition; +} +/** + * Props to configure a MultiNodeJobDefinition + */ +export interface MultiNodeJobDefinitionProps extends JobDefinitionProps { + /** + * The instance type that this job definition + * will run. + */ + readonly instanceType: ec2.InstanceType; + /** + * The containers that this multinode job will run. + * + * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/ + * + * @default none + */ + readonly containers?: MultiNodeContainer[]; + /** + * The index of the main node in this job. + * The main node is responsible for orchestration. + * + * @default 0 + */ + readonly mainNode?: number; + /** + * Whether to propogate tags from the JobDefinition + * to the ECS task that Batch spawns + * + * @default false + */ + readonly propagateTags?: boolean; +} +/** + * A JobDefinition that uses Ecs orchestration to run multiple containers + * + * @resource AWS::Batch::JobDefinition + */ +export declare class MultiNodeJobDefinition extends JobDefinitionBase implements IMultiNodeJobDefinition { + /** + * refer to an existing JobDefinition by its arn + */ + static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition; + readonly containers: MultiNodeContainer[]; + readonly instanceType: ec2.InstanceType; + readonly mainNode?: number; + readonly propagateTags?: boolean; + readonly jobDefinitionArn: string; + readonly jobDefinitionName: string; + constructor(scope: Construct, id: string, props: MultiNodeJobDefinitionProps); + addContainer(container: MultiNodeContainer): void; +} +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js new file mode 100644 index 0000000000000..dac94633d7c25 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js @@ -0,0 +1,104 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.MultiNodeJobDefinition = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +const ecs_job_definition_1 = require("./ecs-job-definition"); +const job_definition_base_1 = require("./job-definition-base"); +/** + * A JobDefinition that uses Ecs orchestration to run multiple containers + * + * @resource AWS::Batch::JobDefinition + */ +class MultiNodeJobDefinition extends job_definition_base_1.JobDefinitionBase { + /** + * refer to an existing JobDefinition by its arn + */ + static fromJobDefinitionArn(scope, id, jobDefinitionArn) { + const stack = core_1.Stack.of(scope); + const jobDefinitionName = stack.splitArn(jobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + class Import extends job_definition_base_1.JobDefinitionBase { + constructor() { + super(...arguments); + this.jobDefinitionArn = jobDefinitionArn; + this.jobDefinitionName = jobDefinitionName; + this.enabled = true; + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, MultiNodeJobDefinition); + } + throw error; + } + this.containers = props.containers ?? []; + this.mainNode = props.mainNode; + this.instanceType = props.instanceType; + this.propagateTags = props?.propagateTags; + const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { + ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), + type: 'multinode', + jobDefinitionName: props.jobDefinitionName, + propagateTags: this.propagateTags, + nodeProperties: { + mainNode: this.mainNode ?? 0, + nodeRangeProperties: core_1.Lazy.any({ + produce: () => this.containers.map((container) => ({ + targetNodes: container.startNode + ':' + container.endNode, + container: { + ...container.container._renderContainerDefinition(), + instanceType: this.instanceType.toString(), + }, + })), + }), + numNodes: core_1.Lazy.number({ + produce: () => computeNumNodes(this.containers), + }), + }, + platformCapabilities: [ecs_job_definition_1.Compatibility.EC2], + }); + this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { + service: 'batch', + resource: 'job-definition', + resourceName: this.physicalName, + }); + this.jobDefinitionName = this.getResourceNameAttribute(resource.ref); + this.node.addValidation({ validate: () => validateContainers(this.containers) }); + } + addContainer(container) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_MultiNodeContainer(container); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addContainer); + } + throw error; + } + this.containers.push(container); + } +} +exports.MultiNodeJobDefinition = MultiNodeJobDefinition; +_a = JSII_RTTI_SYMBOL_1; +MultiNodeJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition", version: "0.0.0" }; +function computeNumNodes(containers) { + let result = 0; + for (const container of containers) { + result += container.endNode - container.startNode + 1; + } + return result; +} +function validateContainers(containers) { + return containers.length === 0 ? ['multinode job has no containers!'] : []; +} +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multinode-job-definition.js","sourceRoot":"","sources":["multinode-job-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport { ArnFormat, Lazy, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { IEcsContainerDefinition } from './ecs-container-definition';\nimport { Compatibility } from './ecs-job-definition';\nimport { baseJobDefinitionProperties, IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base';\n\ninterface IMultiNodeJobDefinition extends IJobDefinition {\n  /**\n   * The containers that this multinode job will run.\n   *\n   * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/\n   */\n  readonly containers: MultiNodeContainer[];\n\n  /**\n   * The instance type that this job definition will run\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The index of the main node in this job.\n   * The main node is responsible for orchestration.\n   *\n   * @default 0\n   */\n  readonly mainNode?: number;\n\n  /**\n   * Whether to propogate tags from the JobDefinition\n   * to the ECS task that Batch spawns\n   *\n   * @default false\n   */\n  readonly propagateTags?: boolean;\n\n  /**\n   * Add a container to this multinode job\n   */\n  addContainer(container: MultiNodeContainer): void;\n}\n\n/**\n * Runs the container on nodes [startNode, endNode]\n */\nexport interface MultiNodeContainer {\n  /**\n   * The index of the first node to run this container\n   *\n   * The container is run on all nodes in the range [startNode, endNode] (inclusive)\n   */\n  readonly startNode: number;\n\n  /**\n   * The index of the last node to run this container.\n   *\n   * The container is run on all nodes in the range [startNode, endNode] (inclusive)\n   */\n  readonly endNode: number;\n\n  /**\n   * The container that this node range will run\n   */\n  readonly container: IEcsContainerDefinition;\n}\n\n/**\n * Props to configure a MultiNodeJobDefinition\n */\nexport interface MultiNodeJobDefinitionProps extends JobDefinitionProps {\n  /**\n   * The instance type that this job definition\n   * will run.\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The containers that this multinode job will run.\n   *\n   * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/\n   *\n   * @default none\n   */\n  readonly containers?: MultiNodeContainer[];\n\n  /**\n   * The index of the main node in this job.\n   * The main node is responsible for orchestration.\n   *\n   * @default 0\n   */\n  readonly mainNode?: number;\n\n  /**\n   * Whether to propogate tags from the JobDefinition\n   * to the ECS task that Batch spawns\n   *\n   * @default false\n   */\n  readonly propagateTags?: boolean;\n}\n\n/**\n * A JobDefinition that uses Ecs orchestration to run multiple containers\n *\n * @resource AWS::Batch::JobDefinition\n */\nexport class MultiNodeJobDefinition extends JobDefinitionBase implements IMultiNodeJobDefinition {\n  /**\n   * refer to an existing JobDefinition by its arn\n   */\n  public static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition {\n    const stack = Stack.of(scope);\n    const jobDefinitionName = stack.splitArn(jobDefinitionArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends JobDefinitionBase implements IJobDefinition {\n      public readonly jobDefinitionArn = jobDefinitionArn;\n      public readonly jobDefinitionName = jobDefinitionName;\n      public readonly enabled = true;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly containers: MultiNodeContainer[];\n  public readonly instanceType: ec2.InstanceType;\n  public readonly mainNode?: number;\n  public readonly propagateTags?: boolean;\n\n  public readonly jobDefinitionArn: string;\n  public readonly jobDefinitionName: string;\n\n  constructor(scope: Construct, id: string, props: MultiNodeJobDefinitionProps) {\n    super(scope, id, props);\n\n    this.containers = props.containers ?? [];\n    this.mainNode = props.mainNode;\n    this.instanceType = props.instanceType;\n    this.propagateTags = props?.propagateTags;\n\n    const resource = new CfnJobDefinition(this, 'Resource', {\n      ...baseJobDefinitionProperties(this),\n      type: 'multinode',\n      jobDefinitionName: props.jobDefinitionName,\n      propagateTags: this.propagateTags,\n      nodeProperties: {\n        mainNode: this.mainNode ?? 0,\n        nodeRangeProperties: Lazy.any({\n          produce: () => this.containers.map((container) => ({\n            targetNodes: container.startNode + ':' + container.endNode,\n            container: {\n              ...container.container._renderContainerDefinition(),\n              instanceType: this.instanceType.toString(),\n            },\n          })),\n        }),\n        numNodes: Lazy.number({\n          produce: () => computeNumNodes(this.containers),\n        }),\n      },\n      platformCapabilities: [Compatibility.EC2],\n    });\n    this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, {\n      service: 'batch',\n      resource: 'job-definition',\n      resourceName: this.physicalName,\n    });\n    this.jobDefinitionName = this.getResourceNameAttribute(resource.ref);\n\n    this.node.addValidation({ validate: () => validateContainers(this.containers) });\n  }\n\n  public addContainer(container: MultiNodeContainer) {\n    this.containers.push(container);\n  }\n}\n\nfunction computeNumNodes(containers: MultiNodeContainer[]) {\n  let result = 0;\n\n  for (const container of containers) {\n    result += container.endNode - container.startNode + 1;\n  }\n\n  return result;\n}\n\nfunction validateContainers(containers: MultiNodeContainer[]): string[] {\n  return containers.length === 0 ? ['multinode job has no containers!'] : [];\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts new file mode 100644 index 0000000000000..1359eddcba414 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts @@ -0,0 +1,188 @@ +import { Duration, IResource, Resource } from 'aws-cdk-lib/core'; +import { Construct } from 'constructs'; +/** + * Represents a Scheduling Policy. Scheduling Policies tell the Batch + * Job Scheduler how to schedule incoming jobs. + */ +export interface ISchedulingPolicy extends IResource { + /** + * The name of this scheduling policy + * + * @attribute + */ + readonly schedulingPolicyName: string; + /** + * The arn of this scheduling policy + * + * @attribute + */ + readonly schedulingPolicyArn: string; +} +/** + * Props to configure a SchedulingPolicy + */ +interface SchedulingPolicyProps { + /** + * The name of this SchedulingPolicy + * + * @default - generated by CloudFormation + */ + readonly schedulingPolicyName?: string; +} +/** + * @internal + */ +export declare abstract class SchedulingPolicyBase extends Resource implements ISchedulingPolicy { + abstract readonly schedulingPolicyName: string; + abstract readonly schedulingPolicyArn: string; + constructor(scope: Construct, id: string, props?: SchedulingPolicyProps); +} +/** + * Represents a group of Job Definitions. All Job Definitions that + * declare a share identifier will be considered members of the Share + * defined by that share identifier. + * + * The Scheduler divides the maximum available vCPUs of the ComputeEnvironment + * among Jobs in the Queue based on their shareIdentifier and the weightFactor + * associated with that shareIdentifier. + */ +export interface Share { + /** + * The identifier of this Share. All jobs that specify this share identifier + * when submitted to the queue will be considered as part of this Share. + */ + readonly shareIdentifier: string; + /** + * The weight factor given to this Share. The Scheduler decides which jobs to put in the Compute Environment + * such that the following ratio is equal for each job: + * + * `sharevCpu / weightFactor`, + * + * where `sharevCpu` is the total amount of vCPU given to that particular share; that is, + * the sum of the vCPU of each job currently in the Compute Environment for that share. + * + * See the readme of this module for a detailed example that shows how these are used, + * how it relates to `computeReservation`, and how `shareDecay` affects these calculations. + */ + readonly weightFactor: number; +} +/** + * Represents a Fairshare Scheduling Policy. Instructs the scheduler + * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. + * + * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. + * It does this by deciding how many Jobs of each share to schedule *relative to how many jobs of + * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with + * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of + * fairshare policies. + */ +export interface IFairshareSchedulingPolicy extends ISchedulingPolicy { + /** + * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue. + * + * The percentage reserved is defined by the Scheduler as: + * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers. + * + * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the + * maximum available vCPU if there's only one fair share identifier. + * It reserves 25% if there are two fair share identifiers. + * It reserves 12.5% if there are three fair share identifiers. + * + * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the + * maximum available vCPU if there's only one fair share identifier, + * 6.25% if there are two fair share identifiers, + * and 1.56% if there are three fair share identifiers. + * + * @default - no vCPU is reserved + */ + readonly computeReservation?: number; + /** + * The amount of time to use to measure the usage of each job. + * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue. + * A value of zero (0) indicates that only current usage is measured. + * The decay is linear and gives preference to newer jobs. + * + * The maximum supported value is 604800 seconds (1 week). + * + * @default - 0: only the current job usage is considered + */ + readonly shareDecay?: Duration; + /** + * The shares that this Scheduling Policy applies to. + * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that + * are not recognized by the Scheduling Policy. + */ + readonly shares: Share[]; +} +/** + * Fairshare SchedulingPolicy configuration + */ +export interface FairshareSchedulingPolicyProps extends SchedulingPolicyProps { + /** + * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue. + * + * The percentage reserved is defined by the Scheduler as: + * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers. + * + * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the + * maximum available vCPU if there's only one fair share identifier. + * It reserves 25% if there are two fair share identifiers. + * It reserves 12.5% if there are three fair share identifiers. + * + * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the + * maximum available vCPU if there's only one fair share identifier, + * 6.25% if there are two fair share identifiers, + * and 1.56% if there are three fair share identifiers. + * + * @default - no vCPU is reserved + */ + readonly computeReservation?: number; + /** + * The amount of time to use to measure the usage of each job. + * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue. + * A value of zero (0) indicates that only current usage is measured. + * The decay is linear and gives preference to newer jobs. + * + * The maximum supported value is 604800 seconds (1 week). + * + * @default - 0: only the current job usage is considered + */ + readonly shareDecay?: Duration; + /** + * The shares that this Scheduling Policy applies to. + * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that + * are not recognized by the Scheduling Policy. + * + * @default - no shares + */ + readonly shares?: Share[]; +} +/** + * Represents a Fairshare Scheduling Policy. Instructs the scheduler + * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. + * + * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. + * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of + * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with + * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of + * fairshare policies. + * + * @resource AWS::Batch::SchedulingPolicy + */ +export declare class FairshareSchedulingPolicy extends SchedulingPolicyBase implements IFairshareSchedulingPolicy { + /** + * Reference an exisiting Scheduling Policy by its ARN + */ + static fromFairshareSchedulingPolicyArn(scope: Construct, id: string, fairshareSchedulingPolicyArn: string): IFairshareSchedulingPolicy; + readonly computeReservation?: number; + readonly shareDecay?: Duration; + readonly shares: Share[]; + readonly schedulingPolicyArn: string; + readonly schedulingPolicyName: string; + constructor(scope: Construct, id: string, props?: FairshareSchedulingPolicyProps); + /** + * Add a share this to this Fairshare SchedulingPolicy + */ + addShare(share: Share): void; +} +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js new file mode 100644 index 0000000000000..927263fa715f3 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js @@ -0,0 +1,101 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.FairshareSchedulingPolicy = exports.SchedulingPolicyBase = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +/** + * @internal + */ +class SchedulingPolicyBase extends core_1.Resource { + constructor(scope, id, props) { + super(scope, id, { + physicalName: props?.schedulingPolicyName, + }); + } +} +exports.SchedulingPolicyBase = SchedulingPolicyBase; +/** + * Represents a Fairshare Scheduling Policy. Instructs the scheduler + * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. + * + * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. + * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of + * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with + * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of + * fairshare policies. + * + * @resource AWS::Batch::SchedulingPolicy + */ +class FairshareSchedulingPolicy extends SchedulingPolicyBase { + /** + * Reference an exisiting Scheduling Policy by its ARN + */ + static fromFairshareSchedulingPolicyArn(scope, id, fairshareSchedulingPolicyArn) { + const stack = core_1.Stack.of(scope); + class Import extends SchedulingPolicyBase { + constructor() { + super(...arguments); + this.schedulingPolicyArn = fairshareSchedulingPolicyArn; + this.schedulingPolicyName = stack.splitArn(fairshareSchedulingPolicyArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + this.shares = []; + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, FairshareSchedulingPolicy); + } + throw error; + } + this.computeReservation = props?.computeReservation; + this.shareDecay = props?.shareDecay; + this.shares = props?.shares ?? []; + const resource = new aws_batch_1.CfnSchedulingPolicy(this, 'Resource', { + fairsharePolicy: { + computeReservation: this.computeReservation, + shareDecaySeconds: this.shareDecay?.toSeconds(), + shareDistribution: core_1.Lazy.any({ + produce: () => this.shares?.map((share) => ({ + shareIdentifier: share.shareIdentifier, + weightFactor: share.weightFactor, + })), + }), + }, + name: props?.schedulingPolicyName, + }); + this.schedulingPolicyArn = this.getResourceArnAttribute(resource.attrArn, { + service: 'batch', + resource: 'scheduling-policy', + resourceName: this.physicalName, + }); + this.schedulingPolicyName = this.getResourceNameAttribute(resource.ref); + } + /** + * Add a share this to this Fairshare SchedulingPolicy + */ + addShare(share) { + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Share(share); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, this.addShare); + } + throw error; + } + this.shares.push(share); + } +} +exports.FairshareSchedulingPolicy = FairshareSchedulingPolicy; +_a = JSII_RTTI_SYMBOL_1; +FairshareSchedulingPolicy[_a] = { fqn: "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy", version: "0.0.0" }; +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheduling-policy.js","sourceRoot":"","sources":["scheduling-policy.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAyF;AAEzF,qDAA4D;AAkC5D;;GAEG;AACH,MAAsB,oBAAqB,SAAQ,eAAQ;IAIzD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,EAAE,oBAAoB;SAC1C,CAAC,CAAC;KACJ;CACF;AATD,oDASC;AAkID;;;;;;;;;;;GAWG;AACH,MAAa,yBAA0B,SAAQ,oBAAoB;IACjE;;OAEG;IACI,MAAM,CAAC,gCAAgC,CAAC,KAAgB,EAAE,EAAU,EAAE,4BAAoC;QAC/G,MAAM,KAAK,GAAG,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,MAAO,SAAQ,oBAAoB;YAAzC;;gBACkB,wBAAmB,GAAG,4BAA4B,CAAC;gBACnD,yBAAoB,GAAG,KAAK,CAAC,QAAQ,CAAC,4BAA4B,EAAE,gBAAS,CAAC,mBAAmB,CAAC,CAAC,YAAa,CAAC;gBACjH,WAAM,GAAG,EAAE,CAAC;YAC9B,CAAC;SAAA;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IAQD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsC;QAC9E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;;;;;;+CAtBf,yBAAyB;;;;QAuBlC,IAAI,CAAC,kBAAkB,GAAG,KAAK,EAAE,kBAAkB,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,KAAK,EAAE,UAAU,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,KAAK,EAAE,MAAM,IAAI,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,+BAAmB,CAAC,IAAI,EAAE,UAAU,EAAE;YACzD,eAAe,EAAE;gBACf,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;gBAC3C,iBAAiB,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE;gBAC/C,iBAAiB,EAAE,WAAI,CAAC,GAAG,CAAC;oBAC1B,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;wBAC1C,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,YAAY,EAAE,KAAK,CAAC,YAAY;qBACjC,CAAC,CAAC;iBACJ,CAAC;aACH;YACD,IAAI,EAAE,KAAK,EAAE,oBAAoB;SAClC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,OAAO,EAAE;YACxE,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,mBAAmB;YAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;KACzE;IAED;;OAEG;IACI,QAAQ,CAAC,KAAY;;;;;;;;;;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KACzB;;AArDH,8DAsDC","sourcesContent":["import { ArnFormat, Duration, IResource, Lazy, Resource, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnSchedulingPolicy } from 'aws-cdk-lib/aws-batch';\n\n/**\n * Represents a Scheduling Policy. Scheduling Policies tell the Batch\n * Job Scheduler how to schedule incoming jobs.\n */\nexport interface ISchedulingPolicy extends IResource {\n  /**\n   * The name of this scheduling policy\n   *\n   * @attribute\n   */\n  readonly schedulingPolicyName: string\n\n  /**\n   * The arn of this scheduling policy\n   *\n   * @attribute\n   */\n  readonly schedulingPolicyArn: string;\n}\n\n/**\n * Props to configure a SchedulingPolicy\n */\ninterface SchedulingPolicyProps {\n  /**\n   * The name of this SchedulingPolicy\n   *\n   * @default - generated by CloudFormation\n   */\n  readonly schedulingPolicyName?: string;\n}\n\n/**\n * @internal\n */\nexport abstract class SchedulingPolicyBase extends Resource implements ISchedulingPolicy {\n  public abstract readonly schedulingPolicyName: string;\n  public abstract readonly schedulingPolicyArn: string;\n\n  constructor(scope: Construct, id: string, props?: SchedulingPolicyProps) {\n    super(scope, id, {\n      physicalName: props?.schedulingPolicyName,\n    });\n  }\n}\n\n/**\n * Represents a group of Job Definitions. All Job Definitions that\n * declare a share identifier will be considered members of the Share\n * defined by that share identifier.\n *\n * The Scheduler divides the maximum available vCPUs of the ComputeEnvironment\n * among Jobs in the Queue based on their shareIdentifier and the weightFactor\n * associated with that shareIdentifier.\n */\nexport interface Share {\n  /**\n   * The identifier of this Share. All jobs that specify this share identifier\n   * when submitted to the queue will be considered as part of this Share.\n   */\n  readonly shareIdentifier: string;\n\n  /**\n   * The weight factor given to this Share. The Scheduler decides which jobs to put in the Compute Environment\n   * such that the following ratio is equal for each job:\n   *\n   * `sharevCpu / weightFactor`,\n   *\n   * where `sharevCpu` is the total amount of vCPU given to that particular share; that is,\n   * the sum of the vCPU of each job currently in the Compute Environment for that share.\n   *\n   * See the readme of this module for a detailed example that shows how these are used,\n   * how it relates to `computeReservation`, and how `shareDecay` affects these calculations.\n   */\n  readonly weightFactor: number;\n}\n\n/**\n * Represents a Fairshare Scheduling Policy. Instructs the scheduler\n * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers.\n *\n * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\n * It does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\n * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with\n * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\n * fairshare policies.\n */\nexport interface IFairshareSchedulingPolicy extends ISchedulingPolicy {\n  /**\n   * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue.\n   *\n   * The percentage reserved is defined by the Scheduler as:\n   * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n   *\n   * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\n   * maximum available vCPU if there's only one fair share identifier.\n   * It reserves 25% if there are two fair share identifiers.\n   * It reserves 12.5% if there are three fair share identifiers.\n   *\n   * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\n   * maximum available vCPU if there's only one fair share identifier,\n   * 6.25% if there are two fair share identifiers,\n   * and 1.56% if there are three fair share identifiers.\n   *\n   * @default - no vCPU is reserved\n   */\n  readonly computeReservation?: number;\n\n  /**\n   * The amount of time to use to measure the usage of each job.\n   * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\n   * A value of zero (0) indicates that only current usage is measured.\n   * The decay is linear and gives preference to newer jobs.\n   *\n   * The maximum supported value is 604800 seconds (1 week).\n   *\n   * @default - 0: only the current job usage is considered\n   */\n  readonly shareDecay?: Duration;\n\n  /**\n   * The shares that this Scheduling Policy applies to.\n   * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that\n   * are not recognized by the Scheduling Policy.\n   */\n  readonly shares: Share[];\n}\n\n/**\n * Fairshare SchedulingPolicy configuration\n */\nexport interface FairshareSchedulingPolicyProps extends SchedulingPolicyProps {\n  /**\n   * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue.\n   *\n   * The percentage reserved is defined by the Scheduler as:\n   * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n   *\n   * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\n   * maximum available vCPU if there's only one fair share identifier.\n   * It reserves 25% if there are two fair share identifiers.\n   * It reserves 12.5% if there are three fair share identifiers.\n   *\n   * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\n   * maximum available vCPU if there's only one fair share identifier,\n   * 6.25% if there are two fair share identifiers,\n   * and 1.56% if there are three fair share identifiers.\n   *\n   * @default - no vCPU is reserved\n   */\n  readonly computeReservation?: number;\n\n  /**\n   * The amount of time to use to measure the usage of each job.\n   * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\n   * A value of zero (0) indicates that only current usage is measured.\n   * The decay is linear and gives preference to newer jobs.\n   *\n   * The maximum supported value is 604800 seconds (1 week).\n   *\n   * @default - 0: only the current job usage is considered\n   */\n  readonly shareDecay?: Duration;\n\n  /**\n   * The shares that this Scheduling Policy applies to.\n   * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that\n   * are not recognized by the Scheduling Policy.\n   *\n   * @default - no shares\n   */\n  readonly shares?: Share[];\n}\n\n/**\n * Represents a Fairshare Scheduling Policy. Instructs the scheduler\n * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers.\n *\n * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\n * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\n * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with\n * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\n * fairshare policies.\n *\n * @resource AWS::Batch::SchedulingPolicy\n */\nexport class FairshareSchedulingPolicy extends SchedulingPolicyBase implements IFairshareSchedulingPolicy {\n  /**\n   * Reference an exisiting Scheduling Policy by its ARN\n   */\n  public static fromFairshareSchedulingPolicyArn(scope: Construct, id: string, fairshareSchedulingPolicyArn: string): IFairshareSchedulingPolicy {\n    const stack = Stack.of(scope);\n    class Import extends SchedulingPolicyBase implements IFairshareSchedulingPolicy {\n      public readonly schedulingPolicyArn = fairshareSchedulingPolicyArn;\n      public readonly schedulingPolicyName = stack.splitArn(fairshareSchedulingPolicyArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n      public readonly shares = [];\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeReservation?: number;\n  public readonly shareDecay?: Duration;\n  public readonly shares: Share[];\n  public readonly schedulingPolicyArn: string;\n  public readonly schedulingPolicyName: string;\n\n  constructor(scope: Construct, id: string, props?: FairshareSchedulingPolicyProps) {\n    super(scope, id, props);\n    this.computeReservation = props?.computeReservation;\n    this.shareDecay = props?.shareDecay;\n    this.shares = props?.shares ?? [];\n    const resource = new CfnSchedulingPolicy(this, 'Resource', {\n      fairsharePolicy: {\n        computeReservation: this.computeReservation,\n        shareDecaySeconds: this.shareDecay?.toSeconds(),\n        shareDistribution: Lazy.any({\n          produce: () => this.shares?.map((share) => ({\n            shareIdentifier: share.shareIdentifier,\n            weightFactor: share.weightFactor,\n          })),\n        }),\n      },\n      name: props?.schedulingPolicyName,\n    });\n\n    this.schedulingPolicyArn = this.getResourceArnAttribute(resource.attrArn, {\n      service: 'batch',\n      resource: 'scheduling-policy',\n      resourceName: this.physicalName,\n    });\n    this.schedulingPolicyName = this.getResourceNameAttribute(resource.ref);\n  }\n\n  /**\n   * Add a share this to this Fairshare SchedulingPolicy\n   */\n  public addShare(share: Share) {\n    this.shares.push(share);\n  }\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts new file mode 100644 index 0000000000000..80c8be1714cae --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts @@ -0,0 +1,47 @@ +import { Construct } from 'constructs'; +import { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base'; +/** + * Represents an UnmanagedComputeEnvironment. Batch will not provision instances on your behalf + * in this ComputeEvironment. + */ +export interface IUnmanagedComputeEnvironment extends IComputeEnvironment { + /** + * The vCPUs this Compute Environment provides. Used only by the + * scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s. + * + * **If this parameter is not provided on a fairshare queue, no capacity is reserved**; + * that is, the `FairshareSchedulingPolicy` is ignored. + */ + readonly unmanagedvCPUs?: number; +} +/** + * Represents an UnmanagedComputeEnvironment. Batch will not provision instances on your behalf + * in this ComputeEvironment. + */ +export interface UnmanagedComputeEnvironmentProps extends ComputeEnvironmentProps { + /** + * The vCPUs this Compute Environment provides. Used only by the + * scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s. + * + * **If this parameter is not provided on a fairshare queue, no capacity is reserved**; + * that is, the `FairshareSchedulingPolicy` is ignored. + * + * @default 0 + */ + readonly unmanagedvCpus?: number; +} +/** + * Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf. + * + * @resource AWS::Batch::ComputeEnvironment + */ +export declare class UnmanagedComputeEnvironment extends ComputeEnvironmentBase implements IUnmanagedComputeEnvironment { + /** + * Import an UnmanagedComputeEnvironment by its arn + */ + static fromUnmanagedComputeEnvironmentArn(scope: Construct, id: string, unmanagedComputeEnvironmentArn: string): IUnmanagedComputeEnvironment; + readonly unmanagedvCPUs?: number | undefined; + readonly computeEnvironmentArn: string; + readonly computeEnvironmentName: string; + constructor(scope: Construct, id: string, props?: UnmanagedComputeEnvironmentProps); +} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js new file mode 100644 index 0000000000000..3a7d3f74798bd --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js @@ -0,0 +1,70 @@ +"use strict"; +var _a; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.UnmanagedComputeEnvironment = void 0; +const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); +const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const core_1 = require("aws-cdk-lib/core"); +const aws_batch_1 = require("aws-cdk-lib/aws-batch"); +const compute_environment_base_1 = require("./compute-environment-base"); +/** + * Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf. + * + * @resource AWS::Batch::ComputeEnvironment + */ +class UnmanagedComputeEnvironment extends compute_environment_base_1.ComputeEnvironmentBase { + /** + * Import an UnmanagedComputeEnvironment by its arn + */ + static fromUnmanagedComputeEnvironmentArn(scope, id, unmanagedComputeEnvironmentArn) { + const stack = core_1.Stack.of(scope); + const computeEnvironmentName = stack.splitArn(unmanagedComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; + class Import extends compute_environment_base_1.ComputeEnvironmentBase { + constructor() { + super(...arguments); + this.computeEnvironmentArn = unmanagedComputeEnvironmentArn; + this.computeEnvironmentName = computeEnvironmentName; + this.enabled = true; + this.containerDefinition = {}; + } + } + return new Import(scope, id); + } + constructor(scope, id, props) { + super(scope, id, props); + try { + jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps(props); + } + catch (error) { + if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { + Error.captureStackTrace(error, UnmanagedComputeEnvironment); + } + throw error; + } + this.unmanagedvCPUs = props?.unmanagedvCpus; + const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { + type: 'unmanaged', + state: this.enabled ? 'ENABLED' : 'DISABLED', + computeEnvironmentName: props?.computeEnvironmentName, + unmanagedvCpus: this.unmanagedvCPUs, + serviceRole: props?.serviceRole?.roleArn + ?? new aws_iam_1.Role(this, 'BatchServiceRole', { + managedPolicies: [ + aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSBatchServiceRole'), + ], + assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), + }).roleArn, + }); + this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); + this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { + service: 'batch', + resource: 'compute-environment', + resourceName: this.physicalName, + }); + } +} +exports.UnmanagedComputeEnvironment = UnmanagedComputeEnvironment; +_a = JSII_RTTI_SYMBOL_1; +UnmanagedComputeEnvironment[_a] = { fqn: "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment", version: "0.0.0" }; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bm1hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxpREFBNEU7QUFDNUUsMkNBQW9EO0FBRXBELHFEQUE4RDtBQUM5RCx5RUFBa0g7QUFrQ2xIOzs7O0dBSUc7QUFDSCxNQUFhLDJCQUE0QixTQUFRLGlEQUFzQjtJQUNyRTs7T0FFRztJQUNJLE1BQU0sQ0FBQyxrQ0FBa0MsQ0FDOUMsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsOEJBQXNDO1FBRXBFLE1BQU0sS0FBSyxHQUFHLFlBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsTUFBTSxzQkFBc0IsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDLDhCQUE4QixFQUFFLGdCQUFTLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxZQUFhLENBQUM7UUFFM0gsTUFBTSxNQUFPLFNBQVEsaURBQXNCO1lBQTNDOztnQkFDa0IsMEJBQXFCLEdBQUcsOEJBQThCLENBQUM7Z0JBQ3ZELDJCQUFzQixHQUFHLHNCQUFzQixDQUFDO2dCQUNoRCxZQUFPLEdBQUcsSUFBSSxDQUFDO2dCQUNmLHdCQUFtQixHQUFHLEVBQVMsQ0FBQztZQUNsRCxDQUFDO1NBQUE7UUFFRCxPQUFPLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztLQUM5QjtJQU1ELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0M7UUFDaEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7Ozs7OzsrQ0F6QmYsMkJBQTJCOzs7O1FBMkJwQyxJQUFJLENBQUMsY0FBYyxHQUFHLEtBQUssRUFBRSxjQUFjLENBQUM7UUFDNUMsTUFBTSxRQUFRLEdBQUcsSUFBSSxpQ0FBcUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQzNELElBQUksRUFBRSxXQUFXO1lBQ2pCLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFVBQVU7WUFDNUMsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLHNCQUFzQjtZQUNyRCxjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7WUFDbkMsV0FBVyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsT0FBTzttQkFDckMsSUFBSSxjQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFO29CQUNwQyxlQUFlLEVBQUU7d0JBQ2YsdUJBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxrQ0FBa0MsQ0FBQztxQkFDM0U7b0JBQ0QsU0FBUyxFQUFFLElBQUksMEJBQWdCLENBQUMscUJBQXFCLENBQUM7aUJBQ3ZELENBQUMsQ0FBQyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLHNCQUFzQixHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUUsSUFBSSxDQUFDLHFCQUFxQixHQUFHLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxRQUFRLENBQUMseUJBQXlCLEVBQUU7WUFDNUYsT0FBTyxFQUFFLE9BQU87WUFDaEIsUUFBUSxFQUFFLHFCQUFxQjtZQUMvQixZQUFZLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDaEMsQ0FBQyxDQUFDO0tBQ0o7O0FBL0NILGtFQWdEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hbmFnZWRQb2xpY3ksIFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IEFybkZvcm1hdCwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYi9jb3JlJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQ2ZuQ29tcHV0ZUVudmlyb25tZW50IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWJhdGNoJztcbmltcG9ydCB7IElDb21wdXRlRW52aXJvbm1lbnQsIENvbXB1dGVFbnZpcm9ubWVudEJhc2UsIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIH0gZnJvbSAnLi9jb21wdXRlLWVudmlyb25tZW50LWJhc2UnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50LiBCYXRjaCB3aWxsIG5vdCBwcm92aXNpb24gaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmXG4gKiBpbiB0aGlzIENvbXB1dGVFdmlyb25tZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQgZXh0ZW5kcyBJQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgLyoqXG4gICAqIFRoZSB2Q1BVcyB0aGlzIENvbXB1dGUgRW52aXJvbm1lbnQgcHJvdmlkZXMuIFVzZWQgb25seSBieSB0aGVcbiAgICogc2NoZWR1bGVyIHRvIHNjaGVkdWxlIGpvYnMgaW4gYFF1ZXVlYHMgdGhhdCB1c2UgYEZhaXJzaGFyZVNjaGVkdWxpbmdQb2xpY3lgcy5cbiAgICpcbiAgICogKipJZiB0aGlzIHBhcmFtZXRlciBpcyBub3QgcHJvdmlkZWQgb24gYSBmYWlyc2hhcmUgcXVldWUsIG5vIGNhcGFjaXR5IGlzIHJlc2VydmVkKio7XG4gICAqIHRoYXQgaXMsIHRoZSBgRmFpcnNoYXJlU2NoZWR1bGluZ1BvbGljeWAgaXMgaWdub3JlZC5cbiAgICovXG4gIHJlYWRvbmx5IHVubWFuYWdlZHZDUFVzPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50LiBCYXRjaCB3aWxsIG5vdCBwcm92aXNpb24gaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmXG4gKiBpbiB0aGlzIENvbXB1dGVFdmlyb25tZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFByb3BzIGV4dGVuZHMgQ29tcHV0ZUVudmlyb25tZW50UHJvcHMge1xuICAvKipcbiAgICogVGhlIHZDUFVzIHRoaXMgQ29tcHV0ZSBFbnZpcm9ubWVudCBwcm92aWRlcy4gVXNlZCBvbmx5IGJ5IHRoZVxuICAgKiBzY2hlZHVsZXIgdG8gc2NoZWR1bGUgam9icyBpbiBgUXVldWVgcyB0aGF0IHVzZSBgRmFpcnNoYXJlU2NoZWR1bGluZ1BvbGljeWBzLlxuICAgKlxuICAgKiAqKklmIHRoaXMgcGFyYW1ldGVyIGlzIG5vdCBwcm92aWRlZCBvbiBhIGZhaXJzaGFyZSBxdWV1ZSwgbm8gY2FwYWNpdHkgaXMgcmVzZXJ2ZWQqKjtcbiAgICogdGhhdCBpcywgdGhlIGBGYWlyc2hhcmVTY2hlZHVsaW5nUG9saWN5YCBpcyBpZ25vcmVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCAwXG4gICAqL1xuICByZWFkb25seSB1bm1hbmFnZWR2Q3B1cz86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBVbm1hbmFnZWQgQ29tcHV0ZUVudmlyb25tZW50cyBkbyBub3QgcHJvdmlzaW9uIG9yIG1hbmFnZSBFQzIgaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmLlxuICpcbiAqIEByZXNvdXJjZSBBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnRcbiAqL1xuZXhwb3J0IGNsYXNzIFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudCBleHRlbmRzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgaW1wbGVtZW50cyBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgLyoqXG4gICAqIEltcG9ydCBhbiBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQgYnkgaXRzIGFyblxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBmcm9tVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50QXJuKFxuICAgIHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudEFybjogc3RyaW5nLFxuICApOiBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgICBjb25zdCBzdGFjayA9IFN0YWNrLm9mKHNjb3BlKTtcbiAgICBjb25zdCBjb21wdXRlRW52aXJvbm1lbnROYW1lID0gc3RhY2suc3BsaXRBcm4odW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50QXJuLCBBcm5Gb3JtYXQuU0xBU0hfUkVTT1VSQ0VfTkFNRSkucmVzb3VyY2VOYW1lITtcblxuICAgIGNsYXNzIEltcG9ydCBleHRlbmRzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgaW1wbGVtZW50cyBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgICAgIHB1YmxpYyByZWFkb25seSBjb21wdXRlRW52aXJvbm1lbnRBcm4gPSB1bm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnRBcm47XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZSA9IGNvbXB1dGVFbnZpcm9ubWVudE5hbWU7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgZW5hYmxlZCA9IHRydWU7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgY29udGFpbmVyRGVmaW5pdGlvbiA9IHt9IGFzIGFueTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IEltcG9ydChzY29wZSwgaWQpO1xuICB9XG5cbiAgcHVibGljIHJlYWRvbmx5IHVubWFuYWdlZHZDUFVzPzogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICBwdWJsaWMgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBjb21wdXRlRW52aXJvbm1lbnROYW1lOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuXG4gICAgdGhpcy51bm1hbmFnZWR2Q1BVcyA9IHByb3BzPy51bm1hbmFnZWR2Q3B1cztcbiAgICBjb25zdCByZXNvdXJjZSA9IG5ldyBDZm5Db21wdXRlRW52aXJvbm1lbnQodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgdHlwZTogJ3VubWFuYWdlZCcsXG4gICAgICBzdGF0ZTogdGhpcy5lbmFibGVkID8gJ0VOQUJMRUQnIDogJ0RJU0FCTEVEJyxcbiAgICAgIGNvbXB1dGVFbnZpcm9ubWVudE5hbWU6IHByb3BzPy5jb21wdXRlRW52aXJvbm1lbnROYW1lLFxuICAgICAgdW5tYW5hZ2VkdkNwdXM6IHRoaXMudW5tYW5hZ2VkdkNQVXMsXG4gICAgICBzZXJ2aWNlUm9sZTogcHJvcHM/LnNlcnZpY2VSb2xlPy5yb2xlQXJuXG4gICAgICA/PyBuZXcgUm9sZSh0aGlzLCAnQmF0Y2hTZXJ2aWNlUm9sZScsIHtcbiAgICAgICAgbWFuYWdlZFBvbGljaWVzOiBbXG4gICAgICAgICAgTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoJ3NlcnZpY2Utcm9sZS9BV1NCYXRjaFNlcnZpY2VSb2xlJyksXG4gICAgICAgIF0sXG4gICAgICAgIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ2JhdGNoLmFtYXpvbmF3cy5jb20nKSxcbiAgICAgIH0pLnJvbGVBcm4sXG4gICAgfSk7XG4gICAgdGhpcy5jb21wdXRlRW52aXJvbm1lbnROYW1lID0gdGhpcy5nZXRSZXNvdXJjZU5hbWVBdHRyaWJ1dGUocmVzb3VyY2UucmVmKTtcbiAgICB0aGlzLmNvbXB1dGVFbnZpcm9ubWVudEFybiA9IHRoaXMuZ2V0UmVzb3VyY2VBcm5BdHRyaWJ1dGUocmVzb3VyY2UuYXR0ckNvbXB1dGVFbnZpcm9ubWVudEFybiwge1xuICAgICAgc2VydmljZTogJ2JhdGNoJyxcbiAgICAgIHJlc291cmNlOiAnY29tcHV0ZS1lbnZpcm9ubWVudCcsXG4gICAgICByZXNvdXJjZU5hbWU6IHRoaXMucGh5c2ljYWxOYW1lLFxuICAgIH0pO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js new file mode 100644 index 0000000000000..26f4d2b7fface --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js @@ -0,0 +1,294 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const batch = require("../../lib"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const assertions_1 = require("aws-cdk-lib/assertions"); +const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); +const events = require("aws-cdk-lib/aws-events"); +const targets = require("aws-cdk-lib/aws-events-targets"); +const sqs = require("aws-cdk-lib/aws-sqs"); +describe('Batch job event target', () => { + let stack; + let jobQueue; + let jobDefinition; + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + jobQueue = new batch.JobQueue(stack, 'MyQueue', { + computeEnvironments: [ + { + computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'), + order: 1, + }, + ], + }); + jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', { + container: new batch.EcsEc2ContainerDefinition(stack, 'container', { + image: aws_ecs_1.ContainerImage.fromRegistry('test-repo'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + }); + test('use aws batch job as an event rule target', () => { + // GIVEN + const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 min)'), + }); + // WHEN + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition)); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { + ScheduleExpression: 'rate(1 min)', + State: 'ENABLED', + Targets: [ + { + Arn: { + 'Fn::GetAtt': [ + 'MyQueueE6CA6235', + 'JobQueueArn', + ], + }, + Id: 'Target0', + RoleArn: { + 'Fn::GetAtt': [ + 'MyJobEventsRoleCF43C336', + 'Arn', + ], + }, + BatchParameters: { + JobDefinition: { + Ref: 'MyJob8719E923', + }, + JobName: 'Rule', + }, + }, + ], + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [ + { + Action: 'batch:SubmitJob', + Effect: 'Allow', + Resource: [ + { Ref: 'MyJob8719E923' }, + { + 'Fn::GetAtt': [ + 'MyQueueE6CA6235', + 'JobQueueArn', + ], + }, + ], + }, + ], + Version: '2012-10-17', + }, + Roles: [ + { Ref: 'MyJobEventsRoleCF43C336' }, + ], + }); + }); + test('use a Dead Letter Queue for the rule target', () => { + // GIVEN + const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 hour)'), + }); + const queue = new sqs.Queue(stack, 'Queue'); + // WHEN + const eventInput = { + buildspecOverride: 'buildspecs/hourly.yml', + }; + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { + deadLetterQueue: queue, + event: events.RuleTargetInput.fromObject(eventInput), + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { + Targets: [ + { + Arn: { + 'Fn::GetAtt': [ + 'MyQueueE6CA6235', + 'JobQueueArn', + ], + }, + Id: 'Target0', + DeadLetterConfig: { + Arn: { + 'Fn::GetAtt': [ + 'Queue4A7E3555', + 'Arn', + ], + }, + }, + Input: JSON.stringify(eventInput), + RoleArn: { + 'Fn::GetAtt': ['MyJobEventsRoleCF43C336', 'Arn'], + }, + BatchParameters: { + JobDefinition: { + Ref: 'MyJob8719E923', + }, + JobName: 'Rule', + }, + }, + ], + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::SQS::QueuePolicy', { + PolicyDocument: { + Statement: [ + { + Action: 'sqs:SendMessage', + Condition: { + ArnEquals: { + 'aws:SourceArn': { + 'Fn::GetAtt': [ + 'Rule4C995B7F', + 'Arn', + ], + }, + }, + }, + Effect: 'Allow', + Principal: { + Service: 'events.amazonaws.com', + }, + Resource: { + 'Fn::GetAtt': [ + 'Queue4A7E3555', + 'Arn', + ], + }, + Sid: 'AllowEventRuleRule', + }, + ], + Version: '2012-10-17', + }, + Queues: [ + { + Ref: 'Queue4A7E3555', + }, + ], + }); + }); + test('specifying retry policy', () => { + // GIVEN + const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 hour)'), + }); + const queue = new sqs.Queue(stack, 'Queue'); + // WHEN + const eventInput = { + buildspecOverride: 'buildspecs/hourly.yml', + }; + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { + deadLetterQueue: queue, + event: events.RuleTargetInput.fromObject(eventInput), + retryAttempts: 2, + maxEventAge: aws_cdk_lib_1.Duration.hours(2), + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { + ScheduleExpression: 'rate(1 hour)', + State: 'ENABLED', + Targets: [ + { + Arn: { + 'Fn::GetAtt': [ + 'MyQueueE6CA6235', + 'JobQueueArn', + ], + }, + BatchParameters: { + JobDefinition: { + Ref: 'MyJob8719E923', + }, + JobName: 'Rule', + }, + DeadLetterConfig: { + Arn: { + 'Fn::GetAtt': [ + 'Queue4A7E3555', + 'Arn', + ], + }, + }, + Id: 'Target0', + Input: JSON.stringify(eventInput), + RetryPolicy: { + MaximumEventAgeInSeconds: 7200, + MaximumRetryAttempts: 2, + }, + RoleArn: { + 'Fn::GetAtt': [ + 'MyJobEventsRoleCF43C336', + 'Arn', + ], + }, + }, + ], + }); + }); + test('specifying retry policy with 0 retryAttempts', () => { + // GIVEN + const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 hour)'), + }); + // WHEN + const eventInput = { + buildspecOverride: 'buildspecs/hourly.yml', + }; + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { + event: events.RuleTargetInput.fromObject(eventInput), + retryAttempts: 0, + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { + ScheduleExpression: 'rate(1 hour)', + State: 'ENABLED', + Targets: [ + { + Arn: { + 'Fn::GetAtt': [ + 'MyQueueE6CA6235', + 'JobQueueArn', + ], + }, + BatchParameters: { + JobDefinition: { + Ref: 'MyJob8719E923', + }, + JobName: 'Rule', + }, + Id: 'Target0', + Input: JSON.stringify(eventInput), + RetryPolicy: { + MaximumRetryAttempts: 0, + }, + RoleArn: { + 'Fn::GetAtt': [ + 'MyJobEventsRoleCF43C336', + 'Arn', + ], + }, + }, + ], + }); + }); + test('should validate jobName minimum and maximum length', () => { + const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 min)'), + }); + expect(() => { + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { + jobName: '', + })); + }).toThrowError(/must have length between 1 and 128/); + expect(() => { + rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { + jobName: 'a'.repeat(200), + })); + }).toThrowError(/must have length between 1 and 128/); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"batch.test.js","sourceRoot":"","sources":["batch.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as batch from '../../lib';\nimport { Duration, Size, Stack } from 'aws-cdk-lib';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport { ContainerImage } from 'aws-cdk-lib/aws-ecs';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as sqs from 'aws-cdk-lib/aws-sqs';\n\ndescribe('Batch job event target', () => {\n  let stack: Stack;\n  let jobQueue: batch.IJobQueue;\n  let jobDefinition: batch.IJobDefinition;\n\n  beforeEach(() => {\n    stack = new Stack();\n    jobQueue = new batch.JobQueue(stack, 'MyQueue', {\n      computeEnvironments: [\n        {\n          computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'),\n          order: 1,\n        },\n      ],\n    });\n    jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', {\n      container: new batch.EcsEc2ContainerDefinition(stack, 'container', {\n        image: ContainerImage.fromRegistry('test-repo'),\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n      }),\n    });\n  });\n\n  test('use aws batch job as an event rule target', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 min)'),\n    });\n\n    // WHEN\n    rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 min)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          Id: 'Target0',\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n        },\n      ],\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: 'batch:SubmitJob',\n            Effect: 'Allow',\n            Resource: [\n              { Ref: 'MyJob8719E923' },\n              {\n                'Fn::GetAtt': [\n                  'MyQueueE6CA6235',\n                  'JobQueueArn',\n                ],\n              },\n            ],\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      Roles: [\n        { Ref: 'MyJobEventsRoleCF43C336' },\n      ],\n    });\n  });\n\n  test('use a Dead Letter Queue for the rule target', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    const queue = new sqs.Queue(stack, 'Queue');\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        deadLetterQueue: queue,\n        event: events.RuleTargetInput.fromObject(eventInput),\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          Id: 'Target0',\n          DeadLetterConfig: {\n            Arn: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n          },\n          Input: JSON.stringify(eventInput),\n          RoleArn: {\n            'Fn::GetAtt': ['MyJobEventsRoleCF43C336', 'Arn'],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n        },\n      ],\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::SQS::QueuePolicy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: 'sqs:SendMessage',\n            Condition: {\n              ArnEquals: {\n                'aws:SourceArn': {\n                  'Fn::GetAtt': [\n                    'Rule4C995B7F',\n                    'Arn',\n                  ],\n                },\n              },\n            },\n            Effect: 'Allow',\n            Principal: {\n              Service: 'events.amazonaws.com',\n            },\n            Resource: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n            Sid: 'AllowEventRuleRule',\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      Queues: [\n        {\n          Ref: 'Queue4A7E3555',\n        },\n      ],\n    });\n  });\n\n  test('specifying retry policy', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    const queue = new sqs.Queue(stack, 'Queue');\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        deadLetterQueue: queue,\n        event: events.RuleTargetInput.fromObject(eventInput),\n        retryAttempts: 2,\n        maxEventAge: Duration.hours(2),\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 hour)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n          DeadLetterConfig: {\n            Arn: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n          },\n          Id: 'Target0',\n          Input: JSON.stringify(eventInput),\n          RetryPolicy: {\n            MaximumEventAgeInSeconds: 7200,\n            MaximumRetryAttempts: 2,\n          },\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n        },\n      ],\n    });\n  });\n\n  test('specifying retry policy with 0 retryAttempts', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        event: events.RuleTargetInput.fromObject(eventInput),\n        retryAttempts: 0,\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 hour)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n          Id: 'Target0',\n          Input: JSON.stringify(eventInput),\n          RetryPolicy: {\n            MaximumRetryAttempts: 0,\n          },\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n        },\n      ],\n    });\n  });\n\n  test('should validate jobName minimum and maximum length', () => {\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 min)'),\n    });\n\n    expect(() => {\n      rule.addTarget(\n        new targets.BatchJob(\n          jobQueue.jobQueueArn,\n          jobQueue,\n          jobDefinition.jobDefinitionArn,\n          jobDefinition,\n          {\n            jobName: '',\n          },\n        ),\n      );\n    }).toThrowError(/must have length between 1 and 128/);\n    expect(() => {\n      rule.addTarget(\n        new targets.BatchJob(\n          jobQueue.jobQueueArn,\n          jobQueue,\n          jobDefinition.jobDefinitionArn,\n          jobDefinition,\n          {\n            jobName: 'a'.repeat(200),\n          },\n        ),\n      );\n    }).toThrowError(/must have length between 1 and 128/);\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js new file mode 100644 index 0000000000000..0ed0f7a77b1ed --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js @@ -0,0 +1,286 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const path = require("path"); +const batch = require("../../lib"); +const cdk_build_tools_1 = require("@aws-cdk/cdk-build-tools"); +const cdk = require("aws-cdk-lib"); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const sfn = require("aws-cdk-lib/aws-stepfunctions"); +const tasks = require("aws-cdk-lib/aws-stepfunctions-tasks"); +let stack; +let batchJobDefinition; +let batchJobQueue; +beforeEach(() => { + // GIVEN + stack = new cdk.Stack(); + batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', { + container: new batch.EcsEc2ContainerDefinition(stack, 'Container', { + image: ecs.ContainerImage.fromAsset(path.join(__dirname, '../batchjob-image')), + cpu: 256, + memory: cdk.Size.mebibytes(2048), + }), + }); + batchJobQueue = new batch.JobQueue(stack, 'JobQueue', { + computeEnvironments: [ + { + order: 1, + computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', { + vpc: new ec2.Vpc(stack, 'vpc'), + }), + }, + ], + }); +}); +(0, cdk_build_tools_1.describeDeprecated)('RunBatchJob', () => { + test('Task with only the required parameters', () => { + // WHEN + const task = new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + }), + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, + JobName: 'JobName', + JobQueue: { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + }, + }); + }); + test('Task with all the parameters', () => { + // WHEN + const task = new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 15, + containerOverrides: { + command: ['sudo', 'rm'], + environment: { key: 'value' }, + instanceType: new ec2.InstanceType('MULTI'), + memory: 1024, + gpuCount: 1, + vcpus: 10, + }, + dependsOn: [{ jobId: '1234', type: 'some_type' }], + payload: { + foo: sfn.JsonPath.stringAt('$.bar'), + }, + attempts: 3, + timeout: cdk.Duration.seconds(60), + integrationPattern: sfn.ServiceIntegrationPattern.FIRE_AND_FORGET, + }), + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob', + ], + ], + }, + End: true, + Parameters: { + JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, + JobName: 'JobName', + JobQueue: { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + ArrayProperties: { Size: 15 }, + ContainerOverrides: { + Command: ['sudo', 'rm'], + Environment: [{ Name: 'key', Value: 'value' }], + InstanceType: 'MULTI', + Memory: 1024, + ResourceRequirements: [{ Type: 'GPU', Value: '1' }], + Vcpus: 10, + }, + DependsOn: [{ JobId: '1234', Type: 'some_type' }], + Parameters: { 'foo.$': '$.bar' }, + RetryStrategy: { Attempts: 3 }, + Timeout: { AttemptDurationSeconds: 60 }, + }, + }); + }); + test('supports tokens', () => { + // WHEN + const task = new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobQueueArn: batchJobQueue.jobQueueArn, + jobName: sfn.JsonPath.stringAt('$.jobName'), + arraySize: sfn.JsonPath.numberAt('$.arraySize'), + timeout: cdk.Duration.seconds(sfn.JsonPath.numberAt('$.timeout')), + attempts: sfn.JsonPath.numberAt('$.attempts'), + }), + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, + 'JobName.$': '$.jobName', + 'JobQueue': { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + 'ArrayProperties': { + 'Size.$': '$.arraySize', + }, + 'RetryStrategy': { + 'Attempts.$': '$.attempts', + }, + 'Timeout': { + 'AttemptDurationSeconds.$': '$.timeout', + }, + }, + }); + }); + test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + integrationPattern: sfn.ServiceIntegrationPattern.WAIT_FOR_TASK_TOKEN, + }), + }); + }).toThrow(/Invalid Service Integration Pattern: WAIT_FOR_TASK_TOKEN is not supported to call RunBatchJob./i); + }); + test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + containerOverrides: { + environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' }, + }, + }), + }); + }).toThrow(/Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./i); + }); + test('Task throws if arraySize is out of limits 2-10000', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 1, + }), + }); + }).toThrow(/arraySize must be between 2 and 10,000/); + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 10001, + }), + }); + }).toThrow(/arraySize must be between 2 and 10,000/); + }); + test('Task throws if dependencies exceeds 20', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + dependsOn: [...Array(21).keys()].map(i => ({ + jobId: `${i}`, + type: `some_type-${i}`, + })), + }), + }); + }).toThrow(/dependencies must be 20 or less/); + }); + test('Task throws if attempts is out of limits 1-10', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + attempts: 0, + }), + }); + }).toThrow(/attempts must be between 1 and 10/); + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + attempts: 11, + }), + }); + }).toThrow(/attempts must be between 1 and 10/); + }); + test('Task throws if timeout is less than 60 sec', () => { + expect(() => { + new sfn.Task(stack, 'Task', { + task: new tasks.RunBatchJob({ + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + timeout: cdk.Duration.seconds(59), + }), + }); + }).toThrow(/timeout must be greater than 60 seconds/); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-batch-job.test.js","sourceRoot":"","sources":["run-batch-job.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as batch from '../../lib';\nimport { describeDeprecated } from '@aws-cdk/cdk-build-tools';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\n\nlet stack: cdk.Stack;\nlet batchJobDefinition: batch.IJobDefinition;\nlet batchJobQueue: batch.IJobQueue;\n\nbeforeEach(() => {\n  // GIVEN\n  stack = new cdk.Stack();\n\n  batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', {\n    container: new batch.EcsEc2ContainerDefinition(stack, 'Container', {\n      image: ecs.ContainerImage.fromAsset(\n        path.join(__dirname, '../batchjob-image'),\n      ),\n      cpu: 256,\n      memory: cdk.Size.mebibytes(2048),\n    }),\n  });\n\n  batchJobQueue = new batch.JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [\n      {\n        order: 1,\n        computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', {\n          vpc: new ec2.Vpc(stack, 'vpc'),\n        }),\n      },\n    ],\n  });\n});\n\ndescribeDeprecated('RunBatchJob', () => {\n  test('Task with only the required parameters', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobName: 'JobName',\n        jobQueueArn: batchJobQueue.jobQueueArn,\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob.sync',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n        JobName: 'JobName',\n        JobQueue: {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n      },\n    });\n  });\n\n  test('Task with all the parameters', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobName: 'JobName',\n        jobQueueArn: batchJobQueue.jobQueueArn,\n        arraySize: 15,\n        containerOverrides: {\n          command: ['sudo', 'rm'],\n          environment: { key: 'value' },\n          instanceType: new ec2.InstanceType('MULTI'),\n          memory: 1024,\n          gpuCount: 1,\n          vcpus: 10,\n        },\n        dependsOn: [{ jobId: '1234', type: 'some_type' }],\n        payload: {\n          foo: sfn.JsonPath.stringAt('$.bar'),\n        },\n        attempts: 3,\n        timeout: cdk.Duration.seconds(60),\n        integrationPattern: sfn.ServiceIntegrationPattern.FIRE_AND_FORGET,\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n        JobName: 'JobName',\n        JobQueue: {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n        ArrayProperties: { Size: 15 },\n        ContainerOverrides: {\n          Command: ['sudo', 'rm'],\n          Environment: [{ Name: 'key', Value: 'value' }],\n          InstanceType: 'MULTI',\n          Memory: 1024,\n          ResourceRequirements: [{ Type: 'GPU', Value: '1' }],\n          Vcpus: 10,\n        },\n        DependsOn: [{ JobId: '1234', Type: 'some_type' }],\n        Parameters: { 'foo.$': '$.bar' },\n        RetryStrategy: { Attempts: 3 },\n        Timeout: { AttemptDurationSeconds: 60 },\n      },\n    });\n  });\n\n  test('supports tokens', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobQueueArn: batchJobQueue.jobQueueArn,\n        jobName: sfn.JsonPath.stringAt('$.jobName'),\n        arraySize: sfn.JsonPath.numberAt('$.arraySize'),\n        timeout: cdk.Duration.seconds(sfn.JsonPath.numberAt('$.timeout')),\n        attempts: sfn.JsonPath.numberAt('$.attempts'),\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob.sync',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n        'JobName.$': '$.jobName',\n        'JobQueue': {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n        'ArrayProperties': {\n          'Size.$': '$.arraySize',\n        },\n        'RetryStrategy': {\n          'Attempts.$': '$.attempts',\n        },\n        'Timeout': {\n          'AttemptDurationSeconds.$': '$.timeout',\n        },\n      },\n    });\n  });\n\n  test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          integrationPattern: sfn.ServiceIntegrationPattern.WAIT_FOR_TASK_TOKEN,\n        }),\n      });\n    }).toThrow(\n      /Invalid Service Integration Pattern: WAIT_FOR_TASK_TOKEN is not supported to call RunBatchJob./i,\n    );\n  });\n\n  test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          containerOverrides: {\n            environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' },\n          },\n        }),\n      });\n    }).toThrow(\n      /Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./i,\n    );\n  });\n\n  test('Task throws if arraySize is out of limits 2-10000', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          arraySize: 1,\n        }),\n      });\n    }).toThrow(\n      /arraySize must be between 2 and 10,000/,\n    );\n\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          arraySize: 10001,\n        }),\n      });\n    }).toThrow(\n      /arraySize must be between 2 and 10,000/,\n    );\n  });\n\n  test('Task throws if dependencies exceeds 20', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          dependsOn: [...Array(21).keys()].map(i => ({\n            jobId: `${i}`,\n            type: `some_type-${i}`,\n          })),\n        }),\n      });\n    }).toThrow(\n      /dependencies must be 20 or less/,\n    );\n  });\n\n  test('Task throws if attempts is out of limits 1-10', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          attempts: 0,\n        }),\n      });\n    }).toThrow(\n      /attempts must be between 1 and 10/,\n    );\n\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          attempts: 11,\n        }),\n      });\n    }).toThrow(\n      /attempts must be between 1 and 10/,\n    );\n  });\n\n  test('Task throws if timeout is less than 60 sec', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          timeout: cdk.Duration.seconds(59),\n        }),\n      });\n    }).toThrow(\n      /timeout must be greater than 60 seconds/,\n    );\n  });\n});"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js new file mode 100644 index 0000000000000..8387351204073 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js @@ -0,0 +1,401 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const path = require("path"); +const batch = require("../../lib"); +const cdk = require("aws-cdk-lib"); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const sfn = require("aws-cdk-lib/aws-stepfunctions"); +const aws_stepfunctions_tasks_1 = require("aws-cdk-lib/aws-stepfunctions-tasks"); +let stack; +let batchJobDefinition; +let batchJobQueue; +beforeEach(() => { + // GIVEN + stack = new cdk.Stack(); + batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', { + container: new batch.EcsEc2ContainerDefinition(stack, 'Container', { + image: ecs.ContainerImage.fromAsset(path.join(__dirname, '../batchjob-image')), + cpu: 256, + memory: cdk.Size.mebibytes(2048), + }), + }); + batchJobQueue = new batch.JobQueue(stack, 'JobQueue', { + computeEnvironments: [ + { + order: 1, + computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', { + vpc: new ec2.Vpc(stack, 'vpc'), + }), + }, + ], + }); +}); +test('Task with only the required parameters', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, + JobName: 'JobName', + JobQueue: { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + }, + }); +}); +test('Task with all the parameters', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 15, + containerOverrides: { + command: ['sudo', 'rm'], + environment: { key: 'value' }, + instanceType: new ec2.InstanceType('MULTI'), + memory: cdk.Size.mebibytes(1024), + gpuCount: 1, + vcpus: 10, + }, + dependsOn: [{ jobId: '1234', type: 'some_type' }], + payload: sfn.TaskInput.fromObject({ + foo: sfn.JsonPath.stringAt('$.bar'), + }), + attempts: 3, + taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(60)), + integrationPattern: sfn.IntegrationPattern.REQUEST_RESPONSE, + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob', + ], + ], + }, + End: true, + Parameters: { + JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, + JobName: 'JobName', + JobQueue: { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + ArrayProperties: { Size: 15 }, + ContainerOverrides: { + Command: ['sudo', 'rm'], + Environment: [{ Name: 'key', Value: 'value' }], + InstanceType: 'MULTI', + ResourceRequirements: [{ Type: 'GPU', Value: '1' }, { Type: 'MEMORY', Value: '1024' }, { Type: 'VCPU', Value: '10' }], + }, + DependsOn: [{ JobId: '1234', Type: 'some_type' }], + Parameters: { 'foo.$': '$.bar' }, + RetryStrategy: { Attempts: 3 }, + Timeout: { AttemptDurationSeconds: 60 }, + }, + }); +}); +test('supports tokens', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobName: sfn.JsonPath.stringAt('$.jobName'), + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: sfn.JsonPath.numberAt('$.arraySize'), + taskTimeout: sfn.Timeout.at('$.timeout'), + attempts: sfn.JsonPath.numberAt('$.attempts'), + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, + 'JobName.$': '$.jobName', + 'JobQueue': { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + 'ArrayProperties': { + 'Size.$': '$.arraySize', + }, + 'RetryStrategy': { + 'Attempts.$': '$.attempts', + }, + 'Timeout': { + 'AttemptDurationSeconds.$': '$.timeout', + }, + }, + }); +}); +test('container overrides are tokens', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + containerOverrides: { + memory: cdk.Size.mebibytes(sfn.JsonPath.numberAt('$.asdf')), + }, + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':states:::batch:submitJob.sync']] }, + End: true, + Parameters: { + JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, + JobName: 'JobName', + JobQueue: { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + ContainerOverrides: { + ResourceRequirements: [{ 'Type': 'MEMORY', 'Value.$': '$.asdf' }], + }, + }, + }); +}); +test('supports passing task input into payload', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobQueueArn: batchJobQueue.jobQueueArn, + jobName: sfn.JsonPath.stringAt('$.jobName'), + payload: sfn.TaskInput.fromJsonPathAt('$.foo'), + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, + 'JobName.$': '$.jobName', + 'JobQueue': { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + 'Parameters.$': '$.foo', + }, + }); +}); +test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN, + }); + }).toThrow(/Unsupported service integration pattern. Supported Patterns: REQUEST_RESPONSE,RUN_JOB. Received: WAIT_FOR_TASK_TOKEN/); +}); +test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + containerOverrides: { + environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' }, + }, + }); + }).toThrow(/Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./); +}); +test('Task throws if arraySize is out of limits 2-10000', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 1, + }); + }).toThrow(/arraySize must be between 2 and 10,000/); + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + arraySize: 10001, + }); + }).toThrow(/arraySize must be between 2 and 10,000/); +}); +test('Task throws if dependencies exceeds 20', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + dependsOn: [...Array(21).keys()].map(i => ({ + jobId: `${i}`, + type: `some_type-${i}`, + })), + }); + }).toThrow(/dependencies must be 20 or less/); +}); +test('Task throws if attempts is out of limits 1-10', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + attempts: 0, + }); + }).toThrow(/attempts must be between 1 and 10/); + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + attempts: 11, + }); + }).toThrow(/attempts must be between 1 and 10/); +}); +test('Task throws if attempt duration is less than 60 sec', () => { + expect(() => { + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(59)), + }); + }).toThrow(/attempt duration must be greater than 60 seconds./); +}); +test('supports passing tags', () => { + // WHEN + const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobQueueArn: batchJobQueue.jobQueueArn, + jobName: sfn.JsonPath.stringAt('$.jobName'), + tags: { + test: 'this is a tag', + }, + }); + // THEN + expect(stack.resolve(task.toStateJson())).toEqual({ + Type: 'Task', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':states:::batch:submitJob.sync', + ], + ], + }, + End: true, + Parameters: { + 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, + 'JobName.$': '$.jobName', + 'JobQueue': { + 'Fn::GetAtt': [ + 'JobQueueEE3AD499', + 'JobQueueArn', + ], + }, + 'Tags': { + test: 'this is a tag', + }, + }, + }); +}); +test('throws if tags has invalid value', () => { + expect(() => { + const tags = {}; + for (let i = 0; i < 100; i++) { + tags[i] = 'tag'; + } + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task1', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + tags, + }); + }).toThrow(/Maximum tag number of entries is 50./); + expect(() => { + const keyTooLong = 'k'.repeat(150); + const tags = {}; + tags[keyTooLong] = 'tag'; + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + tags, + }); + }).toThrow(/Tag key size must be between 1 and 128/); + expect(() => { + const tags = { key: 'k'.repeat(300) }; + new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task3', { + jobDefinitionArn: batchJobDefinition.jobDefinitionArn, + jobName: 'JobName', + jobQueueArn: batchJobQueue.jobQueueArn, + tags, + }); + }).toThrow(/Tag value maximum size is 256/); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"submit-job.test.js","sourceRoot":"","sources":["submit-job.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as batch from '../../lib';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport { BatchSubmitJob } from 'aws-cdk-lib/aws-stepfunctions-tasks';\n\nlet stack: cdk.Stack;\nlet batchJobDefinition: batch.IJobDefinition;\nlet batchJobQueue: batch.IJobQueue;\n\nbeforeEach(() => {\n  // GIVEN\n  stack = new cdk.Stack();\n\n  batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', {\n    container: new batch.EcsEc2ContainerDefinition(stack, 'Container', {\n      image: ecs.ContainerImage.fromAsset(\n        path.join(__dirname, '../batchjob-image'),\n      ),\n      cpu: 256,\n      memory: cdk.Size.mebibytes(2048),\n    }),\n  });\n\n  batchJobQueue = new batch.JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [\n      {\n        order: 1,\n        computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', {\n          vpc: new ec2.Vpc(stack, 'vpc'),\n        }),\n      },\n    ],\n  });\n});\n\ntest('Task with only the required parameters', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n    },\n  });\n});\n\ntest('Task with all the parameters', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    arraySize: 15,\n    containerOverrides: {\n      command: ['sudo', 'rm'],\n      environment: { key: 'value' },\n      instanceType: new ec2.InstanceType('MULTI'),\n      memory: cdk.Size.mebibytes(1024),\n      gpuCount: 1,\n      vcpus: 10,\n    },\n    dependsOn: [{ jobId: '1234', type: 'some_type' }],\n    payload: sfn.TaskInput.fromObject({\n      foo: sfn.JsonPath.stringAt('$.bar'),\n    }),\n    attempts: 3,\n    taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(60)),\n    integrationPattern: sfn.IntegrationPattern.REQUEST_RESPONSE,\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      ArrayProperties: { Size: 15 },\n      ContainerOverrides: {\n        Command: ['sudo', 'rm'],\n        Environment: [{ Name: 'key', Value: 'value' }],\n        InstanceType: 'MULTI',\n        ResourceRequirements: [{ Type: 'GPU', Value: '1' }, { Type: 'MEMORY', Value: '1024' }, { Type: 'VCPU', Value: '10' }],\n      },\n      DependsOn: [{ JobId: '1234', Type: 'some_type' }],\n      Parameters: { 'foo.$': '$.bar' },\n      RetryStrategy: { Attempts: 3 },\n      Timeout: { AttemptDurationSeconds: 60 },\n    },\n  });\n});\n\ntest('supports tokens', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    arraySize: sfn.JsonPath.numberAt('$.arraySize'),\n    taskTimeout: sfn.Timeout.at('$.timeout'),\n    attempts: sfn.JsonPath.numberAt('$.attempts'),\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'ArrayProperties': {\n        'Size.$': '$.arraySize',\n      },\n      'RetryStrategy': {\n        'Attempts.$': '$.attempts',\n      },\n      'Timeout': {\n        'AttemptDurationSeconds.$': '$.timeout',\n      },\n    },\n  });\n});\n\ntest('container overrides are tokens', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    containerOverrides: {\n      memory: cdk.Size.mebibytes(sfn.JsonPath.numberAt('$.asdf')),\n    },\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':states:::batch:submitJob.sync']] },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      ContainerOverrides: {\n        ResourceRequirements: [{ 'Type': 'MEMORY', 'Value.$': '$.asdf' }],\n      },\n    },\n  });\n});\n\ntest('supports passing task input into payload', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    payload: sfn.TaskInput.fromJsonPathAt('$.foo'),\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'Parameters.$': '$.foo',\n    },\n  });\n});\n\ntest('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN,\n    });\n  }).toThrow(\n    /Unsupported service integration pattern. Supported Patterns: REQUEST_RESPONSE,RUN_JOB. Received: WAIT_FOR_TASK_TOKEN/,\n  );\n});\n\ntest('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      containerOverrides: {\n        environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' },\n      },\n    });\n  }).toThrow(\n    /Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./,\n  );\n});\n\ntest('Task throws if arraySize is out of limits 2-10000', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      arraySize: 1,\n    });\n  }).toThrow(\n    /arraySize must be between 2 and 10,000/,\n  );\n\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      arraySize: 10001,\n    });\n  }).toThrow(\n    /arraySize must be between 2 and 10,000/,\n  );\n});\n\ntest('Task throws if dependencies exceeds 20', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      dependsOn: [...Array(21).keys()].map(i => ({\n        jobId: `${i}`,\n        type: `some_type-${i}`,\n      })),\n    });\n  }).toThrow(\n    /dependencies must be 20 or less/,\n  );\n});\n\ntest('Task throws if attempts is out of limits 1-10', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      attempts: 0,\n    });\n  }).toThrow(\n    /attempts must be between 1 and 10/,\n  );\n\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      attempts: 11,\n    });\n  }).toThrow(\n    /attempts must be between 1 and 10/,\n  );\n});\n\ntest('Task throws if attempt duration is less than 60 sec', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(59)),\n    });\n  }).toThrow(\n    /attempt duration must be greater than 60 seconds./,\n  );\n});\n\ntest('supports passing tags', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    tags: {\n      test: 'this is a tag',\n    },\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'Tags': {\n        test: 'this is a tag',\n      },\n    },\n  });\n});\n\ntest('throws if tags has invalid value', () => {\n  expect(() => {\n    const tags: { [key: string]: string } = {};\n    for (let i = 0; i < 100; i++) {\n      tags[i] = 'tag';\n    }\n    new BatchSubmitJob(stack, 'Task1', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Maximum tag number of entries is 50./,\n  );\n\n  expect(() => {\n    const keyTooLong = 'k'.repeat(150);\n    const tags: { [key: string]: string } = {};\n    tags[keyTooLong] = 'tag';\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Tag key size must be between 1 and 128/,\n  );\n\n  expect(() => {\n    const tags = { key: 'k'.repeat(300) };\n    new BatchSubmitJob(stack, 'Task3', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Tag value maximum size is 256/,\n  );\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js new file mode 100644 index 0000000000000..d49b37fb9a85a --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js @@ -0,0 +1,998 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const path = require("path"); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const ecr = require("aws-cdk-lib/aws-ecr"); +const efs = require("aws-cdk-lib/aws-efs"); +const ssm = require("aws-cdk-lib/aws-ssm"); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const logs = require("aws-cdk-lib/aws-logs"); +const secretsmanager = require("aws-cdk-lib/aws-secretsmanager"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const cdk = require("aws-cdk-lib"); +const lib_1 = require("../lib"); +const utils_1 = require("./utils"); +const aws_ecr_assets_1 = require("aws-cdk-lib/aws-ecr-assets"); +// GIVEN +const defaultContainerProps = { + cpu: 256, + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + memory: aws_cdk_lib_1.Size.mebibytes(2048), +}; +const defaultExpectedProps = { + type: 'container', + containerProperties: { + image: 'amazon/amazon-ecs-sample', + resourceRequirements: [ + { + type: 'MEMORY', + value: '2048', + }, + { + type: 'VCPU', + value: '256', + }, + ], + }, +}; +let stack; +let pascalCaseExpectedProps; +describe.each([lib_1.EcsEc2ContainerDefinition, lib_1.EcsFargateContainerDefinition])('%p', (ContainerDefinition) => { + // GIVEN + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { + ...defaultExpectedProps, + containerProperties: { + ...defaultExpectedProps.containerProperties, + executionRoleArn: { + 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], + }, + }, + }); + }); + test('ecs container defaults', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ExecutionRoleArn: { + 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], + }, + ...pascalCaseExpectedProps.ContainerProperties, + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + AssumeRolePolicyDocument: { + Statement: [ + { + Action: 'sts:AssumeRole', + Effect: 'Allow', + Principal: { Service: 'ecs-tasks.amazonaws.com' }, + }, + ], + Version: '2012-10-17', + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [ + { + Action: [ + 'logs:CreateLogStream', + 'logs:PutLogEvents', + ], + Effect: 'Allow', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { Ref: 'AWS::Partition' }, + ':logs:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':log-group:/aws/batch/job:*', + ], + ], + }, + }, + ], + Version: '2012-10-17', + }, + PolicyName: 'EcsContainerExecutionRoleDefaultPolicy6F59CD37', + Roles: [{ + Ref: 'EcsContainerExecutionRole3B199293', + }], + }); + }); + test('respects command', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + command: ['echo', 'foo'], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Command: ['echo', 'foo'], + }, + }); + }); + test('respects environment', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + privileged: true, + environment: { + foo: 'bar', + }, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Environment: [{ + Name: 'foo', + Value: 'bar', + }], + }, + }); + }); + test('respects executionRole', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + privileged: true, + executionRole: new aws_iam_1.Role(stack, 'execRole', { + assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:user/user-name'), + }), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ExecutionRoleArn: { + 'Fn::GetAtt': ['execRole623CB63A', 'Arn'], + }, + }, + }); + }); + test('respects jobRole', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + privileged: true, + jobRole: new aws_iam_1.Role(stack, 'jobRole', { + assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:user/user-name'), + }), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + JobRoleArn: { + 'Fn::GetAtt': ['jobRoleA2173686', 'Arn'], + }, + }, + }); + }); + test('respects linuxParameters', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + privileged: true, + linuxParameters: new lib_1.LinuxParameters(stack, 'linuxParameters', { + initProcessEnabled: true, + maxSwap: aws_cdk_lib_1.Size.kibibytes(4096), + sharedMemorySize: aws_cdk_lib_1.Size.mebibytes(256), + swappiness: 30, + }), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + LinuxParameters: { + InitProcessEnabled: true, + MaxSwap: 4, + SharedMemorySize: 256, + Swappiness: 30, + }, + }, + }); + }); + test('respects logging', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + logging: ecs.LogDriver.awsLogs({ + datetimeFormat: 'format', + logRetention: logs.RetentionDays.ONE_MONTH, + multilinePattern: 'pattern', + streamPrefix: 'hello', + }), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ExecutionRoleArn: { + 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], + }, + ...pascalCaseExpectedProps.ContainerProperties, + LogConfiguration: { + Options: { + 'awslogs-datetime-format': 'format', + 'awslogs-group': { Ref: 'EcsContainerLogGroup6C5D5962' }, + 'awslogs-multiline-pattern': 'pattern', + 'awslogs-region': { Ref: 'AWS::Region' }, + 'awslogs-stream-prefix': 'hello', + }, + }, + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + AssumeRolePolicyDocument: { + Statement: [ + { + Action: 'sts:AssumeRole', + Effect: 'Allow', + Principal: { Service: 'ecs-tasks.amazonaws.com' }, + }, + ], + Version: '2012-10-17', + }, + }); + }); + test('respects readonlyRootFilesystem', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + readonlyRootFilesystem: true, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ReadonlyRootFilesystem: true, + }, + }); + }); + test('respects secrets from secrestsmanager', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + secrets: { + envName: lib_1.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'testSecret')), + }, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Secrets: [ + { + Name: 'envName', + ValueFrom: { Ref: 'testSecretB96AD12C' }, + }, + ], + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [ + { + Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], + Effect: 'Allow', + Resource: { + 'Fn::Join': [ + '', [ + 'arn:', + { Ref: 'AWS::Partition' }, + ':logs:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':log-group:/aws/batch/job:*', + ], + ], + }, + }, + { + Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'], + Effect: 'Allow', + Resource: { Ref: 'testSecretB96AD12C' }, + }, + ], + }, + }); + }); + test('respects versioned secrets from secrestsmanager', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + secrets: { + envName: lib_1.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'testSecret'), { + versionId: 'versionID', + versionStage: 'stage', + }), + }, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Secrets: [ + { + Name: 'envName', + ValueFrom: { + 'Fn::Join': [ + '', [ + { Ref: 'testSecretB96AD12C' }, + '::stage:versionID', + ], + ], + }, + }, + ], + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [ + { + Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], + Effect: 'Allow', + Resource: { + 'Fn::Join': [ + '', [ + 'arn:', + { Ref: 'AWS::Partition' }, + ':logs:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':log-group:/aws/batch/job:*', + ], + ], + }, + }, + { + Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'], + Effect: 'Allow', + Resource: { Ref: 'testSecretB96AD12C' }, + }, + ], + }, + }); + }); + test('respects secrets from ssm', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + secrets: { + envName: lib_1.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'myParam', { stringValue: 'super secret' })), + }, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Secrets: [ + { + Name: 'envName', + ValueFrom: { + 'Fn::Join': [ + '', [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':ssm:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':parameter/', + { Ref: 'myParam03610B68' }, + ], + ], + }, + }, + ], + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [ + { + Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], + Effect: 'Allow', + Resource: { + 'Fn::Join': [ + '', [ + 'arn:', + { Ref: 'AWS::Partition' }, + ':logs:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':log-group:/aws/batch/job:*', + ], + ], + }, + }, + { + Action: ['ssm:DescribeParameters', 'ssm:GetParameters', 'ssm:GetParameter', 'ssm:GetParameterHistory'], + Effect: 'Allow', + Resource: { + 'Fn::Join': [ + '', + [ + 'arn:', + { Ref: 'AWS::Partition' }, + ':ssm:', + { Ref: 'AWS::Region' }, + ':', + { Ref: 'AWS::AccountId' }, + ':parameter/', + { Ref: 'myParam03610B68' }, + ], + ], + }, + }, + ], + }, + }); + }); + test('respects user', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + user: 'foo', + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + User: 'foo', + }, + }); + }); + test('respects efs volumes', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + volumes: [ + lib_1.EcsVolume.efs({ + containerPath: '/first/path', + fileSystem: new efs.FileSystem(stack, 'efs', { + vpc: new aws_ec2_1.Vpc(stack, 'vpc'), + }), + name: 'firstEfsVolume', + accessPointId: 'EfsVolumeAccessPointId', + readonly: true, + rootDirectory: 'efsRootDir', + enableTransitEncryption: true, + transitEncryptionPort: 20181, + useJobRole: true, + }), + lib_1.EcsVolume.efs({ + containerPath: '/second/path', + fileSystem: new efs.FileSystem(stack, 'efs2', { + vpc: new aws_ec2_1.Vpc(stack, 'vpc2'), + }), + name: 'secondEfsVolume', + }), + ], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Volumes: [ + { + EfsVolumeConfiguration: { + FileSystemId: { + Ref: 'efs6C17982A', + }, + RootDirectory: 'efsRootDir', + TransitEncryptionPort: 20181, + AuthorizationConfig: { + AccessPointId: 'EfsVolumeAccessPointId', + Iam: 'ENABLED', + }, + }, + Name: 'firstEfsVolume', + }, + { + EfsVolumeConfiguration: { + FileSystemId: { + Ref: 'efs2CB3916C1', + }, + }, + Name: 'secondEfsVolume', + }, + ], + MountPoints: [ + { + ContainerPath: '/first/path', + ReadOnly: true, + SourceVolume: 'firstEfsVolume', + }, + { + ContainerPath: '/second/path', + SourceVolume: 'secondEfsVolume', + }, + ], + }, + }); + }); + test('respects host volumes', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + volumes: [ + lib_1.EcsVolume.host({ + containerPath: '/container/path', + name: 'EcsHostPathVolume', + hostPath: '/host/path', + }), + ], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Volumes: [ + { + Name: 'EcsHostPathVolume', + Host: { + SourcePath: '/host/path', + }, + }, + ], + MountPoints: [ + { + ContainerPath: '/container/path', + SourceVolume: 'EcsHostPathVolume', + }, + ], + }, + }); + }); + test('respects addVolume() with an EfsVolume', () => { + // GIVEN + const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addVolume(lib_1.EcsVolume.efs({ + containerPath: '/container/path', + fileSystem: new efs.FileSystem(stack, 'efs', { + vpc: new aws_ec2_1.Vpc(stack, 'vpc'), + }), + name: 'AddedEfsVolume', + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Volumes: [{ + Name: 'AddedEfsVolume', + EfsVolumeConfiguration: { + FileSystemId: { + Ref: 'efs6C17982A', + }, + }, + }], + MountPoints: [{ + ContainerPath: '/container/path', + SourceVolume: 'AddedEfsVolume', + }], + }, + }); + }); + test('respects addVolume() with a host volume', () => { + // GIVEN + const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addVolume(lib_1.EcsVolume.host({ + containerPath: '/container/path/new', + name: 'hostName', + hostPath: '/host/path', + readonly: false, + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Volumes: [{ + Name: 'hostName', + Host: { + SourcePath: '/host/path', + }, + }], + MountPoints: [{ + ContainerPath: '/container/path/new', + SourceVolume: 'hostName', + }], + }, + }); + }); + test('correctly renders docker images', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + image: ecs.ContainerImage.fromDockerImageAsset(new aws_ecr_assets_1.DockerImageAsset(stack, 'dockerImageAsset', { + directory: path.join(__dirname, 'batchjob-image'), + })), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Image: { + 'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b', + }, + }, + }); + }); + test('correctly renders images from repositories', () => { + // GIVEN + const repo = new ecr.Repository(stack, 'Repo'); + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new ContainerDefinition(stack, 'EcsContainer', { + ...defaultContainerProps, + image: ecs.ContainerImage.fromEcrRepository(repo, 'my-tag'), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Image: { + 'Fn::Join': [ + '', + [ + { + 'Fn::Select': [ + 4, + { + 'Fn::Split': [ + ':', + { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] }, + ], + }, + ], + }, + '.dkr.ecr.', + { + 'Fn::Select': [ + 3, + { + 'Fn::Split': [ + ':', + { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] }, + ], + }, + ], + }, + '.', + { Ref: 'AWS::URLSuffix' }, + '/', + { Ref: 'Repo02AC86CF' }, + ':my-tag', + ], + ], + }, + }, + }); + }); +}); +describe('EC2 containers', () => { + // GIVEN + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { + ...defaultExpectedProps, + containerProperties: { + ...defaultExpectedProps.containerProperties, + executionRoleArn: { + 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'], + }, + }, + }); + }); + test('respects addUlimit()', () => { + // GIVEN + const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addUlimit({ + hardLimit: 10, + name: lib_1.UlimitName.SIGPENDING, + softLimit: 1, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Ulimits: [{ + HardLimit: 10, + SoftLimit: 1, + Name: 'sigpending', + }], + }, + }); + }); + test('respects ulimits', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + ulimits: [ + { + hardLimit: 100, + name: lib_1.UlimitName.CORE, + softLimit: 10, + }, + ], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Ulimits: [ + { + HardLimit: 100, + Name: 'core', + SoftLimit: 10, + }, + ], + }, + }); + }); + test('respects privileged', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + privileged: true, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Privileged: true, + }, + }); + }); + test('respects gpu', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + privileged: true, + gpu: 12, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ResourceRequirements: [ + { + Type: 'MEMORY', + Value: '2048', + }, + { + Type: 'VCPU', + Value: '256', + }, + { + Type: 'GPU', + Value: '12', + }, + ], + }, + }); + }); + test('can use an assset as a container', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + image: ecs.ContainerImage.fromAsset(path.join(__dirname, 'batchjob-image')), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + Image: { + 'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b', + }, + ExecutionRoleArn: { 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'] }, + }, + }); + }); +}); +describe('Fargate containers', () => { + // GIVEN + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { + ...defaultExpectedProps, + containerProperties: { + ...defaultExpectedProps.containerProperties, + executionRoleArn: { + 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], + }, + }, + }); + }); + test('create executionRole by default', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { + ...defaultContainerProps, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ExecutionRoleArn: { + 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], + }, + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + AssumeRolePolicyDocument: { + Statement: [{ + Action: 'sts:AssumeRole', + Effect: 'Allow', + Principal: { Service: 'ecs-tasks.amazonaws.com' }, + }], + Version: '2012-10-17', + }, + }); + }); + test('can set ephemeralStorageSize', () => { + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { + ...defaultContainerProps, + fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, + ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(100), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ExecutionRoleArn: { + 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], + }, + EphemeralStorage: { + SizeInGiB: aws_cdk_lib_1.Size.gibibytes(100).toGibibytes(), + }, + }, + }); + }); + test('can set ephemeralStorageSize as token', () => { + const ephemeralStorageValue = cdk.Token.asNumber(150); + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { + ...defaultContainerProps, + fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, + ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(ephemeralStorageValue), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + ContainerProperties: { + ...pascalCaseExpectedProps.ContainerProperties, + ExecutionRoleArn: { + 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], + }, + EphemeralStorage: { + SizeInGiB: aws_cdk_lib_1.Size.gibibytes(150).toGibibytes(), + }, + }, + }); + }); + test('ephemeralStorageSize throws error when out of range', () => { + expect(() => new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { + ...defaultContainerProps, + fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, + ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(19), + }), + })).toThrow("ECS Fargate container 'EcsFargateContainer' specifies 'ephemeralStorageSize' at 19 < 21 GB"); + expect(() => new lib_1.EcsJobDefinition(stack, 'ECSJobDefn2', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer2', { + ...defaultContainerProps, + fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, + ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(201), + }), + })).toThrow("ECS Fargate container 'EcsFargateContainer2' specifies 'ephemeralStorageSize' at 201 > 200 GB"); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-container-definition.test.js","sourceRoot":"","sources":["ecs-container-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as path from 'path';\nimport { Vpc } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\nimport * as efs from 'aws-cdk-lib/aws-efs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { ArnPrincipal, Role } from 'aws-cdk-lib/aws-iam';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport { EcsContainerDefinitionProps, EcsEc2ContainerDefinition, EcsFargateContainerDefinition, EcsJobDefinition, EcsVolume, IEcsEc2ContainerDefinition, LinuxParameters, Secret, UlimitName } from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\nimport { capitalizePropertyNames } from './utils';\nimport { DockerImageAsset } from 'aws-cdk-lib/aws-ecr-assets';\n\n// GIVEN\nconst defaultContainerProps: EcsContainerDefinitionProps = {\n  cpu: 256,\n  image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n  memory: Size.mebibytes(2048),\n};\n\nconst defaultExpectedProps: CfnJobDefinitionProps = {\n  type: 'container',\n  containerProperties: {\n    image: 'amazon/amazon-ecs-sample',\n    resourceRequirements: [\n      {\n        type: 'MEMORY',\n        value: '2048',\n      },\n      {\n        type: 'VCPU',\n        value: '256',\n      },\n    ],\n  },\n};\n\nlet stack: Stack;\nlet pascalCaseExpectedProps: any;\n\ndescribe.each([EcsEc2ContainerDefinition, EcsFargateContainerDefinition])('%p', (ContainerDefinition) => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('ecs container defaults', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        },\n        ...pascalCaseExpectedProps.ContainerProperties,\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: 'sts:AssumeRole',\n            Effect: 'Allow',\n            Principal: { Service: 'ecs-tasks.amazonaws.com' },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: [\n              'logs:CreateLogStream',\n              'logs:PutLogEvents',\n            ],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '',\n                [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      PolicyName: 'EcsContainerExecutionRoleDefaultPolicy6F59CD37',\n      Roles: [{\n        Ref: 'EcsContainerExecutionRole3B199293',\n      }],\n    });\n  });\n\n  test('respects command', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        command: ['echo', 'foo'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Command: ['echo', 'foo'],\n      },\n    });\n  });\n\n  test('respects environment', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        environment: {\n          foo: 'bar',\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Environment: [{\n          Name: 'foo',\n          Value: 'bar',\n        }],\n      },\n    });\n  });\n\n  test('respects executionRole', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        executionRole: new Role(stack, 'execRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:user/user-name'),\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['execRole623CB63A', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('respects jobRole', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        jobRole: new Role(stack, 'jobRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:user/user-name'),\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        JobRoleArn: {\n          'Fn::GetAtt': ['jobRoleA2173686', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('respects linuxParameters', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        linuxParameters: new LinuxParameters(stack, 'linuxParameters', {\n          initProcessEnabled: true,\n          maxSwap: Size.kibibytes(4096),\n          sharedMemorySize: Size.mebibytes(256),\n          swappiness: 30,\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        LinuxParameters: {\n          InitProcessEnabled: true,\n          MaxSwap: 4,\n          SharedMemorySize: 256,\n          Swappiness: 30,\n        },\n      },\n    });\n  });\n\n  test('respects logging', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        logging: ecs.LogDriver.awsLogs({\n          datetimeFormat: 'format',\n          logRetention: logs.RetentionDays.ONE_MONTH,\n          multilinePattern: 'pattern',\n          streamPrefix: 'hello',\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        },\n        ...pascalCaseExpectedProps.ContainerProperties,\n        LogConfiguration: {\n          Options: {\n            'awslogs-datetime-format': 'format',\n            'awslogs-group': { Ref: 'EcsContainerLogGroup6C5D5962' },\n            'awslogs-multiline-pattern': 'pattern',\n            'awslogs-region': { Ref: 'AWS::Region' },\n            'awslogs-stream-prefix': 'hello',\n          },\n        },\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: 'sts:AssumeRole',\n            Effect: 'Allow',\n            Principal: { Service: 'ecs-tasks.amazonaws.com' },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('respects readonlyRootFilesystem', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        readonlyRootFilesystem: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ReadonlyRootFilesystem: true,\n      },\n    });\n  });\n\n  test('respects secrets from secrestsmanager', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'testSecret')),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'],\n            Effect: 'Allow',\n            Resource: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects versioned secrets from secrestsmanager', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'testSecret'), {\n            versionId: 'versionID',\n            versionStage: 'stage',\n          }),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: {\n              'Fn::Join': [\n                '', [\n                  { Ref: 'testSecretB96AD12C' },\n                  '::stage:versionID',\n                ],\n              ],\n            },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'],\n            Effect: 'Allow',\n            Resource: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects secrets from ssm', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSsmParameter(new ssm.StringParameter(stack, 'myParam', { stringValue: 'super secret' })),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  {\n                    Ref: 'AWS::Partition',\n                  },\n                  ':ssm:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':parameter/',\n                  { Ref: 'myParam03610B68' },\n                ],\n              ],\n            },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['ssm:DescribeParameters', 'ssm:GetParameters', 'ssm:GetParameter', 'ssm:GetParameterHistory'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '',\n                [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':ssm:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':parameter/',\n                  { Ref: 'myParam03610B68' },\n                ],\n\n              ],\n            },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects user', () => {\n  // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        user: 'foo',\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        User: 'foo',\n      },\n    });\n  });\n\n  test('respects efs volumes', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        volumes: [\n          EcsVolume.efs({\n            containerPath: '/first/path',\n            fileSystem: new efs.FileSystem(stack, 'efs', {\n              vpc: new Vpc(stack, 'vpc'),\n            }),\n            name: 'firstEfsVolume',\n            accessPointId: 'EfsVolumeAccessPointId',\n            readonly: true,\n            rootDirectory: 'efsRootDir',\n            enableTransitEncryption: true,\n            transitEncryptionPort: 20181,\n            useJobRole: true,\n          }),\n          EcsVolume.efs({\n            containerPath: '/second/path',\n            fileSystem: new efs.FileSystem(stack, 'efs2', {\n              vpc: new Vpc(stack, 'vpc2'),\n            }),\n            name: 'secondEfsVolume',\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [\n          {\n            EfsVolumeConfiguration: {\n              FileSystemId: {\n                Ref: 'efs6C17982A',\n              },\n              RootDirectory: 'efsRootDir',\n              TransitEncryptionPort: 20181,\n              AuthorizationConfig: {\n                AccessPointId: 'EfsVolumeAccessPointId',\n                Iam: 'ENABLED',\n              },\n            },\n            Name: 'firstEfsVolume',\n          },\n          {\n            EfsVolumeConfiguration: {\n              FileSystemId: {\n                Ref: 'efs2CB3916C1',\n              },\n            },\n            Name: 'secondEfsVolume',\n          },\n        ],\n        MountPoints: [\n          {\n            ContainerPath: '/first/path',\n            ReadOnly: true,\n            SourceVolume: 'firstEfsVolume',\n          },\n          {\n            ContainerPath: '/second/path',\n            SourceVolume: 'secondEfsVolume',\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects host volumes', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        volumes: [\n          EcsVolume.host({\n            containerPath: '/container/path',\n            name: 'EcsHostPathVolume',\n            hostPath: '/host/path',\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [\n          {\n            Name: 'EcsHostPathVolume',\n            Host: {\n              SourcePath: '/host/path',\n            },\n          },\n        ],\n        MountPoints: [\n          {\n            ContainerPath: '/container/path',\n            SourceVolume: 'EcsHostPathVolume',\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects addVolume() with an EfsVolume', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EcsVolume.efs({\n      containerPath: '/container/path',\n      fileSystem: new efs.FileSystem(stack, 'efs', {\n        vpc: new Vpc(stack, 'vpc'),\n      }),\n      name: 'AddedEfsVolume',\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [{\n          Name: 'AddedEfsVolume',\n          EfsVolumeConfiguration: {\n            FileSystemId: {\n              Ref: 'efs6C17982A',\n            },\n          },\n        }],\n        MountPoints: [{\n          ContainerPath: '/container/path',\n          SourceVolume: 'AddedEfsVolume',\n        }],\n      },\n    });\n  });\n\n  test('respects addVolume() with a host volume', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EcsVolume.host({\n      containerPath: '/container/path/new',\n      name: 'hostName',\n      hostPath: '/host/path',\n      readonly: false,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [{\n          Name: 'hostName',\n          Host: {\n            SourcePath: '/host/path',\n          },\n        }],\n        MountPoints: [{\n          ContainerPath: '/container/path/new',\n          SourceVolume: 'hostName',\n        }],\n      },\n    });\n  });\n\n  test('correctly renders docker images', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromDockerImageAsset(new DockerImageAsset(stack, 'dockerImageAsset', {\n          directory: path.join(__dirname, 'batchjob-image'),\n        })),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b',\n        },\n      },\n    });\n  });\n\n  test('correctly renders images from repositories', () => {\n    // GIVEN\n    const repo = new ecr.Repository(stack, 'Repo');\n\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromEcrRepository(repo, 'my-tag'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Join': [\n            '',\n            [\n              {\n                'Fn::Select': [\n                  4,\n                  {\n                    'Fn::Split': [\n                      ':',\n                      { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] },\n                    ],\n                  },\n                ],\n              },\n              '.dkr.ecr.',\n              {\n                'Fn::Select': [\n                  3,\n                  {\n                    'Fn::Split': [\n                      ':',\n                      { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] },\n                    ],\n                  },\n                ],\n              },\n              '.',\n              { Ref: 'AWS::URLSuffix' },\n              '/',\n              { Ref: 'Repo02AC86CF' },\n              ':my-tag',\n            ],\n          ],\n        },\n      },\n    });\n  });\n});\n\ndescribe('EC2 containers', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('respects addUlimit()', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    (jobDefn.container as IEcsEc2ContainerDefinition).addUlimit({\n      hardLimit: 10,\n      name: UlimitName.SIGPENDING,\n      softLimit: 1,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Ulimits: [{\n          HardLimit: 10,\n          SoftLimit: 1,\n          Name: 'sigpending',\n        }],\n      },\n    });\n  });\n\n  test('respects ulimits', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        ulimits: [\n          {\n            hardLimit: 100,\n            name: UlimitName.CORE,\n            softLimit: 10,\n          },\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Ulimits: [\n          {\n            HardLimit: 100,\n            Name: 'core',\n            SoftLimit: 10,\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects privileged', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Privileged: true,\n      },\n    });\n  });\n\n  test('respects gpu', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n        gpu: 12,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ResourceRequirements: [\n          {\n            Type: 'MEMORY',\n            Value: '2048',\n          },\n          {\n            Type: 'VCPU',\n            Value: '256',\n          },\n          {\n            Type: 'GPU',\n            Value: '12',\n          },\n        ],\n      },\n    });\n  });\n\n  test('can use an assset as a container', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromAsset(\n          path.join(__dirname, 'batchjob-image'),\n        ),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b',\n        },\n        ExecutionRoleArn: { 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'] },\n      },\n    });\n  });\n});\n\ndescribe('Fargate containers', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('create executionRole by default', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'ecs-tasks.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('can set ephemeralStorageSize', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(100),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n        EphemeralStorage: {\n          SizeInGiB: Size.gibibytes(100).toGibibytes(),\n        },\n      },\n    });\n  });\n\n  test('can set ephemeralStorageSize as token', () => {\n    const ephemeralStorageValue: number = cdk.Token.asNumber(150);\n\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(ephemeralStorageValue),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n        EphemeralStorage: {\n          SizeInGiB: Size.gibibytes(150).toGibibytes(),\n        },\n      },\n    });\n  });\n\n  test('ephemeralStorageSize throws error when out of range', () => {\n    expect(() => new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(19),\n      }),\n    })).toThrow(\"ECS Fargate container 'EcsFargateContainer' specifies 'ephemeralStorageSize' at 19 < 21 GB\");\n\n    expect(() => new EcsJobDefinition(stack, 'ECSJobDefn2', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer2', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(201),\n      }),\n    })).toThrow(\"ECS Fargate container 'EcsFargateContainer2' specifies 'ephemeralStorageSize' at 201 > 200 GB\");\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js new file mode 100644 index 0000000000000..0eb741964ca54 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js @@ -0,0 +1,147 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const iam = require("aws-cdk-lib/aws-iam"); +const lib_1 = require("../lib"); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +test('EcsJobDefinition respects propagateTags', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EcsJobDefinition(stack, 'JobDefn', { + propagateTags: true, + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + PropagateTags: true, + }); +}); +test('EcsJobDefinition uses Compatibility.EC2 for EC2 containers', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + PlatformCapabilities: [lib_1.Compatibility.EC2], + }); +}); +test('EcsJobDefinition uses Compatibility.FARGATE for Fargate containers', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + PlatformCapabilities: [lib_1.Compatibility.FARGATE], + }); +}); +test('can be imported from ARN', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + const importedJob = lib_1.EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); + // THEN + expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); +}); +test('JobDefinitionName is parsed from arn', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + const jobDefinition = new lib_1.EcsJobDefinition(stack, 'JobDefn', { + propagateTags: true, + container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + expect(aws_cdk_lib_1.Tokenization.resolve(jobDefinition.jobDefinitionName, { + scope: stack, + resolver: new aws_cdk_lib_1.DefaultTokenResolver(new aws_cdk_lib_1.StringConcat()), + })).toEqual({ + 'Fn::Select': [ + 1, + { + 'Fn::Split': [ + '/', + { + 'Fn::Select': [ + 5, + { + 'Fn::Split': [ + ':', + { + Ref: 'JobDefnA747EE6E', + }, + ], + }, + ], + }, + ], + }, + ], + }); +}); +test('JobDefinitionName is parsed from arn in imported job', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + const importedJob = lib_1.EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); + // THEN + expect(importedJob.jobDefinitionName).toEqual('job-def-name'); +}); +test('grantSubmitJob() grants the job role the correct actions', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const ecsJob = new lib_1.EcsJobDefinition(stack, 'ECSJob', { + container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'), + }), + }); + const queue = new lib_1.JobQueue(stack, 'queue'); + queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'env', { + vpc: new aws_ec2_1.Vpc(stack, 'VPC'), + }), 1); + const user = new iam.User(stack, 'MyUser'); + // WHEN + ecsJob.grantSubmitJob(user, queue); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { + PolicyDocument: { + Statement: [{ + Action: 'batch:SubmitJob', + Effect: 'Allow', + Resource: [ + { Ref: 'ECSJobFFFEA569' }, + { 'Fn::GetAtt': ['queue276F7297', 'JobQueueArn'] }, + ], + }], + Version: '2012-10-17', + }, + PolicyName: 'MyUserDefaultPolicy7B897426', + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-job-definition.test.js","sourceRoot":"","sources":["ecs-job-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { DefaultTokenResolver, Size, StringConcat, Stack, Tokenization } from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Compatibility, EcsEc2ContainerDefinition, EcsFargateContainerDefinition, EcsJobDefinition, JobQueue, ManagedEc2EcsComputeEnvironment } from '../lib';\nimport { Vpc } from 'aws-cdk-lib/aws-ec2';\n\ntest('EcsJobDefinition respects propagateTags', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'JobDefn', {\n    propagateTags: true,\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PropagateTags: true,\n  });\n});\n\ntest('EcsJobDefinition uses Compatibility.EC2 for EC2 containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'ECSJobDefn', {\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('EcsJobDefinition uses Compatibility.FARGATE for Fargate containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'ECSJobDefn', {\n    container: new EcsFargateContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PlatformCapabilities: [Compatibility.FARGATE],\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const importedJob = EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition',\n    'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n\n  // THEN\n  expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n});\n\ntest('JobDefinitionName is parsed from arn', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const jobDefinition = new EcsJobDefinition(stack, 'JobDefn', {\n    propagateTags: true,\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  expect(Tokenization.resolve(jobDefinition.jobDefinitionName, {\n    scope: stack,\n    resolver: new DefaultTokenResolver(new StringConcat()),\n  })).toEqual({\n    'Fn::Select': [\n      1,\n      {\n        'Fn::Split': [\n          '/',\n          {\n            'Fn::Select': [\n              5,\n              {\n                'Fn::Split': [\n                  ':',\n                  {\n                    Ref: 'JobDefnA747EE6E',\n                  },\n                ],\n              },\n            ],\n          },\n        ],\n      },\n    ],\n  });\n});\n\ntest('JobDefinitionName is parsed from arn in imported job', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const importedJob = EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition',\n    'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n\n  // THEN\n  expect(importedJob.jobDefinitionName).toEqual('job-def-name');\n});\n\ntest('grantSubmitJob() grants the job role the correct actions', () => {\n  // GIVEN\n  const stack = new Stack();\n  const ecsJob = new EcsJobDefinition(stack, 'ECSJob', {\n    container: new EcsFargateContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      memory: Size.mebibytes(2048),\n      image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'),\n    }),\n  });\n  const queue = new JobQueue(stack, 'queue');\n\n  queue.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'env', {\n      vpc: new Vpc(stack, 'VPC'),\n    }),\n    1,\n  );\n\n  const user = new iam.User(stack, 'MyUser');\n\n  // WHEN\n  ecsJob.grantSubmitJob(user, queue);\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n    PolicyDocument: {\n      Statement: [{\n        Action: 'batch:SubmitJob',\n        Effect: 'Allow',\n        Resource: [\n          { Ref: 'ECSJobFFFEA569' },\n          { 'Fn::GetAtt': ['queue276F7297', 'JobQueueArn'] },\n        ],\n      }],\n      Version: '2012-10-17',\n    },\n    PolicyName: 'MyUserDefaultPolicy7B897426',\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js new file mode 100644 index 0000000000000..3230501ab97c5 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js @@ -0,0 +1,712 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const utils_1 = require("./utils"); +const lib_1 = require("../lib"); +// GIVEN +const defaultContainerProps = { + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), +}; +const defaultExpectedProps = { + type: 'container', + eksProperties: { + podProperties: { + containers: [{ + image: 'amazon/amazon-ecs-sample', + }], + }, + }, +}; +let stack; +let pascalCaseExpectedProps; +describe('eks container', () => { + // GIVEN + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedProps); + }); + test('eks container defaults', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + }); + }); + test('respects args', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + args: ['arg1', 'arg2'], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Args: ['arg1', 'arg2'], + }], + }, + }, + }); + }); + test('respects command', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + command: ['echo', 'bar'], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Command: ['echo', 'bar'], + }], + }, + }, + }); + }); + test('respects cpuLimit', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + cpuLimit: 256, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Limits: { + cpu: 256, + }, + }, + }], + }, + }, + }); + }); + test('respects cpuReservation', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + cpuReservation: 256, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Requests: { + cpu: 256, + }, + }, + }], + }, + }, + }); + }); + test('respects memoryLimitMiB', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + memoryLimit: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Limits: { + memory: '2048Mi', + }, + }, + }], + }, + }, + }); + }); + test('respects memoryReservation', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + memoryReservation: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Requests: { + memory: '2048Mi', + }, + }, + }], + }, + }, + }); + }); + test('respects gpuLimit', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + gpuLimit: 20, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Limits: { + 'nvidia.com/gpu': 20, + }, + }, + }], + }, + }, + }); + }); + test('respects gpuReservation', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + gpuReservation: 20, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Requests: { + 'nvidia.com/gpu': 20, + }, + }, + }], + }, + }, + }); + }); + test('respects resource requests and limits', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + cpuLimit: 256, + cpuReservation: 128, + memoryLimit: aws_cdk_lib_1.Size.mebibytes(2048), + memoryReservation: aws_cdk_lib_1.Size.mebibytes(2048), + gpuLimit: 20, + gpuReservation: 10, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Resources: { + Limits: { + 'cpu': 256, + 'memory': '2048Mi', + 'nvidia.com/gpu': 20, + }, + Requests: { + 'cpu': 128, + 'memory': '2048Mi', + 'nvidia.com/gpu': 10, + }, + }, + }], + }, + }, + }); + }); + test('respects env', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + env: { + var: 'val', + boo: 'bah', + }, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Env: [ + { + Name: 'var', + Value: 'val', + }, + { + Name: 'boo', + Value: 'bah', + }, + ], + }], + }, + }, + }); + }); + test('respects imagePullPolicy', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + imagePullPolicy: lib_1.ImagePullPolicy.NEVER, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + ImagePullPolicy: 'Never', + }], + }, + }, + }); + }); + test('respects name', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + name: 'myContainerName', + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + Name: 'myContainerName', + }], + }, + }, + }); + }); + test('respects privileged', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + privileged: true, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + SecurityContext: { + Privileged: true, + }, + }], + }, + }, + }); + }); + test('respects readonlyFileSystem', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + readonlyRootFilesystem: true, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + SecurityContext: { + ReadOnlyRootFilesystem: true, + }, + }], + }, + }, + }); + }); + test('respects runAsGroup', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + runAsGroup: 1, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + SecurityContext: { + RunAsGroup: 1, + }, + }], + }, + }, + }); + }); + test('respects runAsRoot', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefEksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + runAsRoot: true, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + SecurityContext: { + RunAsNonRoot: false, + }, + }], + }, + }, + }); + }); + test('respects runAsUser', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + runAsUser: 90, + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + SecurityContext: { + RunAsUser: 90, + }, + }], + }, + }, + }); + }); + test('respects emptyDir volumes', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + volumes: [ + lib_1.EksVolume.emptyDir({ + name: 'emptyDirName', + medium: lib_1.EmptyDirMediumType.DISK, + mountPath: '/mount/path', + readonly: false, + sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), + }), + ], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + Name: 'emptyDirName', + ReadOnly: false, + }], + }], + Volumes: [{ + Name: 'emptyDirName', + EmptyDir: { + Medium: '', + SizeLimit: '2048Mi', + }, + }], + }, + }, + }); + }); + test('respects hostPath volumes', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + volumes: [lib_1.EksVolume.hostPath({ + name: 'hostPathName', + hostPath: 'hostPathPath', + mountPath: '/mount/path', + readonly: true, + })], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + Name: 'hostPathName', + ReadOnly: true, + }], + }], + Volumes: [{ + Name: 'hostPathName', + HostPath: { + Path: 'hostPathPath', + }, + }], + }, + }, + }); + }); + test('respects secret volumes, and ensures optional defaults to true', () => { + // WHEN + new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + volumes: [lib_1.EksVolume.secret({ + name: 'secretVolumeName', + secretName: 'myKubeSecret', + mountPath: '/mount/path', + readonly: true, + })], + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + ReadOnly: true, + }], + }], + Volumes: [{ + Name: 'secretVolumeName', + Secret: { + SecretName: 'myKubeSecret', + Optional: true, + }, + }], + }, + }, + }); + }); + test('respects addVolume() with emptyDir volume', () => { + // GIVEN + const jobDefn = new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addVolume(lib_1.EksVolume.emptyDir({ + name: 'emptyDirName', + medium: lib_1.EmptyDirMediumType.DISK, + mountPath: '/mount/path', + readonly: false, + sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + Name: 'emptyDirName', + ReadOnly: false, + }], + }], + Volumes: [{ + Name: 'emptyDirName', + EmptyDir: { + Medium: '', + SizeLimit: '2048Mi', + }, + }], + }, + }, + }); + }); + test('respects addVolume() with hostPath volume', () => { + // GIVEN + const jobDefn = new lib_1.EksJobDefinition(stack, 'EksJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addVolume(lib_1.EksVolume.hostPath({ + name: 'hostPathName', + hostPath: 'hostPathPath', + mountPath: '/mount/path', + readonly: true, + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + Name: 'hostPathName', + ReadOnly: true, + }], + }], + Volumes: [{ + Name: 'hostPathName', + HostPath: { + Path: 'hostPathPath', + }, + }], + }, + }, + }); + }); + test('respects addVolume() with secret volume (optional: false)', () => { + // GIVEN + const jobDefn = new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { + ...defaultContainerProps, + }), + }); + // WHEN + jobDefn.container.addVolume(lib_1.EksVolume.secret({ + name: 'secretVolumeName', + secretName: 'secretName', + optional: false, + mountPath: '/mount/path', + readonly: true, + })); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...pascalCaseExpectedProps, + EksProperties: { + PodProperties: { + ...pascalCaseExpectedProps.EksProperties.PodProperties, + Containers: [{ + ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], + VolumeMounts: [{ + MountPath: '/mount/path', + Name: 'secretVolumeName', + ReadOnly: true, + }], + }], + Volumes: [{ + Name: 'secretVolumeName', + Secret: { + SecretName: 'secretName', + Optional: false, + }, + }], + }, + }, + }); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-container-definition.test.js","sourceRoot":"","sources":["eks-container-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport { EksContainerDefinitionProps, EksContainerDefinition, EksJobDefinition, ImagePullPolicy, EksVolume, EmptyDirMediumType } from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\n// GIVEN\nconst defaultContainerProps: EksContainerDefinitionProps = {\n  image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n};\n\nconst defaultExpectedProps: CfnJobDefinitionProps = {\n  type: 'container',\n  eksProperties: {\n    podProperties: {\n      containers: [{\n        image: 'amazon/amazon-ecs-sample',\n      }],\n    },\n  },\n};\n\nlet stack: Stack;\nlet pascalCaseExpectedProps: any;\n\ndescribe('eks container', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, defaultExpectedProps);\n  });\n\n  test('eks container defaults', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n    });\n  });\n\n  test('respects args', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        args: ['arg1', 'arg2'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Args: ['arg1', 'arg2'],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects command', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        command: ['echo', 'bar'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Command: ['echo', 'bar'],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects cpuLimit', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuLimit: 256,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                cpu: 256,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects cpuReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuReservation: 256,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                cpu: 256,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects memoryLimitMiB', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        memoryLimit: Size.mebibytes(2048),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                memory: '2048Mi',\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects memoryReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        memoryReservation: Size.mebibytes(2048),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                memory: '2048Mi',\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects gpuLimit', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        gpuLimit: 20,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                'nvidia.com/gpu': 20,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects gpuReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        gpuReservation: 20,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                'nvidia.com/gpu': 20,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects resource requests and limits', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuLimit: 256,\n        cpuReservation: 128,\n        memoryLimit: Size.mebibytes(2048),\n        memoryReservation: Size.mebibytes(2048),\n        gpuLimit: 20,\n        gpuReservation: 10,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                'cpu': 256,\n                'memory': '2048Mi',\n                'nvidia.com/gpu': 20,\n              },\n              Requests: {\n                'cpu': 128,\n                'memory': '2048Mi',\n                'nvidia.com/gpu': 10,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects env', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        env: {\n          var: 'val',\n          boo: 'bah',\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Env: [\n              {\n                Name: 'var',\n                Value: 'val',\n              },\n              {\n                Name: 'boo',\n                Value: 'bah',\n              },\n            ],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects imagePullPolicy', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        imagePullPolicy: ImagePullPolicy.NEVER,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            ImagePullPolicy: 'Never',\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        name: 'myContainerName',\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Name: 'myContainerName',\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects privileged', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              Privileged: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects readonlyFileSystem', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        readonlyRootFilesystem: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              ReadOnlyRootFilesystem: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsGroup', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsGroup: 1,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsGroup: 1,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsRoot', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefEksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsRoot: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsNonRoot: false,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsUser', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsUser: 90,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsUser: 90,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects emptyDir volumes', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [\n          EksVolume.emptyDir({\n            name: 'emptyDirName',\n            medium: EmptyDirMediumType.DISK,\n            mountPath: '/mount/path',\n            readonly: false,\n            sizeLimit: Size.mebibytes(2048),\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'emptyDirName',\n              ReadOnly: false,\n            }],\n          }],\n          Volumes: [{\n            Name: 'emptyDirName',\n            EmptyDir: {\n              Medium: '',\n              SizeLimit: '2048Mi',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects hostPath volumes', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [EksVolume.hostPath({\n          name: 'hostPathName',\n          hostPath: 'hostPathPath',\n          mountPath: '/mount/path',\n          readonly: true,\n        })],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'hostPathName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'hostPathName',\n            HostPath: {\n              Path: 'hostPathPath',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects secret volumes, and ensures optional defaults to true', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [EksVolume.secret({\n          name: 'secretVolumeName',\n          secretName: 'myKubeSecret',\n          mountPath: '/mount/path',\n          readonly: true,\n        })],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'secretVolumeName',\n            Secret: {\n              SecretName: 'myKubeSecret',\n              Optional: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with emptyDir volume', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.emptyDir({\n      name: 'emptyDirName',\n      medium: EmptyDirMediumType.DISK,\n      mountPath: '/mount/path',\n      readonly: false,\n      sizeLimit: Size.mebibytes(2048),\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'emptyDirName',\n              ReadOnly: false,\n            }],\n          }],\n          Volumes: [{\n            Name: 'emptyDirName',\n            EmptyDir: {\n              Medium: '',\n              SizeLimit: '2048Mi',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with hostPath volume', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.hostPath({\n      name: 'hostPathName',\n      hostPath: 'hostPathPath',\n      mountPath: '/mount/path',\n      readonly: true,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'hostPathName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'hostPathName',\n            HostPath: {\n              Path: 'hostPathPath',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with secret volume (optional: false)', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EKSJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.secret({\n      name: 'secretVolumeName',\n      secretName: 'secretName',\n      optional: false,\n      mountPath: '/mount/path',\n      readonly: true,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'secretVolumeName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'secretVolumeName',\n            Secret: {\n              SecretName: 'secretName',\n              Optional: false,\n            },\n          }],\n        },\n      },\n    });\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js new file mode 100644 index 0000000000000..6a75c414d26d2 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js @@ -0,0 +1,72 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const lib_1 = require("../lib"); +test('EcsJobDefinition respects dnsPolicy', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + dnsPolicy: lib_1.DnsPolicy.CLUSTER_FIRST, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + EksProperties: { + PodProperties: { + DnsPolicy: lib_1.DnsPolicy.CLUSTER_FIRST, + }, + }, + }); +}); +test('EcsJobDefinition respects useHostNetwork', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + useHostNetwork: true, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + EksProperties: { + PodProperties: { + HostNetwork: true, + }, + }, + }); +}); +test('EcsJobDefinition respects serviceAccount', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { + container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + serviceAccount: 'my-service-account', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + EksProperties: { + PodProperties: { + ServiceAccountName: 'my-service-account', + }, + }, + }); +}); +test('can be imported from ARN', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + const importedJob = lib_1.EksJobDefinition.fromEksJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); + // THEN + expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWtzLWpvYi1kZWZpbml0aW9uLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJla3Mtam9iLWRlZmluaXRpb24udGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHVEQUFrRDtBQUNsRCwyQ0FBMkM7QUFDM0MsNkNBQW9DO0FBQ3BDLGdDQUE2RTtBQUU3RSxJQUFJLENBQUMscUNBQXFDLEVBQUUsR0FBRyxFQUFFO0lBQy9DLFFBQVE7SUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLEVBQUUsQ0FBQztJQUUxQixPQUFPO0lBQ1AsSUFBSSxzQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1FBQ3hDLFNBQVMsRUFBRSxJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7WUFDM0QsS0FBSyxFQUFFLEdBQUcsQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO1NBQ25FLENBQUM7UUFDRixTQUFTLEVBQUUsZUFBUyxDQUFDLGFBQWE7S0FDbkMsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLDJCQUEyQixFQUFFO1FBQzNFLGFBQWEsRUFBRTtZQUNiLGFBQWEsRUFBRTtnQkFDYixTQUFTLEVBQUUsZUFBUyxDQUFDLGFBQWE7YUFDbkM7U0FDRjtLQUNGLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDO0FBRUgsSUFBSSxDQUFDLDBDQUEwQyxFQUFFLEdBQUcsRUFBRTtJQUNwRCxRQUFRO0lBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxFQUFFLENBQUM7SUFFMUIsT0FBTztJQUNQLElBQUksc0JBQWdCLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtRQUN4QyxTQUFTLEVBQUUsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFO1lBQzNELEtBQUssRUFBRSxHQUFHLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztTQUNuRSxDQUFDO1FBQ0YsY0FBYyxFQUFFLElBQUk7S0FDckIsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLDJCQUEyQixFQUFFO1FBQzNFLGFBQWEsRUFBRTtZQUNiLGFBQWEsRUFBRTtnQkFDYixXQUFXLEVBQUUsSUFBSTthQUNsQjtTQUNGO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLENBQUMsMENBQTBDLEVBQUUsR0FBRyxFQUFFO0lBQ3BELFFBQVE7SUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLEVBQUUsQ0FBQztJQUUxQixPQUFPO0lBQ1AsSUFBSSxzQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1FBQ3hDLFNBQVMsRUFBRSxJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7WUFDM0QsS0FBSyxFQUFFLEdBQUcsQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO1NBQ25FLENBQUM7UUFDRixjQUFjLEVBQUUsb0JBQW9CO0tBQ3JDLENBQUMsQ0FBQztJQUVILE9BQU87SUFDUCxxQkFBUSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQywyQkFBMkIsRUFBRTtRQUMzRSxhQUFhLEVBQUU7WUFDYixhQUFhLEVBQUU7Z0JBQ2Isa0JBQWtCLEVBQUUsb0JBQW9CO2FBQ3pDO1NBQ0Y7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQywwQkFBMEIsRUFBRSxHQUFHLEVBQUU7SUFDcEMsUUFBUTtJQUNSLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssRUFBRSxDQUFDO0lBRTFCLE9BQU87SUFDUCxNQUFNLFdBQVcsR0FBRyxzQkFBZ0IsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLEVBQUUsdUJBQXVCLEVBQ3pGLG9FQUFvRSxDQUFDLENBQUM7SUFFeEUsT0FBTztJQUNQLE1BQU0sQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxPQUFPLENBQUMsb0VBQW9FLENBQUMsQ0FBQztBQUNySCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSAnYXdzLWNkay1saWIvYXNzZXJ0aW9ucyc7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjcyc7XG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IERuc1BvbGljeSwgRWtzQ29udGFpbmVyRGVmaW5pdGlvbiwgRWtzSm9iRGVmaW5pdGlvbiB9IGZyb20gJy4uL2xpYic7XG5cbnRlc3QoJ0Vjc0pvYkRlZmluaXRpb24gcmVzcGVjdHMgZG5zUG9saWN5JywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IEVrc0pvYkRlZmluaXRpb24oc3RhY2ssICdFS1NKb2JEZWZuJywge1xuICAgIGNvbnRhaW5lcjogbmV3IEVrc0NvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdFa3NDb250YWluZXInLCB7XG4gICAgICBpbWFnZTogZWNzLkNvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgfSksXG4gICAgZG5zUG9saWN5OiBEbnNQb2xpY3kuQ0xVU1RFUl9GSVJTVCxcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Sm9iRGVmaW5pdGlvbicsIHtcbiAgICBFa3NQcm9wZXJ0aWVzOiB7XG4gICAgICBQb2RQcm9wZXJ0aWVzOiB7XG4gICAgICAgIERuc1BvbGljeTogRG5zUG9saWN5LkNMVVNURVJfRklSU1QsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pO1xufSk7XG5cbnRlc3QoJ0Vjc0pvYkRlZmluaXRpb24gcmVzcGVjdHMgdXNlSG9zdE5ldHdvcmsnLCAoKSA9PiB7XG4gIC8vIEdJVkVOXG4gIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG5cbiAgLy8gV0hFTlxuICBuZXcgRWtzSm9iRGVmaW5pdGlvbihzdGFjaywgJ0VLU0pvYkRlZm4nLCB7XG4gICAgY29udGFpbmVyOiBuZXcgRWtzQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vrc0NvbnRhaW5lcicsIHtcbiAgICAgIGltYWdlOiBlY3MuQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICB9KSxcbiAgICB1c2VIb3N0TmV0d29yazogdHJ1ZSxcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Sm9iRGVmaW5pdGlvbicsIHtcbiAgICBFa3NQcm9wZXJ0aWVzOiB7XG4gICAgICBQb2RQcm9wZXJ0aWVzOiB7XG4gICAgICAgIEhvc3ROZXR3b3JrOiB0cnVlLFxuICAgICAgfSxcbiAgICB9LFxuICB9KTtcbn0pO1xuXG50ZXN0KCdFY3NKb2JEZWZpbml0aW9uIHJlc3BlY3RzIHNlcnZpY2VBY2NvdW50JywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IEVrc0pvYkRlZmluaXRpb24oc3RhY2ssICdFS1NKb2JEZWZuJywge1xuICAgIGNvbnRhaW5lcjogbmV3IEVrc0NvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdFa3NDb250YWluZXInLCB7XG4gICAgICBpbWFnZTogZWNzLkNvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgfSksXG4gICAgc2VydmljZUFjY291bnQ6ICdteS1zZXJ2aWNlLWFjY291bnQnLFxuICB9KTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpKb2JEZWZpbml0aW9uJywge1xuICAgIEVrc1Byb3BlcnRpZXM6IHtcbiAgICAgIFBvZFByb3BlcnRpZXM6IHtcbiAgICAgICAgU2VydmljZUFjY291bnROYW1lOiAnbXktc2VydmljZS1hY2NvdW50JyxcbiAgICAgIH0sXG4gICAgfSxcbiAgfSk7XG59KTtcblxudGVzdCgnY2FuIGJlIGltcG9ydGVkIGZyb20gQVJOJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgY29uc3QgaW1wb3J0ZWRKb2IgPSBFa3NKb2JEZWZpbml0aW9uLmZyb21Fa3NKb2JEZWZpbml0aW9uQXJuKHN0YWNrLCAnaW1wb3J0ZWRKb2JEZWZpbml0aW9uJyxcbiAgICAnYXJuOmF3czpiYXRjaDp1cy1lYXN0LTE6MTIzNDU2Nzg5MDEyOmpvYi1kZWZpbml0aW9uL2pvYi1kZWYtbmFtZToxJyk7XG5cbiAgLy8gVEhFTlxuICBleHBlY3QoaW1wb3J0ZWRKb2Iuam9iRGVmaW5pdGlvbkFybikudG9FcXVhbCgnYXJuOmF3czpiYXRjaDp1cy1lYXN0LTE6MTIzNDU2Nzg5MDEyOmpvYi1kZWZpbml0aW9uL2pvYi1kZWYtbmFtZToxJyk7XG59KTtcblxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js new file mode 100644 index 0000000000000..5d9e85af3e008 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const events = require("aws-cdk-lib/aws-events"); +const targets = require("aws-cdk-lib/aws-events-targets"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const batch = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +const jobQueue = new batch.JobQueue(stack, 'MyQueue', { + computeEnvironments: [ + { + computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'), + order: 1, + }, + ], +}); +const jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', { + container: new batch.EcsEc2ContainerDefinition(stack, 'container', { + image: aws_ecs_1.ContainerImage.fromRegistry('test-repo'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), +}); +const rule = new events.Rule(stack, 'Rule', { + schedule: events.Schedule.expression('rate(1 minute)'), +}); +rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition)); +new integ.IntegTest(app, 'BatchUniqueNameTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYmF0Y2gtdW5pcXVlLW5hbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5iYXRjaC11bmlxdWUtbmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUFxRDtBQUNyRCw2Q0FBK0M7QUFDL0MsaURBQWlEO0FBQ2pELDBEQUEwRDtBQUMxRCxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBRWhDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdEMsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUU7SUFDcEQsbUJBQW1CLEVBQUU7UUFDbkI7WUFDRSxrQkFBa0IsRUFBRSxJQUFJLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxLQUFLLEVBQUUsb0JBQW9CLENBQUM7WUFDdEYsS0FBSyxFQUFFLENBQUM7U0FDVDtLQUNGO0NBQ0YsQ0FBQyxDQUFDO0FBQ0gsTUFBTSxhQUFhLEdBQUcsSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtJQUMvRCxTQUFTLEVBQUUsSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsS0FBSyxFQUFFLFdBQVcsRUFBRTtRQUNqRSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDO1FBQy9DLEdBQUcsRUFBRSxHQUFHO1FBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztLQUM3QixDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsTUFBTSxJQUFJLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDMUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDO0NBQ3ZELENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUNqQyxRQUFRLENBQUMsV0FBVyxFQUNwQixRQUFRLEVBQ1IsYUFBYSxDQUFDLGdCQUFnQixFQUM5QixhQUFhLENBQ2QsQ0FBQyxDQUFDO0FBRUgsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxxQkFBcUIsRUFBRTtJQUM5QyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGFpbmVySW1hZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IEFwcCwgU2l6ZSwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBldmVudHMgZnJvbSAnYXdzLWNkay1saWIvYXdzLWV2ZW50cyc7XG5pbXBvcnQgKiBhcyB0YXJnZXRzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1ldmVudHMtdGFyZ2V0cyc7XG5pbXBvcnQgKiBhcyBpbnRlZyBmcm9tICdAYXdzLWNkay9pbnRlZy10ZXN0cy1hbHBoYSc7XG5pbXBvcnQgKiBhcyBiYXRjaCBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3Qgam9iUXVldWUgPSBuZXcgYmF0Y2guSm9iUXVldWUoc3RhY2ssICdNeVF1ZXVlJywge1xuICBjb21wdXRlRW52aXJvbm1lbnRzOiBbXG4gICAge1xuICAgICAgY29tcHV0ZUVudmlyb25tZW50OiBuZXcgYmF0Y2guVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnQ29tcHV0ZUVudmlyb25tZW50JyksXG4gICAgICBvcmRlcjogMSxcbiAgICB9LFxuICBdLFxufSk7XG5jb25zdCBqb2JEZWZpbml0aW9uID0gbmV3IGJhdGNoLkVjc0pvYkRlZmluaXRpb24oc3RhY2ssICdNeUpvYicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ2NvbnRhaW5lcicsIHtcbiAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCd0ZXN0LXJlcG8nKSxcbiAgICBjcHU6IDI1NixcbiAgICBtZW1vcnk6IFNpemUubWViaWJ5dGVzKDIwNDgpLFxuICB9KSxcbn0pO1xuXG5jb25zdCBydWxlID0gbmV3IGV2ZW50cy5SdWxlKHN0YWNrLCAnUnVsZScsIHtcbiAgc2NoZWR1bGU6IGV2ZW50cy5TY2hlZHVsZS5leHByZXNzaW9uKCdyYXRlKDEgbWludXRlKScpLFxufSk7XG5cbnJ1bGUuYWRkVGFyZ2V0KG5ldyB0YXJnZXRzLkJhdGNoSm9iKFxuICBqb2JRdWV1ZS5qb2JRdWV1ZUFybixcbiAgam9iUXVldWUsXG4gIGpvYkRlZmluaXRpb24uam9iRGVmaW5pdGlvbkFybixcbiAgam9iRGVmaW5pdGlvbixcbikpO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoVW5pcXVlTmFtZVRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js new file mode 100644 index 0000000000000..acacc540d2191 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js @@ -0,0 +1,94 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); +const efs = require("aws-cdk-lib/aws-efs"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const ssm = require("aws-cdk-lib/aws-ssm"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const batch = require("../lib"); +const aws_ecr_assets_1 = require("aws-cdk-lib/aws-ecr-assets"); +const path = require("path"); +const secretsmanager = require("aws-cdk-lib/aws-secretsmanager"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); +new batch.EcsJobDefinition(stack, 'ECSJobDefn', { + container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + environment: { + foo: 'bar', + }, + gpu: 12, + volumes: [ + batch.EcsVolume.host({ + name: 'volumeName', + hostPath: '/foo/bar', + containerPath: 'ahhh', + }), + batch.EcsVolume.efs({ + fileSystem: new efs.FileSystem(stack, 'myFileSystem', { + vpc, + }), + name: 'efsVolume', + containerPath: '/my/path', + }), + ], + ulimits: [{ + hardLimit: 50, + name: batch.UlimitName.CORE, + softLimit: 10, + }], + secrets: { + MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'mySecret')), + ANOTHER_ONE: batch.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'anotherSecret'), { + versionId: 'foo', + versionStage: 'bar', + }), + SSM_TIME: batch.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'ssm', { stringValue: 'myString' })), + }, + }), +}); +new batch.EcsJobDefinition(stack, 'ECSFargateJobDefn', { + container: new batch.EcsFargateContainerDefinition(stack, 'myFargateContainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + cpu: 16, + memory: aws_cdk_lib_1.Size.mebibytes(32768), + ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(100), + fargatePlatformVersion: aws_ecs_1.FargatePlatformVersion.LATEST, + }), + jobDefinitionName: 'foofoo', + parameters: { + foo: 'bar', + }, + propagateTags: true, + retryAttempts: 5, + retryStrategies: [ + new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER), + new batch.RetryStrategy(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE), + new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.custom({ + onExitCode: '40*', + onReason: 'reason', + onStatusReason: 'statusreason', + })), + ], + schedulingPriority: 10, + timeout: aws_cdk_lib_1.Duration.minutes(10), +}); +new batch.EcsJobDefinition(stack, 'ECSDockerJobDefn', { + container: new batch.EcsEc2ContainerDefinition(stack, 'EcsDockerContainer', { + cpu: 16, + memory: aws_cdk_lib_1.Size.mebibytes(32768), + image: ecs.ContainerImage.fromDockerImageAsset(new aws_ecr_assets_1.DockerImageAsset(stack, 'dockerImageAsset', { + directory: path.join(__dirname, 'batchjob-image'), + })), + }), +}); +new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ.ecs-job-definition.js","sourceRoot":"","sources":["integ.ecs-job-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import { Vpc } from 'aws-cdk-lib/aws-ec2';\nimport { ContainerImage, FargatePlatformVersion } from 'aws-cdk-lib/aws-ecs';\nimport * as efs from 'aws-cdk-lib/aws-efs';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { App, Duration, Size, Stack } from 'aws-cdk-lib';\nimport * as integ from '@aws-cdk/integ-tests-alpha';\nimport * as batch from '../lib';\nimport { DockerImageAsset } from 'aws-cdk-lib/aws-ecr-assets';\nimport * as path from 'path';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\n\nconst app = new App();\nconst stack = new Stack(app, 'stack');\nconst vpc = new Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false });\n\nnew batch.EcsJobDefinition(stack, 'ECSJobDefn', {\n  container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', {\n    image: ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n    cpu: 256,\n    memory: Size.mebibytes(2048),\n    environment: {\n      foo: 'bar',\n    },\n    gpu: 12,\n    volumes: [\n      batch.EcsVolume.host({\n        name: 'volumeName',\n        hostPath: '/foo/bar',\n        containerPath: 'ahhh',\n      }),\n      batch.EcsVolume.efs({\n        fileSystem: new efs.FileSystem(stack, 'myFileSystem', {\n          vpc,\n        }),\n        name: 'efsVolume',\n        containerPath: '/my/path',\n      }),\n    ],\n    ulimits: [{\n      hardLimit: 50,\n      name: batch.UlimitName.CORE,\n      softLimit: 10,\n    }],\n    secrets: {\n      MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'mySecret')),\n      ANOTHER_ONE: batch.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'anotherSecret'), {\n        versionId: 'foo',\n        versionStage: 'bar',\n      }),\n      SSM_TIME: batch.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'ssm', { stringValue: 'myString' })),\n    },\n  }),\n});\n\nnew batch.EcsJobDefinition(stack, 'ECSFargateJobDefn', {\n  container: new batch.EcsFargateContainerDefinition(stack, 'myFargateContainer', {\n    image: ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n    cpu: 16,\n    memory: Size.mebibytes(32768),\n    ephemeralStorageSize: Size.gibibytes(100),\n    fargatePlatformVersion: FargatePlatformVersion.LATEST,\n  }),\n  jobDefinitionName: 'foofoo',\n  parameters: {\n    foo: 'bar',\n  },\n  propagateTags: true,\n  retryAttempts: 5,\n  retryStrategies: [\n    new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n    new batch.RetryStrategy(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE),\n    new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.custom({\n      onExitCode: '40*',\n      onReason: 'reason',\n      onStatusReason: 'statusreason',\n    })),\n  ],\n  schedulingPriority: 10,\n  timeout: Duration.minutes(10),\n});\n\nnew batch.EcsJobDefinition(stack, 'ECSDockerJobDefn', {\n  container: new batch.EcsEc2ContainerDefinition(stack, 'EcsDockerContainer', {\n    cpu: 16,\n    memory: Size.mebibytes(32768),\n    image: ecs.ContainerImage.fromDockerImageAsset(new DockerImageAsset(stack, 'dockerImageAsset', {\n      directory: path.join(__dirname, 'batchjob-image'),\n    })),\n  }),\n});\n\nnew integ.IntegTest(app, 'BatchEcsJobDefinitionTest', {\n  testCases: [stack],\n});\n\napp.synth();\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js new file mode 100644 index 0000000000000..ec09421f64761 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js @@ -0,0 +1,59 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const batch = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +new batch.EksJobDefinition(stack, 'EksJobDefn', { + container: new batch.EksContainerDefinition(stack, 'EksContainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + args: ['foo'], + command: ['echo foo'], + env: { foo: 'bar' }, + cpuLimit: 8, + cpuReservation: 4, + memoryLimit: aws_cdk_lib_1.Size.mebibytes(8192), + memoryReservation: aws_cdk_lib_1.Size.mebibytes(8192), + gpuLimit: 12, + gpuReservation: 12, + imagePullPolicy: batch.ImagePullPolicy.ALWAYS, + name: 'myBigCoolVolume', + privileged: true, + readonlyRootFilesystem: false, + runAsGroup: 1, + runAsRoot: false, + runAsUser: 20, + volumes: [ + batch.EksVolume.emptyDir({ + name: 'woah', + mountPath: '/mount/path', + medium: batch.EmptyDirMediumType.MEMORY, + readonly: true, + sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), + }), + batch.EksVolume.secret({ + name: 'secretVolumeName', + secretName: 'secretName', + mountPath: '/secret/path', + optional: false, + }), + batch.EksVolume.secret({ + name: 'defaultOptionalSettingSecretVolume', + secretName: 'NewSecretName', + mountPath: '/secret/path2', + }), + batch.EksVolume.hostPath({ + name: 'hostPath', + hostPath: '/foo/bar', + mountPath: '/fooasdfadfs', + }), + ], + }), +}); +new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZWtzLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZWtzLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQXFEO0FBQ3JELDZDQUErQztBQUMvQyxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBRWhDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFFdEMsSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtJQUM5QyxTQUFTLEVBQUUsSUFBSSxLQUFLLENBQUMsc0JBQXNCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtRQUNqRSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsMEJBQTBCLENBQUM7UUFDOUQsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDO1FBQ2IsT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFDO1FBQ3JCLEdBQUcsRUFBRSxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUU7UUFDbkIsUUFBUSxFQUFFLENBQUM7UUFDWCxjQUFjLEVBQUUsQ0FBQztRQUNqQixXQUFXLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO1FBQ2pDLGlCQUFpQixFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztRQUN2QyxRQUFRLEVBQUUsRUFBRTtRQUNaLGNBQWMsRUFBRSxFQUFFO1FBQ2xCLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLE1BQU07UUFDN0MsSUFBSSxFQUFFLGlCQUFpQjtRQUN2QixVQUFVLEVBQUUsSUFBSTtRQUNoQixzQkFBc0IsRUFBRSxLQUFLO1FBQzdCLFVBQVUsRUFBRSxDQUFDO1FBQ2IsU0FBUyxFQUFFLEtBQUs7UUFDaEIsU0FBUyxFQUFFLEVBQUU7UUFDYixPQUFPLEVBQUU7WUFDUCxLQUFLLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQztnQkFDdkIsSUFBSSxFQUFFLE1BQU07Z0JBQ1osU0FBUyxFQUFFLGFBQWE7Z0JBQ3hCLE1BQU0sRUFBRSxLQUFLLENBQUMsa0JBQWtCLENBQUMsTUFBTTtnQkFDdkMsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsU0FBUyxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQzthQUNoQyxDQUFDO1lBQ0YsS0FBSyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7Z0JBQ3JCLElBQUksRUFBRSxrQkFBa0I7Z0JBQ3hCLFVBQVUsRUFBRSxZQUFZO2dCQUN4QixTQUFTLEVBQUUsY0FBYztnQkFDekIsUUFBUSxFQUFFLEtBQUs7YUFDaEIsQ0FBQztZQUNGLEtBQUssQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO2dCQUNyQixJQUFJLEVBQUUsb0NBQW9DO2dCQUMxQyxVQUFVLEVBQUUsZUFBZTtnQkFDM0IsU0FBUyxFQUFFLGVBQWU7YUFDM0IsQ0FBQztZQUNGLEtBQUssQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO2dCQUN2QixJQUFJLEVBQUUsVUFBVTtnQkFDaEIsUUFBUSxFQUFFLFVBQVU7Z0JBQ3BCLFNBQVMsRUFBRSxjQUFjO2FBQzFCLENBQUM7U0FDSDtLQUNGLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLDJCQUEyQixFQUFFO0lBQ3BELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250YWluZXJJbWFnZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lY3MnO1xuaW1wb3J0IHsgQXBwLCBTdGFjaywgU2l6ZSB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCAqIGFzIGJhdGNoIGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ3N0YWNrJyk7XG5cbm5ldyBiYXRjaC5Fa3NKb2JEZWZpbml0aW9uKHN0YWNrLCAnRWtzSm9iRGVmbicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWtzQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vrc0NvbnRhaW5lcicsIHtcbiAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICBhcmdzOiBbJ2ZvbyddLFxuICAgIGNvbW1hbmQ6IFsnZWNobyBmb28nXSxcbiAgICBlbnY6IHsgZm9vOiAnYmFyJyB9LFxuICAgIGNwdUxpbWl0OiA4LFxuICAgIGNwdVJlc2VydmF0aW9uOiA0LFxuICAgIG1lbW9yeUxpbWl0OiBTaXplLm1lYmlieXRlcyg4MTkyKSxcbiAgICBtZW1vcnlSZXNlcnZhdGlvbjogU2l6ZS5tZWJpYnl0ZXMoODE5MiksXG4gICAgZ3B1TGltaXQ6IDEyLFxuICAgIGdwdVJlc2VydmF0aW9uOiAxMixcbiAgICBpbWFnZVB1bGxQb2xpY3k6IGJhdGNoLkltYWdlUHVsbFBvbGljeS5BTFdBWVMsXG4gICAgbmFtZTogJ215QmlnQ29vbFZvbHVtZScsXG4gICAgcHJpdmlsZWdlZDogdHJ1ZSxcbiAgICByZWFkb25seVJvb3RGaWxlc3lzdGVtOiBmYWxzZSxcbiAgICBydW5Bc0dyb3VwOiAxLFxuICAgIHJ1bkFzUm9vdDogZmFsc2UsXG4gICAgcnVuQXNVc2VyOiAyMCxcbiAgICB2b2x1bWVzOiBbXG4gICAgICBiYXRjaC5Fa3NWb2x1bWUuZW1wdHlEaXIoe1xuICAgICAgICBuYW1lOiAnd29haCcsXG4gICAgICAgIG1vdW50UGF0aDogJy9tb3VudC9wYXRoJyxcbiAgICAgICAgbWVkaXVtOiBiYXRjaC5FbXB0eURpck1lZGl1bVR5cGUuTUVNT1JZLFxuICAgICAgICByZWFkb25seTogdHJ1ZSxcbiAgICAgICAgc2l6ZUxpbWl0OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgICAgIH0pLFxuICAgICAgYmF0Y2guRWtzVm9sdW1lLnNlY3JldCh7XG4gICAgICAgIG5hbWU6ICdzZWNyZXRWb2x1bWVOYW1lJyxcbiAgICAgICAgc2VjcmV0TmFtZTogJ3NlY3JldE5hbWUnLFxuICAgICAgICBtb3VudFBhdGg6ICcvc2VjcmV0L3BhdGgnLFxuICAgICAgICBvcHRpb25hbDogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIGJhdGNoLkVrc1ZvbHVtZS5zZWNyZXQoe1xuICAgICAgICBuYW1lOiAnZGVmYXVsdE9wdGlvbmFsU2V0dGluZ1NlY3JldFZvbHVtZScsXG4gICAgICAgIHNlY3JldE5hbWU6ICdOZXdTZWNyZXROYW1lJyxcbiAgICAgICAgbW91bnRQYXRoOiAnL3NlY3JldC9wYXRoMicsXG4gICAgICB9KSxcbiAgICAgIGJhdGNoLkVrc1ZvbHVtZS5ob3N0UGF0aCh7XG4gICAgICAgIG5hbWU6ICdob3N0UGF0aCcsXG4gICAgICAgIGhvc3RQYXRoOiAnL2Zvby9iYXInLFxuICAgICAgICBtb3VudFBhdGg6ICcvZm9vYXNkZmFkZnMnLFxuICAgICAgfSksXG4gICAgXSxcbiAgfSksXG59KTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaEVjc0pvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js new file mode 100644 index 0000000000000..96eab371eb46c --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js @@ -0,0 +1,35 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const iam = require("aws-cdk-lib/aws-iam"); +const batch = require("../lib"); +const lib_1 = require("../lib"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); +const queue = new batch.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'managedEc2CE', { + vpc, + }), + order: 1, + }], + priority: 10, +}); +const ecsJob = new batch.EcsJobDefinition(stack, 'ECSJob', { + container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'), + }), +}); +const user = new iam.User(stack, 'MyUser'); +ecsJob.grantSubmitJob(user, queue); +new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZ3JhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZ3JhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQTBDO0FBQzFDLDZDQUErQztBQUMvQyxvREFBb0Q7QUFDcEQsMkNBQTJDO0FBQzNDLGdDQUFnQztBQUNoQyxnQ0FBeUQ7QUFDekQsMkNBQTJDO0FBRTNDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxhQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLDRCQUE0QixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFFM0UsTUFBTSxLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7SUFDL0MsbUJBQW1CLEVBQUUsQ0FBQztZQUNwQixrQkFBa0IsRUFBRSxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7Z0JBQzdFLEdBQUc7YUFDSixDQUFDO1lBQ0YsS0FBSyxFQUFFLENBQUM7U0FDVCxDQUFDO0lBQ0YsUUFBUSxFQUFFLEVBQUU7Q0FDYixDQUFDLENBQUM7QUFFSCxNQUFNLE1BQU0sR0FBRyxJQUFJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsUUFBUSxFQUFFO0lBQ3pELFNBQVMsRUFBRSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFO1FBQ3BFLEdBQUcsRUFBRSxHQUFHO1FBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztRQUM1QixLQUFLLEVBQUUsR0FBRyxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsa0JBQWtCLENBQUM7S0FDM0QsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVILE1BQU0sSUFBSSxHQUFHLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7QUFDM0MsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFbkMsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSwyQkFBMkIsRUFBRTtJQUNwRCxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVnBjIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XG5pbXBvcnQgeyBBcHAsIFN0YWNrLCBTaXplIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgaW50ZWcgZnJvbSAnQGF3cy1jZGsvaW50ZWctdGVzdHMtYWxwaGEnO1xuaW1wb3J0ICogYXMgaWFtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0ICogYXMgYmF0Y2ggZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQgfSBmcm9tICcuLi9saWInO1xuaW1wb3J0ICogYXMgZWNzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lY3MnO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3QgdnBjID0gbmV3IFZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbmNvbnN0IHF1ZXVlID0gbmV3IGJhdGNoLkpvYlF1ZXVlKHN0YWNrLCAnam9CQlEnLCB7XG4gIGNvbXB1dGVFbnZpcm9ubWVudHM6IFt7XG4gICAgY29tcHV0ZUVudmlyb25tZW50OiBuZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21hbmFnZWRFYzJDRScsIHtcbiAgICAgIHZwYyxcbiAgICB9KSxcbiAgICBvcmRlcjogMSxcbiAgfV0sXG4gIHByaW9yaXR5OiAxMCxcbn0pO1xuXG5jb25zdCBlY3NKb2IgPSBuZXcgYmF0Y2guRWNzSm9iRGVmaW5pdGlvbihzdGFjaywgJ0VDU0pvYicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vjc0NvbnRhaW5lcicsIHtcbiAgICBjcHU6IDI1NixcbiAgICBtZW1vcnk6IFNpemUubWViaWJ5dGVzKDIwNDgpLFxuICAgIGltYWdlOiBlY3MuQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdmb29yZXBvL2Zvb2ltYWdlJyksXG4gIH0pLFxufSk7XG5cbmNvbnN0IHVzZXIgPSBuZXcgaWFtLlVzZXIoc3RhY2ssICdNeVVzZXInKTtcbmVjc0pvYi5ncmFudFN1Ym1pdEpvYih1c2VyLCBxdWV1ZSk7XG5cbm5ldyBpbnRlZy5JbnRlZ1Rlc3QoYXBwLCAnQmF0Y2hFY3NKb2JEZWZpbml0aW9uVGVzdCcsIHtcbiAgdGVzdENhc2VzOiBbc3RhY2tdLFxufSk7XG5cbmFwcC5zeW50aCgpO1xuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js new file mode 100644 index 0000000000000..5798e3b70f7e9 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js @@ -0,0 +1,41 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const batch = require("../lib"); +const lib_1 = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); +const fairsharePolicy = new batch.FairshareSchedulingPolicy(stack, 'fairshare', { + computeReservation: 75, + schedulingPolicyName: 'joBBQFairsharePolicy', + shareDecay: aws_cdk_lib_1.Duration.hours(1), + shares: [{ + shareIdentifier: 'shareA', + weightFactor: 0.5, + }], +}); +const queue = new batch.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'managedEc2CE', { + vpc, + }), + order: 1, + }], + priority: 10, + schedulingPolicy: fairsharePolicy, +}); +fairsharePolicy.addShare({ + shareIdentifier: 'shareB', + weightFactor: 7, +}); +queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'newManagedEc2CE', { + vpc, +}), 2); +new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuam9iLXF1ZXVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuam9iLXF1ZXVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQTBDO0FBQzFDLDZDQUFtRDtBQUNuRCxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBQ2hDLGdDQUF5RDtBQUV6RCxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ3RDLE1BQU0sR0FBRyxHQUFHLElBQUksYUFBRyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSw0QkFBNEIsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0FBRTNFLE1BQU0sZUFBZSxHQUFHLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxXQUFXLEVBQUU7SUFDOUUsa0JBQWtCLEVBQUUsRUFBRTtJQUN0QixvQkFBb0IsRUFBRSxzQkFBc0I7SUFDNUMsVUFBVSxFQUFFLHNCQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUM3QixNQUFNLEVBQUUsQ0FBQztZQUNQLGVBQWUsRUFBRSxRQUFRO1lBQ3pCLFlBQVksRUFBRSxHQUFHO1NBQ2xCLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtJQUMvQyxtQkFBbUIsRUFBRSxDQUFDO1lBQ3BCLGtCQUFrQixFQUFFLElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtnQkFDN0UsR0FBRzthQUNKLENBQUM7WUFDRixLQUFLLEVBQUUsQ0FBQztTQUNULENBQUM7SUFDRixRQUFRLEVBQUUsRUFBRTtJQUNaLGdCQUFnQixFQUFFLGVBQWU7Q0FDbEMsQ0FBQyxDQUFDO0FBRUgsZUFBZSxDQUFDLFFBQVEsQ0FBQztJQUN2QixlQUFlLEVBQUUsUUFBUTtJQUN6QixZQUFZLEVBQUUsQ0FBQztDQUNoQixDQUFDLENBQUM7QUFFSCxLQUFLLENBQUMscUJBQXFCLENBQ3pCLElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGlCQUFpQixFQUFFO0lBQzVELEdBQUc7Q0FDSixDQUFDLEVBQ0YsQ0FBQyxDQUNGLENBQUM7QUFFRixJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLDJCQUEyQixFQUFFO0lBQ3BELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWcGMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IEFwcCwgU3RhY2ssIER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgaW50ZWcgZnJvbSAnQGF3cy1jZGsvaW50ZWctdGVzdHMtYWxwaGEnO1xuaW1wb3J0ICogYXMgYmF0Y2ggZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQgfSBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3QgdnBjID0gbmV3IFZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbmNvbnN0IGZhaXJzaGFyZVBvbGljeSA9IG5ldyBiYXRjaC5GYWlyc2hhcmVTY2hlZHVsaW5nUG9saWN5KHN0YWNrLCAnZmFpcnNoYXJlJywge1xuICBjb21wdXRlUmVzZXJ2YXRpb246IDc1LFxuICBzY2hlZHVsaW5nUG9saWN5TmFtZTogJ2pvQkJRRmFpcnNoYXJlUG9saWN5JyxcbiAgc2hhcmVEZWNheTogRHVyYXRpb24uaG91cnMoMSksXG4gIHNoYXJlczogW3tcbiAgICBzaGFyZUlkZW50aWZpZXI6ICdzaGFyZUEnLFxuICAgIHdlaWdodEZhY3RvcjogMC41LFxuICB9XSxcbn0pO1xuXG5jb25zdCBxdWV1ZSA9IG5ldyBiYXRjaC5Kb2JRdWV1ZShzdGFjaywgJ2pvQkJRJywge1xuICBjb21wdXRlRW52aXJvbm1lbnRzOiBbe1xuICAgIGNvbXB1dGVFbnZpcm9ubWVudDogbmV3IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdtYW5hZ2VkRWMyQ0UnLCB7XG4gICAgICB2cGMsXG4gICAgfSksXG4gICAgb3JkZXI6IDEsXG4gIH1dLFxuICBwcmlvcml0eTogMTAsXG4gIHNjaGVkdWxpbmdQb2xpY3k6IGZhaXJzaGFyZVBvbGljeSxcbn0pO1xuXG5mYWlyc2hhcmVQb2xpY3kuYWRkU2hhcmUoe1xuICBzaGFyZUlkZW50aWZpZXI6ICdzaGFyZUInLFxuICB3ZWlnaHRGYWN0b3I6IDcsXG59KTtcblxucXVldWUuYWRkQ29tcHV0ZUVudmlyb25tZW50KFxuICBuZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ25ld01hbmFnZWRFYzJDRScsIHtcbiAgICB2cGMsXG4gIH0pLFxuICAyLFxuKTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaEVjc0pvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js new file mode 100644 index 0000000000000..29a0fed0681b9 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js @@ -0,0 +1,78 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const lib_1 = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'batch-stack'); +const vpc = new ec2.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); +new lib_1.FargateComputeEnvironment(stack, 'minimalPropsFargate', { + vpc, + maxvCpus: 512, +}); +new lib_1.FargateComputeEnvironment(stack, 'maximalPropsFargate', { + vpc, + maxvCpus: 512, + computeEnvironmentName: 'maxPropsFargateCE', + replaceComputeEnvironment: true, + spot: true, + terminateOnUpdate: true, + updateTimeout: aws_cdk_lib_1.Duration.minutes(30), + updateToLatestImageVersion: false, +}); +new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'minimalPropsEc2', { + vpc, + images: [{ + image: new ec2.AmazonLinuxImage(), + }], +}); +new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'LaunchTemplate', { + vpc, + images: [{ + image: new ec2.AmazonLinuxImage(), + }], + allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, + minvCpus: 256, + maxvCpus: 512, + replaceComputeEnvironment: true, + terminateOnUpdate: false, + placementGroup: new ec2.PlacementGroup(stack, 'placementGroup'), + updateTimeout: aws_cdk_lib_1.Duration.hours(1), + launchTemplate: new aws_ec2_1.LaunchTemplate(stack, 'launchTemplate'), +}); +new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SpotEc2', { + vpc, + images: [{ + image: new ec2.AmazonLinuxImage(), + }], + spot: true, + spotBidPercentage: 95, + spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { + assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), + }), +}); +new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'AllocationStrategySPOT_CAPACITY', { + vpc, + images: [{ + image: new ec2.AmazonLinuxImage(), + }], + spot: true, + spotBidPercentage: 95, + allocationStrategy: lib_1.AllocationStrategy.SPOT_CAPACITY_OPTIMIZED, +}); +const taggedEc2Ecs = new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'taggedCE', { + vpc, + images: [{ + image: new ec2.AmazonLinuxImage(), + }], +}); +aws_cdk_lib_1.Tags.of(taggedEc2Ecs).add('foo', 'bar'); +aws_cdk_lib_1.Tags.of(taggedEc2Ecs).add('super', 'salamander'); +new integ.IntegTest(app, 'BatchManagedComputeEnvironmentTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsMkNBQTJDO0FBQzNDLGlEQUFxRDtBQUNyRCxpREFBNkQ7QUFDN0QsNkNBQXlEO0FBQ3pELG9EQUFvRDtBQUNwRCxnQ0FBd0c7QUFFeEcsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSxhQUFhLENBQUMsQ0FBQztBQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLDRCQUE0QixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFFL0UsSUFBSSwrQkFBeUIsQ0FBQyxLQUFLLEVBQUUscUJBQXFCLEVBQUU7SUFDMUQsR0FBRztJQUNILFFBQVEsRUFBRSxHQUFHO0NBQ2QsQ0FBQyxDQUFDO0FBRUgsSUFBSSwrQkFBeUIsQ0FBQyxLQUFLLEVBQUUscUJBQXFCLEVBQUU7SUFDMUQsR0FBRztJQUNILFFBQVEsRUFBRSxHQUFHO0lBQ2Isc0JBQXNCLEVBQUUsbUJBQW1CO0lBQzNDLHlCQUF5QixFQUFFLElBQUk7SUFDL0IsSUFBSSxFQUFFLElBQUk7SUFDVixpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLGFBQWEsRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7SUFDbkMsMEJBQTBCLEVBQUUsS0FBSztDQUNsQyxDQUFDLENBQUM7QUFFSCxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxpQkFBaUIsRUFBRTtJQUM1RCxHQUFHO0lBQ0gsTUFBTSxFQUFFLENBQUM7WUFDUCxLQUFLLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLEVBQUU7U0FDbEMsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVILElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixFQUFFO0lBQzNELEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0lBQ0Ysa0JBQWtCLEVBQUUsd0JBQWtCLENBQUMsUUFBUTtJQUMvQyxRQUFRLEVBQUUsR0FBRztJQUNiLFFBQVEsRUFBRSxHQUFHO0lBQ2IseUJBQXlCLEVBQUUsSUFBSTtJQUMvQixpQkFBaUIsRUFBRSxLQUFLO0lBQ3hCLGNBQWMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDO0lBQy9ELGFBQWEsRUFBRSxzQkFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDaEMsY0FBYyxFQUFFLElBQUksd0JBQWMsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUM7Q0FDNUQsQ0FBQyxDQUFDO0FBRUgsSUFBSSxxQ0FBK0IsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO0lBQ3BELEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0lBQ0YsSUFBSSxFQUFFLElBQUk7SUFDVixpQkFBaUIsRUFBRSxFQUFFO0lBQ3JCLGFBQWEsRUFBRSxJQUFJLGNBQUksQ0FBQyxLQUFLLEVBQUUsZUFBZSxFQUFFO1FBQzlDLFNBQVMsRUFBRSxJQUFJLDBCQUFnQixDQUFDLHFCQUFxQixDQUFDO0tBQ3ZELENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxpQ0FBaUMsRUFBRTtJQUM1RSxHQUFHO0lBQ0gsTUFBTSxFQUFFLENBQUM7WUFDUCxLQUFLLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLEVBQUU7U0FDbEMsQ0FBQztJQUNGLElBQUksRUFBRSxJQUFJO0lBQ1YsaUJBQWlCLEVBQUUsRUFBRTtJQUNyQixrQkFBa0IsRUFBRSx3QkFBa0IsQ0FBQyx1QkFBdUI7Q0FDL0QsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSxxQ0FBK0IsQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFO0lBQzFFLEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsa0JBQUksQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUN4QyxrQkFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDO0FBRWpELElBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsb0NBQW9DLEVBQUU7SUFDN0QsU0FBUyxFQUFFLENBQUMsS0FBSyxDQUFDO0NBQ25CLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IExhdW5jaFRlbXBsYXRlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XG5pbXBvcnQgeyBSb2xlLCBTZXJ2aWNlUHJpbmNpcGFsIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWlhbSc7XG5pbXBvcnQgeyBBcHAsIER1cmF0aW9uLCBTdGFjaywgVGFncyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCB7IEFsbG9jYXRpb25TdHJhdGVneSwgRmFyZ2F0ZUNvbXB1dGVFbnZpcm9ubWVudCwgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudCB9IGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ2JhdGNoLXN0YWNrJyk7XG5jb25zdCB2cGMgPSBuZXcgZWMyLlZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbm5ldyBGYXJnYXRlQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnbWluaW1hbFByb3BzRmFyZ2F0ZScsIHtcbiAgdnBjLFxuICBtYXh2Q3B1czogNTEyLFxufSk7XG5cbm5ldyBGYXJnYXRlQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnbWF4aW1hbFByb3BzRmFyZ2F0ZScsIHtcbiAgdnBjLFxuICBtYXh2Q3B1czogNTEyLFxuICBjb21wdXRlRW52aXJvbm1lbnROYW1lOiAnbWF4UHJvcHNGYXJnYXRlQ0UnLFxuICByZXBsYWNlQ29tcHV0ZUVudmlyb25tZW50OiB0cnVlLFxuICBzcG90OiB0cnVlLFxuICB0ZXJtaW5hdGVPblVwZGF0ZTogdHJ1ZSxcbiAgdXBkYXRlVGltZW91dDogRHVyYXRpb24ubWludXRlcygzMCksXG4gIHVwZGF0ZVRvTGF0ZXN0SW1hZ2VWZXJzaW9uOiBmYWxzZSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21pbmltYWxQcm9wc0VjMicsIHtcbiAgdnBjLFxuICBpbWFnZXM6IFt7XG4gICAgaW1hZ2U6IG5ldyBlYzIuQW1hem9uTGludXhJbWFnZSgpLFxuICB9XSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ0xhdW5jaFRlbXBsYXRlJywge1xuICB2cGMsXG4gIGltYWdlczogW3tcbiAgICBpbWFnZTogbmV3IGVjMi5BbWF6b25MaW51eEltYWdlKCksXG4gIH1dLFxuICBhbGxvY2F0aW9uU3RyYXRlZ3k6IEFsbG9jYXRpb25TdHJhdGVneS5CRVNUX0ZJVCxcbiAgbWludkNwdXM6IDI1NixcbiAgbWF4dkNwdXM6IDUxMixcbiAgcmVwbGFjZUNvbXB1dGVFbnZpcm9ubWVudDogdHJ1ZSxcbiAgdGVybWluYXRlT25VcGRhdGU6IGZhbHNlLFxuICBwbGFjZW1lbnRHcm91cDogbmV3IGVjMi5QbGFjZW1lbnRHcm91cChzdGFjaywgJ3BsYWNlbWVudEdyb3VwJyksXG4gIHVwZGF0ZVRpbWVvdXQ6IER1cmF0aW9uLmhvdXJzKDEpLFxuICBsYXVuY2hUZW1wbGF0ZTogbmV3IExhdW5jaFRlbXBsYXRlKHN0YWNrLCAnbGF1bmNoVGVtcGxhdGUnKSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ1Nwb3RFYzInLCB7XG4gIHZwYyxcbiAgaW1hZ2VzOiBbe1xuICAgIGltYWdlOiBuZXcgZWMyLkFtYXpvbkxpbnV4SW1hZ2UoKSxcbiAgfV0sXG4gIHNwb3Q6IHRydWUsXG4gIHNwb3RCaWRQZXJjZW50YWdlOiA5NSxcbiAgc3BvdEZsZWV0Um9sZTogbmV3IFJvbGUoc3RhY2ssICdTcG90RmxlZXRSb2xlJywge1xuICAgIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ2JhdGNoLmFtYXpvbmF3cy5jb20nKSxcbiAgfSksXG59KTtcblxubmV3IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdBbGxvY2F0aW9uU3RyYXRlZ3lTUE9UX0NBUEFDSVRZJywge1xuICB2cGMsXG4gIGltYWdlczogW3tcbiAgICBpbWFnZTogbmV3IGVjMi5BbWF6b25MaW51eEltYWdlKCksXG4gIH1dLFxuICBzcG90OiB0cnVlLFxuICBzcG90QmlkUGVyY2VudGFnZTogOTUsXG4gIGFsbG9jYXRpb25TdHJhdGVneTogQWxsb2NhdGlvblN0cmF0ZWd5LlNQT1RfQ0FQQUNJVFlfT1BUSU1JWkVELFxufSk7XG5cbmNvbnN0IHRhZ2dlZEVjMkVjcyA9IG5ldyBNYW5hZ2VkRWMyRWNzQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAndGFnZ2VkQ0UnLCB7XG4gIHZwYyxcbiAgaW1hZ2VzOiBbe1xuICAgIGltYWdlOiBuZXcgZWMyLkFtYXpvbkxpbnV4SW1hZ2UoKSxcbiAgfV0sXG59KTtcblxuVGFncy5vZih0YWdnZWRFYzJFY3MpLmFkZCgnZm9vJywgJ2JhcicpO1xuVGFncy5vZih0YWdnZWRFYzJFY3MpLmFkZCgnc3VwZXInLCAnc2FsYW1hbmRlcicpO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoTWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js new file mode 100644 index 0000000000000..5c3d60fee788b --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js @@ -0,0 +1,48 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const batch = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'stack'); +new batch.MultiNodeJobDefinition(stack, 'SingleContainerMultiNodeJob', { + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + containers: [{ + startNode: 0, + endNode: 10, + container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }], + propagateTags: true, +}); +const multinodeJob = new batch.MultiNodeJobDefinition(stack, 'MultiContainerMultiNodeJob', { + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + containers: [{ + startNode: 0, + endNode: 10, + container: new batch.EcsEc2ContainerDefinition(stack, 'multinodecontainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), + }], +}); +multinodeJob.addContainer({ + startNode: 11, + endNode: 20, + container: new batch.EcsEc2ContainerDefinition(stack, 'multiContainer', { + image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + }), +}); +new integ.IntegTest(app, 'BatchMultiNodeJobDefinitionTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcubXVsdGlub2RlLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcubXVsdGlub2RlLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQWdGO0FBQ2hGLGlEQUFxRDtBQUNyRCw2Q0FBK0M7QUFDL0Msb0RBQW9EO0FBQ3BELGdDQUFnQztBQUVoQyxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBRXRDLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSw2QkFBNkIsRUFBRTtJQUNyRSxZQUFZLEVBQUUsc0JBQVksQ0FBQyxFQUFFLENBQUMsdUJBQWEsQ0FBQyxFQUFFLEVBQUUsc0JBQVksQ0FBQyxLQUFLLENBQUM7SUFDbkUsVUFBVSxFQUFFLENBQUM7WUFDWCxTQUFTLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxFQUFFO1lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxhQUFhLEVBQUU7Z0JBQ25FLEtBQUssRUFBRSx3QkFBYyxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztnQkFDOUQsR0FBRyxFQUFFLEdBQUc7Z0JBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQzthQUM3QixDQUFDO1NBQ0gsQ0FBQztJQUNGLGFBQWEsRUFBRSxJQUFJO0NBQ3BCLENBQUMsQ0FBQztBQUVILE1BQU0sWUFBWSxHQUFHLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSw0QkFBNEIsRUFBRTtJQUN6RixZQUFZLEVBQUUsc0JBQVksQ0FBQyxFQUFFLENBQUMsdUJBQWEsQ0FBQyxFQUFFLEVBQUUsc0JBQVksQ0FBQyxLQUFLLENBQUM7SUFDbkUsVUFBVSxFQUFFLENBQUM7WUFDWCxTQUFTLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxFQUFFO1lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxvQkFBb0IsRUFBRTtnQkFDMUUsS0FBSyxFQUFFLHdCQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO2dCQUM5RCxHQUFHLEVBQUUsR0FBRztnQkFDUixNQUFNLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO2FBQzdCLENBQUM7U0FDSCxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsWUFBWSxDQUFDLFlBQVksQ0FBQztJQUN4QixTQUFTLEVBQUUsRUFBRTtJQUNiLE9BQU8sRUFBRSxFQUFFO0lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsRUFBRTtRQUN0RSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsMEJBQTBCLENBQUM7UUFDOUQsR0FBRyxFQUFFLEdBQUc7UUFDUixNQUFNLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0tBQzdCLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLGlDQUFpQyxFQUFFO0lBQzFELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnN0YW5jZUNsYXNzLCBJbnN0YW5jZVNpemUsIEluc3RhbmNlVHlwZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xuaW1wb3J0IHsgQ29udGFpbmVySW1hZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IEFwcCwgU2l6ZSwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBpbnRlZyBmcm9tICdAYXdzLWNkay9pbnRlZy10ZXN0cy1hbHBoYSc7XG5pbXBvcnQgKiBhcyBiYXRjaCBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuXG5uZXcgYmF0Y2guTXVsdGlOb2RlSm9iRGVmaW5pdGlvbihzdGFjaywgJ1NpbmdsZUNvbnRhaW5lck11bHRpTm9kZUpvYicsIHtcbiAgaW5zdGFuY2VUeXBlOiBJbnN0YW5jZVR5cGUub2YoSW5zdGFuY2VDbGFzcy5SNCwgSW5zdGFuY2VTaXplLkxBUkdFKSxcbiAgY29udGFpbmVyczogW3tcbiAgICBzdGFydE5vZGU6IDAsXG4gICAgZW5kTm9kZTogMTAsXG4gICAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ215Q29udGFpbmVyJywge1xuICAgICAgaW1hZ2U6IENvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgICBjcHU6IDI1NixcbiAgICAgIG1lbW9yeTogU2l6ZS5tZWJpYnl0ZXMoMjA0OCksXG4gICAgfSksXG4gIH1dLFxuICBwcm9wYWdhdGVUYWdzOiB0cnVlLFxufSk7XG5cbmNvbnN0IG11bHRpbm9kZUpvYiA9IG5ldyBiYXRjaC5NdWx0aU5vZGVKb2JEZWZpbml0aW9uKHN0YWNrLCAnTXVsdGlDb250YWluZXJNdWx0aU5vZGVKb2InLCB7XG4gIGluc3RhbmNlVHlwZTogSW5zdGFuY2VUeXBlLm9mKEluc3RhbmNlQ2xhc3MuUjQsIEluc3RhbmNlU2l6ZS5MQVJHRSksXG4gIGNvbnRhaW5lcnM6IFt7XG4gICAgc3RhcnROb2RlOiAwLFxuICAgIGVuZE5vZGU6IDEwLFxuICAgIGNvbnRhaW5lcjogbmV3IGJhdGNoLkVjc0VjMkNvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdtdWx0aW5vZGVjb250YWluZXInLCB7XG4gICAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICAgIGNwdTogMjU2LFxuICAgICAgbWVtb3J5OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgICB9KSxcbiAgfV0sXG59KTtcblxubXVsdGlub2RlSm9iLmFkZENvbnRhaW5lcih7XG4gIHN0YXJ0Tm9kZTogMTEsXG4gIGVuZE5vZGU6IDIwLFxuICBjb250YWluZXI6IG5ldyBiYXRjaC5FY3NFYzJDb250YWluZXJEZWZpbml0aW9uKHN0YWNrLCAnbXVsdGlDb250YWluZXInLCB7XG4gICAgaW1hZ2U6IENvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgY3B1OiAyNTYsXG4gICAgbWVtb3J5OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgfSksXG59KTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaE11bHRpTm9kZUpvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js new file mode 100644 index 0000000000000..55a17c9cfbbe7 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js @@ -0,0 +1,25 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const integ = require("@aws-cdk/integ-tests-alpha"); +const lib_1 = require("../lib"); +const app = new aws_cdk_lib_1.App(); +const stack = new aws_cdk_lib_1.Stack(app, 'batch-stack'); +new lib_1.UnmanagedComputeEnvironment(stack, 'minimalProps'); +new lib_1.UnmanagedComputeEnvironment(stack, 'maximalProps', { + computeEnvironmentName: 'unmanagedIntegTestCE', + enabled: true, + unmanagedvCpus: 256, + serviceRole: new aws_iam_1.Role(stack, 'IntegServiceRole', { + managedPolicies: [ + aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSBatchServiceRole'), + ], + assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), + }), +}); +new integ.IntegTest(app, 'BatchManagedComputeEnvironmentTest', { + testCases: [stack], +}); +app.synth(); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcudW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy51bm1hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUE0RTtBQUM1RSw2Q0FBeUM7QUFDekMsb0RBQW9EO0FBQ3BELGdDQUFxRDtBQUVyRCxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0FBRTVDLElBQUksaUNBQTJCLENBQUMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0FBRXZELElBQUksaUNBQTJCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtJQUNyRCxzQkFBc0IsRUFBRSxzQkFBc0I7SUFDOUMsT0FBTyxFQUFFLElBQUk7SUFDYixjQUFjLEVBQUUsR0FBRztJQUNuQixXQUFXLEVBQUUsSUFBSSxjQUFJLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFO1FBQy9DLGVBQWUsRUFBRTtZQUNmLHVCQUFhLENBQUMsd0JBQXdCLENBQUMsa0NBQWtDLENBQUM7U0FDM0U7UUFDRCxTQUFTLEVBQUUsSUFBSSwwQkFBZ0IsQ0FBQyxxQkFBcUIsQ0FBQztLQUN2RCxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxvQ0FBb0MsRUFBRTtJQUM3RCxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWFuYWdlZFBvbGljeSwgUm9sZSwgU2VydmljZVByaW5jaXBhbCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgQXBwLCBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCB7IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudCB9IGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ2JhdGNoLXN0YWNrJyk7XG5cbm5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdtaW5pbWFsUHJvcHMnKTtcblxubmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21heGltYWxQcm9wcycsIHtcbiAgY29tcHV0ZUVudmlyb25tZW50TmFtZTogJ3VubWFuYWdlZEludGVnVGVzdENFJyxcbiAgZW5hYmxlZDogdHJ1ZSxcbiAgdW5tYW5hZ2VkdkNwdXM6IDI1NixcbiAgc2VydmljZVJvbGU6IG5ldyBSb2xlKHN0YWNrLCAnSW50ZWdTZXJ2aWNlUm9sZScsIHtcbiAgICBtYW5hZ2VkUG9saWNpZXM6IFtcbiAgICAgIE1hbmFnZWRQb2xpY3kuZnJvbUF3c01hbmFnZWRQb2xpY3lOYW1lKCdzZXJ2aWNlLXJvbGUvQVdTQmF0Y2hTZXJ2aWNlUm9sZScpLFxuICAgIF0sXG4gICAgYXNzdW1lZEJ5OiBuZXcgU2VydmljZVByaW5jaXBhbCgnYmF0Y2guYW1hem9uYXdzLmNvbScpLFxuICB9KSxcbn0pO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoTWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js new file mode 100644 index 0000000000000..5a3ad995469b0 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js @@ -0,0 +1,205 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const utils_1 = require("./utils"); +const batch = require("../lib"); +const defaultExpectedEcsProps = { + type: 'container', + platformCapabilities: [batch.Compatibility.EC2], +}; +const defaultExpectedEksProps = { + type: 'container', +}; +const defaultExpectedMultiNodeProps = { + type: 'multinode', +}; +let stack; +let pascalCaseExpectedEcsProps; +let pascalCaseExpectedEksProps; +let pascalCaseExpectedMultiNodeProps; +let defaultEcsProps; +let defaultEksProps; +let defaultMultiNodeProps; +let expectedProps; +let defaultProps; +describe.each([batch.EcsJobDefinition, batch.EksJobDefinition, batch.MultiNodeJobDefinition])('%p type JobDefinition', (JobDefinition) => { + // GIVEN + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); + pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); + pascalCaseExpectedMultiNodeProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedMultiNodeProps); + defaultEcsProps = { + container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + }; + defaultEksProps = { + container: new batch.EksContainerDefinition(stack, 'EksContainer', { + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + }; + defaultMultiNodeProps = { + containers: [{ + container: new batch.EcsEc2ContainerDefinition(stack, 'MultinodeEcsContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 0, + endNode: 10, + }], + mainNode: 0, + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + }; + switch (JobDefinition) { + case batch.EcsJobDefinition: + expectedProps = pascalCaseExpectedEcsProps; + defaultProps = defaultEcsProps; + break; + case batch.EksJobDefinition: + expectedProps = pascalCaseExpectedEksProps; + defaultProps = defaultEksProps; + break; + case batch.MultiNodeJobDefinition: + expectedProps = pascalCaseExpectedMultiNodeProps; + defaultProps = defaultMultiNodeProps; + break; + } + }); + test('JobDefinition respects name', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + jobDefinitionName: 'myEcsJob', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + JobDefinitionName: 'myEcsJob', + }); + }); + test('JobDefinition respects parameters', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + parameters: { + foo: 'bar', + }, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + Parameters: { + foo: 'bar', + }, + }); + }); + test('JobDefinition respects retryAttempts', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + retryAttempts: 8, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + RetryStrategy: { + Attempts: 8, + }, + }); + }); + test('JobDefinition respects retryStrategies', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + retryStrategies: [ + batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER), + batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE), + batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED), + batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.custom({ + onExitCode: '40*', + onReason: 'reason*', + onStatusReason: 'statusReason', + })), + ], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + RetryStrategy: { + EvaluateOnExit: [ + { + Action: 'EXIT', + OnReason: 'CannotPullContainerError:*', + }, + { + Action: 'RETRY', + OnExitCode: '*', + }, + { + Action: 'RETRY', + OnStatusReason: 'Host EC2*', + }, + { + Action: 'RETRY', + OnExitCode: '40*', + OnReason: 'reason*', + OnStatusReason: 'statusReason', + }, + ], + }, + }); + }); + test('JobDefinition respects schedulingPriority', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + schedulingPriority: 10, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + SchedulingPriority: 10, + }); + }); + test('JobDefinition respects schedulingPriority', () => { + // WHEN + new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + timeout: aws_cdk_lib_1.Duration.minutes(10), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + Timeout: { + AttemptDurationSeconds: 600, + }, + }); + }); + test('JobDefinition respects addRetryStrategy()', () => { + // WHEN + const jobDefn = new JobDefinition(stack, 'JobDefn', { + ...defaultProps, + }); + jobDefn.addRetryStrategy(batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED)); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + ...expectedProps, + RetryStrategy: { + EvaluateOnExit: [ + { + Action: 'RETRY', + OnStatusReason: 'Host EC2*', + }, + ], + }, + }); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-definition-base.test.js","sourceRoot":"","sources":["job-definition-base.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { /*Aws,*/ Duration, Size, Stack } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport * as batch from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\nconst defaultExpectedEcsProps: CfnJobDefinitionProps = {\n  type: 'container',\n  platformCapabilities: [batch.Compatibility.EC2],\n};\nconst defaultExpectedEksProps: CfnJobDefinitionProps = {\n  type: 'container',\n};\nconst defaultExpectedMultiNodeProps: CfnJobDefinitionProps = {\n  type: 'multinode',\n};\n\nlet stack: Stack;\n\nlet pascalCaseExpectedEcsProps: any;\nlet pascalCaseExpectedEksProps: any;\nlet pascalCaseExpectedMultiNodeProps: any;\n\nlet defaultEcsProps: batch.EcsJobDefinitionProps;\nlet defaultEksProps: batch.EksJobDefinitionProps;\nlet defaultMultiNodeProps: batch.MultiNodeJobDefinitionProps;\n\nlet expectedProps: any;\nlet defaultProps: any;\n\ndescribe.each([batch.EcsJobDefinition, batch.EksJobDefinition, batch.MultiNodeJobDefinition])('%p type JobDefinition', (JobDefinition) => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    pascalCaseExpectedMultiNodeProps = capitalizePropertyNames(stack, defaultExpectedMultiNodeProps);\n\n    defaultEcsProps = {\n      container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n    };\n    defaultEksProps = {\n      container: new batch.EksContainerDefinition(stack, 'EksContainer', {\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n    };\n    defaultMultiNodeProps = {\n      containers: [{\n        container: new batch.EcsEc2ContainerDefinition(stack, 'MultinodeEcsContainer', {\n          cpu: 256,\n          memory: Size.mebibytes(2048),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 0,\n        endNode: 10,\n      }],\n      mainNode: 0,\n      instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n    };\n    switch (JobDefinition) {\n      case batch.EcsJobDefinition:\n        expectedProps = pascalCaseExpectedEcsProps;\n        defaultProps = defaultEcsProps;\n        break;\n      case batch.EksJobDefinition:\n        expectedProps = pascalCaseExpectedEksProps;\n        defaultProps = defaultEksProps;\n        break;\n      case batch.MultiNodeJobDefinition:\n        expectedProps = pascalCaseExpectedMultiNodeProps;\n        defaultProps = defaultMultiNodeProps;\n        break;\n    }\n  });\n\n  test('JobDefinition respects name', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      jobDefinitionName: 'myEcsJob',\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      JobDefinitionName: 'myEcsJob',\n    });\n  });\n\n  test('JobDefinition respects parameters', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      parameters: {\n        foo: 'bar',\n      },\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      Parameters: {\n        foo: 'bar',\n      },\n    });\n  });\n\n  test('JobDefinition respects retryAttempts', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      retryAttempts: 8,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        Attempts: 8,\n      },\n    });\n  });\n\n  test('JobDefinition respects retryStrategies', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      retryStrategies: [\n        batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.custom({\n          onExitCode: '40*',\n          onReason: 'reason*',\n          onStatusReason: 'statusReason',\n        })),\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        EvaluateOnExit: [\n          {\n            Action: 'EXIT',\n            OnReason: 'CannotPullContainerError:*',\n          },\n          {\n            Action: 'RETRY',\n            OnExitCode: '*',\n          },\n          {\n            Action: 'RETRY',\n            OnStatusReason: 'Host EC2*',\n          },\n          {\n            Action: 'RETRY',\n            OnExitCode: '40*',\n            OnReason: 'reason*',\n            OnStatusReason: 'statusReason',\n          },\n        ],\n      },\n    });\n  });\n\n  test('JobDefinition respects schedulingPriority', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      schedulingPriority: 10,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      SchedulingPriority: 10,\n    });\n  });\n\n  test('JobDefinition respects schedulingPriority', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      timeout: Duration.minutes(10),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      Timeout: {\n        AttemptDurationSeconds: 600,\n      },\n    });\n  });\n\n  test('JobDefinition respects addRetryStrategy()', () => {\n    // WHEN\n    const jobDefn = new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n    });\n\n    jobDefn.addRetryStrategy(batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        EvaluateOnExit: [\n          {\n            Action: 'RETRY',\n            OnStatusReason: 'Host EC2*',\n          },\n        ],\n      },\n    });\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js new file mode 100644 index 0000000000000..b15482f2d3cc1 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js @@ -0,0 +1,228 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const lib_1 = require("../lib"); +test('JobQueue respects computeEnvironments', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + new lib_1.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { + vpc, + }), + order: 1, + }], + priority: 10, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { + ComputeEnvironmentOrder: [{ + ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, + Order: 1, + }], + Priority: 10, + State: 'ENABLED', + }); +}); +test('JobQueue respects enabled', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + new lib_1.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { + vpc, + }), + order: 1, + }], + priority: 10, + enabled: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { + ComputeEnvironmentOrder: [{ + ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, + Order: 1, + }], + Priority: 10, + State: 'DISABLED', + }); +}); +test('JobQueue respects name', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + new lib_1.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { + vpc, + }), + order: 1, + }], + priority: 10, + jobQueueName: 'JoBBQ', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { + ComputeEnvironmentOrder: [{ + ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, + Order: 1, + }], + Priority: 10, + JobQueueName: 'JoBBQ', + }); +}); +test('JobQueue name is parsed from arn', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + const queue = new lib_1.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { + vpc, + }), + order: 1, + }], + priority: 10, + jobQueueName: 'JoBBQ', + }); + // THEN + expect(aws_cdk_lib_1.Tokenization.resolve(queue.jobQueueName, { + scope: stack, + resolver: new aws_cdk_lib_1.DefaultTokenResolver(new aws_cdk_lib_1.StringConcat()), + })).toEqual({ + 'Fn::Select': [ + 1, + { + 'Fn::Split': [ + '/', + { + 'Fn::Select': [ + 5, + { + 'Fn::Split': [ + ':', + { + 'Fn::GetAtt': [ + 'joBBQ9FD52DAF', + 'JobQueueArn', + ], + }, + ], + }, + ], + }, + ], + }, + ], + }); +}); +test('JobQueue respects schedulingPolicy', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + new lib_1.JobQueue(stack, 'JobQueue', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { + vpc, + }), + order: 1, + }], + priority: 10, + schedulingPolicy: new lib_1.FairshareSchedulingPolicy(stack, 'FairsharePolicy'), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { + ComputeEnvironmentOrder: [{ + ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, + Order: 1, + }], + Priority: 10, + SchedulingPolicyArn: { + 'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'], + }, + }); +}); +test('JobQueue respects addComputeEnvironment', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + const queue = new lib_1.JobQueue(stack, 'JobQueue', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', { + vpc, + }), + order: 1, + }], + priority: 10, + schedulingPolicy: new lib_1.FairshareSchedulingPolicy(stack, 'FairsharePolicy'), + }); + queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', { + vpc, + }), 2); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { + ComputeEnvironmentOrder: [ + { + ComputeEnvironment: { 'Fn::GetAtt': ['FirstCEAD3794AD', 'ComputeEnvironmentArn'] }, + Order: 1, + }, + { + ComputeEnvironment: { 'Fn::GetAtt': ['SecondCEEBA93938', 'ComputeEnvironmentArn'] }, + Order: 2, + }, + ], + Priority: 10, + SchedulingPolicyArn: { + 'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'], + }, + }); +}); +test('can be imported from ARN', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + const queue = lib_1.JobQueue.fromJobQueueArn(stack, 'importedJobQueue', 'arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue'); + // THEN + expect(queue.jobQueueArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue'); +}); +test('JobQueue throws when the same order is assigned to multiple ComputeEnvironments', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + const vpc = new ec2.Vpc(stack, 'vpc'); + // WHEN + const joBBQ = new lib_1.JobQueue(stack, 'joBBQ', { + computeEnvironments: [{ + computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', { + vpc, + }), + order: 1, + }], + priority: 10, + }); + joBBQ.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', { + vpc, + }), 1); + expect(() => { + assertions_1.Template.fromStack(stack); + }).toThrow(/assigns the same order to different ComputeEnvironments/); +}); +test('JobQueue throws when there are no linked ComputeEnvironments', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.JobQueue(stack, 'joBBQ'); + expect(() => { + assertions_1.Template.fromStack(stack); + }).toThrow(/This JobQueue does not link any ComputeEnvironments/); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-queue.test.js","sourceRoot":"","sources":["job-queue.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { DefaultTokenResolver, Stack, StringConcat, Tokenization } from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport { FairshareSchedulingPolicy, JobQueue, ManagedEc2EcsComputeEnvironment } from '../lib';\n\ntest('JobQueue respects computeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    State: 'ENABLED',\n  });\n});\n\ntest('JobQueue respects enabled', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    enabled: false,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    State: 'DISABLED',\n  });\n});\n\ntest('JobQueue respects name', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    jobQueueName: 'JoBBQ',\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    JobQueueName: 'JoBBQ',\n  });\n});\n\ntest('JobQueue name is parsed from arn', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const queue = new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    jobQueueName: 'JoBBQ',\n  });\n\n  // THEN\n  expect(Tokenization.resolve(queue.jobQueueName, {\n    scope: stack,\n    resolver: new DefaultTokenResolver(new StringConcat()),\n  })).toEqual({\n    'Fn::Select': [\n      1,\n      {\n        'Fn::Split': [\n          '/',\n          {\n            'Fn::Select': [\n              5,\n              {\n                'Fn::Split': [\n                  ':',\n                  {\n                    'Fn::GetAtt': [\n                      'joBBQ9FD52DAF',\n                      'JobQueueArn',\n                    ],\n                  },\n                ],\n              },\n            ],\n          },\n        ],\n      },\n    ],\n  });\n});\n\ntest('JobQueue respects schedulingPolicy', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    schedulingPolicy: new FairshareSchedulingPolicy(stack, 'FairsharePolicy'),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    SchedulingPolicyArn: {\n      'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'],\n    },\n  });\n});\n\ntest('JobQueue respects addComputeEnvironment', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const queue = new JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    schedulingPolicy: new FairshareSchedulingPolicy(stack, 'FairsharePolicy'),\n  });\n\n  queue.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', {\n      vpc,\n    }),\n    2,\n  );\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [\n      {\n        ComputeEnvironment: { 'Fn::GetAtt': ['FirstCEAD3794AD', 'ComputeEnvironmentArn'] },\n        Order: 1,\n      },\n      {\n        ComputeEnvironment: { 'Fn::GetAtt': ['SecondCEEBA93938', 'ComputeEnvironmentArn'] },\n        Order: 2,\n      },\n    ],\n    Priority: 10,\n    SchedulingPolicyArn: {\n      'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'],\n    },\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const queue = JobQueue.fromJobQueueArn(stack, 'importedJobQueue',\n    'arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue');\n\n  // THEN\n  expect(queue.jobQueueArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue');\n});\n\ntest('JobQueue throws when the same order is assigned to multiple ComputeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const joBBQ = new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n  });\n\n  joBBQ.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', {\n      vpc,\n    }),\n    1,\n  );\n\n  expect(() => {\n    Template.fromStack(stack);\n  }).toThrow(/assigns the same order to different ComputeEnvironments/);\n});\n\ntest('JobQueue throws when there are no linked ComputeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ');\n\n  expect(() => {\n    Template.fromStack(stack);\n  }).toThrow(/This JobQueue does not link any ComputeEnvironments/);\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js new file mode 100644 index 0000000000000..012dc0b22f7ed --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js @@ -0,0 +1,860 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const ec2 = require("aws-cdk-lib/aws-ec2"); +const eks = require("aws-cdk-lib/aws-eks"); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const utils_1 = require("./utils"); +const batch = require("../lib"); +const lib_1 = require("../lib"); +const defaultExpectedEcsProps = { + type: 'managed', + computeEnvironmentName: undefined, + serviceRole: undefined, + state: 'ENABLED', + eksConfiguration: undefined, + computeResources: { + allocationStrategy: lib_1.AllocationStrategy.BEST_FIT_PROGRESSIVE, + bidPercentage: undefined, + desiredvCpus: undefined, + maxvCpus: 256, + type: 'EC2', + ec2Configuration: undefined, + minvCpus: 0, + subnets: [ + { Ref: 'vpcPrivateSubnet1Subnet934893E8' }, + { Ref: 'vpcPrivateSubnet2Subnet7031C2BA' }, + ], + ec2KeyPair: undefined, + imageId: undefined, + instanceRole: { 'Fn::GetAtt': ['MyCEInstanceProfile6D69963F', 'Arn'] }, + instanceTypes: ['optimal'], + launchTemplate: undefined, + placementGroup: undefined, + securityGroupIds: [{ + 'Fn::GetAtt': ['MyCESecurityGroup81DCAA06', 'GroupId'], + }], + spotIamFleetRole: undefined, + updateToLatestImageVersion: true, + }, + replaceComputeEnvironment: false, +}; +const defaultExpectedEksProps = { + ...defaultExpectedEcsProps, + eksConfiguration: { + eksClusterArn: { + 'Fn::GetAtt': ['eksTestCluster1B416C0E', 'Arn'], + }, + kubernetesNamespace: 'cdk-test-namespace', + }, +}; +let stack; +let vpc; +let pascalCaseExpectedEcsProps; +let pascalCaseExpectedEksProps; +let defaultComputeResources; +let defaultEcsProps; +let defaultEksProps; +let expectedProps; +let defaultProps; +describe.each([lib_1.ManagedEc2EcsComputeEnvironment, lib_1.ManagedEc2EksComputeEnvironment])('%p type ComputeEnvironment', (ComputeEnvironment) => { + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + vpc = new ec2.Vpc(stack, 'vpc'); + pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); + pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); + defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; + defaultEcsProps = { + vpc, + }; + defaultEksProps = { + vpc, + kubernetesNamespace: 'cdk-test-namespace', + eksCluster: new eks.Cluster(stack, 'eksTestCluster', { + version: eks.KubernetesVersion.V1_24, + }), + }; + expectedProps = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment + ? pascalCaseExpectedEcsProps + : pascalCaseExpectedEksProps; + defaultProps = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment + ? defaultEcsProps + : defaultEksProps; + }); + test('default props', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', { + Roles: [{ Ref: 'MyCEInstanceProfileRole895D248D' }], + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + AssumeRolePolicyDocument: { + Statement: [{ + Action: 'sts:AssumeRole', + Effect: 'Allow', + Principal: { Service: 'ec2.amazonaws.com' }, + }], + Version: '2012-10-17', + }, + }); + }); + test('can specify maxvCpus', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + maxvCpus: 512, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + MaxvCpus: 512, + }, + }); + }); + test('can specify minvCpus', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + minvCpus: 8, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + MinvCpus: 8, + }, + }); + }); + test('can be disabled', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + enabled: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + State: 'DISABLED', + }); + }); + test('spot => AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spot: true, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + Type: 'SPOT', + AllocationStrategy: 'SPOT_PRICE_CAPACITY_OPTIMIZED', + }, + }); + }); + test('images are correctly rendered as EC2ConfigurationObjects', () => { + const expectedImageType = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment + ? batch.EcsMachineImageType.ECS_AL2 + : batch.EksMachineImageType.EKS_AL2; + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + images: [ + { + image: ec2.MachineImage.latestAmazonLinux2(), + }, + ], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + Ec2Configuration: [ + { + ImageIdOverride: { Ref: 'SsmParameterValueawsserviceamiamazonlinuxlatestamzn2amikernel510hvmx8664gp2C96584B6F00A464EAD1953AFF4B05118Parameter' }, + ImageType: expectedImageType, + }, + ], + }, + }); + }); + test('instance classes are correctly rendered', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + instanceClasses: [ec2.InstanceClass.R4], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + InstanceTypes: [ + 'r4', + 'optimal', + ], + }, + }); + }); + test('instance types are correctly rendered', () => { + // WHEN + const ce = new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE)], + }); + ce.addInstanceClass(ec2.InstanceClass.M4); + ce.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.LARGE)); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + InstanceTypes: [ + 'r4.large', + 'c4.large', + 'm4', + 'optimal', + ], + }, + }); + }); + test('respects useOptimalInstanceClasses: false', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + useOptimalInstanceClasses: false, + instanceClasses: [ec2.InstanceClass.R4], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + InstanceTypes: [ + 'r4', + ], + }, + }); + }); + test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceClass()', () => { + // WHEN + const myCE = new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + useOptimalInstanceClasses: false, + }); + myCE.addInstanceClass(ec2.InstanceClass.C4); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + InstanceTypes: [ + 'c4', + ], + }, + }); + }); + test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceType()', () => { + // WHEN + const myCE = new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + useOptimalInstanceClasses: false, + }); + myCE.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.XLARGE112)); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + InstanceTypes: [ + 'c4.112xlarge', + ], + }, + }); + }); + test('creates and uses instanceProfile, even when instanceRole is specified', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + instanceRole: new aws_iam_1.Role(stack, 'myRole', { + assumedBy: new aws_iam_1.ServicePrincipal('foo.amazonaws.com', { + region: 'bermuda-triangle-1337', + }), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + // instanceRole is unchanged from default + }, + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', { + Roles: [{ Ref: 'myRoleE60D68E8' }], + }); + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + AssumeRolePolicyDocument: { + Statement: [{ + Action: 'sts:AssumeRole', + Effect: 'Allow', + Principal: { Service: 'foo.amazonaws.com' }, + }], + Version: '2012-10-17', + }, + }); + }); + test('respects launch template', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + launchTemplate: new ec2.LaunchTemplate(stack, 'launchTemplate'), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + LaunchTemplate: { + LaunchTemplateId: { Ref: 'launchTemplateDEE5742D' }, + }, + }, + }); + }); + test('respects name', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + computeEnvironmentName: 'NamedCE', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeEnvironmentName: 'NamedCE', + ComputeResources: { + ...defaultComputeResources, + }, + }); + }); + test('respects placement group', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + placementGroup: new ec2.PlacementGroup(stack, 'myPlacementGroup'), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + PlacementGroup: { + 'Fn::GetAtt': ['myPlacementGroup2E94D14E', 'GroupName'], + }, + }, + }); + }); + test('respects replaceComputeEnvironment', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + replaceComputeEnvironment: true, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + }, + ReplaceComputeEnvironment: true, + }); + }); + test('respects security groups', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + securityGroups: [new ec2.SecurityGroup(stack, 'TestSG', { + vpc, + allowAllOutbound: false, + })], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + SecurityGroupIds: [{ + 'Fn::GetAtt': ['TestSG581D3391', 'GroupId'], + }], + }, + }); + }); + test('respects service role', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + serviceRole: new aws_iam_1.Role(stack, 'TestSLR', { + assumedBy: new aws_iam_1.ServicePrincipal('cdk.amazonaws.com'), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ServiceRole: { + 'Fn::GetAtt': ['TestSLR05974C22', 'Arn'], + }, + ComputeResources: { + ...defaultComputeResources, + }, + }); + }); + test('respects vpcSubnets', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpcSubnets: { + subnets: [new ec2.Subnet(stack, 'testSubnet', { + availabilityZone: 'az-3', + cidrBlock: '10.0.0.0/32', + vpcId: new ec2.Vpc(stack, 'subnetVpc').vpcId, + })], + }, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + Subnets: [ + { Ref: 'testSubnet42F0FA0C' }, + ], + }, + }); + }); + test('respects updateTimeout', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + updateTimeout: aws_cdk_lib_1.Duration.minutes(1), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + }, + UpdatePolicy: { + JobExecutionTimeoutMinutes: 1, + }, + }); + }); + test('respects terminateOnUpdate', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + terminateOnUpdate: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + }, + UpdatePolicy: { + TerminateJobsOnUpdate: false, + }, + }); + }); + test('respects updateToLatestImageVersion', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + updateToLatestImageVersion: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + UpdateToLatestImageVersion: false, + }, + }); + }); + test('respects tags', () => { + // WHEN + const ce = new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + }); + aws_cdk_lib_1.Tags.of(ce).add('superfood', 'acai'); + aws_cdk_lib_1.Tags.of(ce).add('super', 'salamander'); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...expectedProps, + ComputeResources: { + ...defaultComputeResources, + Tags: { + superfood: 'acai', + super: 'salamander', + }, + }, + }); + }); + test('can be imported from arn', () => { + // WHEN + const ce = lib_1.ManagedEc2EcsComputeEnvironment.fromManagedEc2EcsComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); + // THEN + expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); + }); + test('attach necessary managed policy to instance role', () => { + // WHEN + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { + ManagedPolicyArns: [ + { + 'Fn::Join': [ + '', + [ + 'arn:', + { + Ref: 'AWS::Partition', + }, + ':iam::aws:policy/service-role/AmazonEC2ContainerServiceforEC2Role', + ], + ], + }, + ], + }); + }); + test('throws when no instance types are provided', () => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + useOptimalInstanceClasses: false, + vpc, + }); + expect(() => { + assertions_1.Template.fromStack(stack); + }).toThrow(/Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes/); + }); + test('throws error when AllocationStrategy.SPOT_CAPACITY_OPTIMIZED is used without specfiying spot', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + allocationStrategy: lib_1.AllocationStrategy.SPOT_CAPACITY_OPTIMIZED, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances/); + }); + test('throws error when AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED is used without specfiying spot', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + allocationStrategy: lib_1.AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances/); + }); + test('throws error when spotBidPercentage is specified without spot', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spotBidPercentage: 80, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/); + }); + test('throws error when spotBidPercentage is specified and spot is false', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spotBidPercentage: 80, + spot: false, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/); + }); + test('throws error when spotBidPercentage > 100', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spotBidPercentage: 120, + spot: true, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' > 100/); + }); + test('throws error when spotBidPercentage < 0', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spotBidPercentage: -120, + spot: true, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' < 0/); + }); + test('throws error when minvCpus > maxvCpus', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + maxvCpus: 512, + minvCpus: 1024, + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = 1024 > 'maxvCpus' = 512; 'minvCpus' cannot be greater than 'maxvCpus'/); + }); + test('throws error when minvCpus < 0', () => { + // THEN + expect(() => { + new ComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + minvCpus: -256, + }); + }).toThrowError(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = -256 < 0; 'minvCpus' cannot be less than zero/); + }); +}); +describe('ManagedEc2EcsComputeEnvironment', () => { + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + vpc = new ec2.Vpc(stack, 'vpc'); + pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); + pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); + defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; + defaultEcsProps = { + vpc, + }; + defaultEksProps = { + vpc, + kubernetesNamespace: 'cdk-test-namespace', + eksCluster: new eks.Cluster(stack, 'eksTestCluster', { + version: eks.KubernetesVersion.V1_24, + }), + }; + }); + test('respects spotFleetRole', () => { + // WHEN + new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { + ...defaultEcsProps, + spot: true, + spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { + assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEcsProps, + ComputeResources: { + ...defaultComputeResources, + AllocationStrategy: lib_1.AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED, + Type: 'SPOT', + SpotIamFleetRole: { + 'Fn::GetAtt': ['SpotFleetRole6D4F7558', 'Arn'], + }, + }, + }); + }); + test('image types are correctly rendered as EC2ConfigurationObjects', () => { + // WHEN + new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { + ...defaultEcsProps, + vpc, + images: [ + { + imageType: batch.EcsMachineImageType.ECS_AL2_NVIDIA, + }, + ], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEcsProps, + ComputeResources: { + ...defaultComputeResources, + Ec2Configuration: [ + { + ImageType: 'ECS_AL2_NVIDIA', + }, + ], + }, + }); + }); + test('can use non-default allocation strategy', () => { + // WHEN + new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEcsProps, + ComputeResources: { + ...defaultComputeResources, + AllocationStrategy: 'BEST_FIT', + }, + }); + }); + test('spot and AllocationStrategy.BEST_FIT => a default spot fleet role is created', () => { + // WHEN + new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + vpc, + spot: true, + allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEcsProps, + ComputeResources: { + ...defaultComputeResources, + Type: 'SPOT', + AllocationStrategy: 'BEST_FIT', + SpotIamFleetRole: { 'Fn::GetAtt': ['MyCESpotFleetRole70BE30A0', 'Arn'] }, + }, + }); + }); + test('throws when spotFleetRole is specified without spot', () => { + // WHEN + expect(() => { + new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { + ...defaultEcsProps, + spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { + assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'), + }), + }); + }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotFleetRole' without specifying 'spot'/); + }); +}); +describe('ManagedEc2EksComputeEnvironment', () => { + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + vpc = new ec2.Vpc(stack, 'vpc'); + pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); + pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); + defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; + defaultEcsProps = { + vpc, + }; + defaultEksProps = { + vpc, + kubernetesNamespace: 'cdk-test-namespace', + eksCluster: new eks.Cluster(stack, 'eksTestCluster', { + version: eks.KubernetesVersion.V1_24, + }), + }; + }); + test('default props', () => { + // WHEN + new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { + ...defaultEksProps, + vpc, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEksProps, + ComputeResources: { + ...defaultComputeResources, + }, + }); + }); + test('throws error when AllocationStrategy.BEST_FIT is used', () => { + // THEN + expect(() => { + new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { + ...defaultProps, + allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, + }); + }).toThrow(/ManagedEc2EksComputeEnvironment 'MyCE' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'/); + }); + test('image types are correctly rendered as EC2ConfigurationObjects', () => { + // WHEN + new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { + ...defaultEksProps, + vpc, + images: [ + { + imageType: batch.EksMachineImageType.EKS_AL2_NVIDIA, + }, + ], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedEksProps, + ComputeResources: { + ...defaultComputeResources, + Ec2Configuration: [ + { + ImageType: 'EKS_AL2_NVIDIA', + }, + ], + }, + }); + }); +}); +describe('FargateComputeEnvironment', () => { + beforeEach(() => { + stack = new aws_cdk_lib_1.Stack(); + vpc = new ec2.Vpc(stack, 'vpc'); + }); + test('respects name', () => { + // WHEN + new lib_1.FargateComputeEnvironment(stack, 'maximalPropsFargate', { + vpc, + maxvCpus: 512, + computeEnvironmentName: 'maxPropsFargateCE', + replaceComputeEnvironment: true, + spot: true, + terminateOnUpdate: true, + updateTimeout: aws_cdk_lib_1.Duration.minutes(30), + updateToLatestImageVersion: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ComputeEnvironmentName: 'maxPropsFargateCE', + }); + }); + test('can be imported from arn', () => { + // WHEN + const ce = lib_1.FargateComputeEnvironment.fromFargateComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); + // THEN + expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); + }); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-compute-environment.test.js","sourceRoot":"","sources":["managed-compute-environment.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as eks from 'aws-cdk-lib/aws-eks';\nimport { ArnPrincipal, Role, ServicePrincipal } from 'aws-cdk-lib/aws-iam';\nimport { Stack, Duration, Tags } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport * as batch from '../lib';\nimport { AllocationStrategy, ManagedEc2EcsComputeEnvironment, ManagedEc2EcsComputeEnvironmentProps, ManagedEc2EksComputeEnvironment, ManagedEc2EksComputeEnvironmentProps, FargateComputeEnvironment } from '../lib';\nimport { CfnComputeEnvironmentProps } from 'aws-cdk-lib/aws-batch';\n\nconst defaultExpectedEcsProps: CfnComputeEnvironmentProps = {\n  type: 'managed',\n  computeEnvironmentName: undefined,\n  serviceRole: undefined,\n  state: 'ENABLED',\n  eksConfiguration: undefined,\n  computeResources: {\n    allocationStrategy: AllocationStrategy.BEST_FIT_PROGRESSIVE,\n    bidPercentage: undefined,\n    desiredvCpus: undefined,\n    maxvCpus: 256,\n    type: 'EC2',\n    ec2Configuration: undefined,\n    minvCpus: 0,\n    subnets: [\n      { Ref: 'vpcPrivateSubnet1Subnet934893E8' } as any,\n      { Ref: 'vpcPrivateSubnet2Subnet7031C2BA' } as any,\n    ],\n    ec2KeyPair: undefined,\n    imageId: undefined,\n    instanceRole: { 'Fn::GetAtt': ['MyCEInstanceProfile6D69963F', 'Arn'] } as any,\n    instanceTypes: ['optimal'],\n    launchTemplate: undefined,\n    placementGroup: undefined,\n    securityGroupIds: [{\n      'Fn::GetAtt': ['MyCESecurityGroup81DCAA06', 'GroupId'],\n    }] as any,\n    spotIamFleetRole: undefined,\n    updateToLatestImageVersion: true,\n  },\n  replaceComputeEnvironment: false,\n};\n\nconst defaultExpectedEksProps: CfnComputeEnvironmentProps = {\n  ...defaultExpectedEcsProps,\n  eksConfiguration: {\n    eksClusterArn: {\n      'Fn::GetAtt': ['eksTestCluster1B416C0E', 'Arn'],\n    } as any,\n    kubernetesNamespace: 'cdk-test-namespace',\n  },\n};\n\nlet stack: Stack;\nlet vpc: ec2.Vpc;\n\nlet pascalCaseExpectedEcsProps: any;\nlet pascalCaseExpectedEksProps: any;\nlet defaultComputeResources: any;\n\nlet defaultEcsProps: ManagedEc2EcsComputeEnvironmentProps;\nlet defaultEksProps: ManagedEc2EksComputeEnvironmentProps;\n\nlet expectedProps: any;\nlet defaultProps: any;\n\ndescribe.each([ManagedEc2EcsComputeEnvironment, ManagedEc2EksComputeEnvironment])('%p type ComputeEnvironment', (ComputeEnvironment) => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n    expectedProps = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? pascalCaseExpectedEcsProps\n      : pascalCaseExpectedEksProps;\n    defaultProps = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? defaultEcsProps as ManagedEc2EcsComputeEnvironmentProps\n      : defaultEksProps as ManagedEc2EksComputeEnvironmentProps;\n  });\n\n  test('default props', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', {\n      Roles: [{ Ref: 'MyCEInstanceProfileRole895D248D' }],\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'ec2.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('can specify maxvCpus', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      maxvCpus: 512,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        MaxvCpus: 512,\n      },\n    });\n  });\n\n  test('can specify minvCpus', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      minvCpus: 8,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        MinvCpus: 8,\n      },\n    });\n  });\n\n  test('can be disabled', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      enabled: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      State: 'DISABLED',\n    });\n  });\n\n  test('spot => AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      spot: true,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Type: 'SPOT',\n        AllocationStrategy: 'SPOT_PRICE_CAPACITY_OPTIMIZED',\n      },\n    });\n  });\n\n  test('images are correctly rendered as EC2ConfigurationObjects', () => {\n    const expectedImageType = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? batch.EcsMachineImageType.ECS_AL2\n      : batch.EksMachineImageType.EKS_AL2;\n\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      images: [\n        {\n          image: ec2.MachineImage.latestAmazonLinux2(),\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageIdOverride: { Ref: 'SsmParameterValueawsserviceamiamazonlinuxlatestamzn2amikernel510hvmx8664gp2C96584B6F00A464EAD1953AFF4B05118Parameter' },\n            ImageType: expectedImageType,\n          },\n        ],\n      },\n    });\n  });\n\n  test('instance classes are correctly rendered', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceClasses: [ec2.InstanceClass.R4],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4',\n          'optimal',\n        ],\n      },\n    });\n  });\n\n  test('instance types are correctly rendered', () => {\n    // WHEN\n    const ce = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE)],\n    });\n\n    ce.addInstanceClass(ec2.InstanceClass.M4);\n    ce.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.LARGE));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4.large',\n          'c4.large',\n          'm4',\n          'optimal',\n        ],\n      },\n    });\n  });\n\n  test('respects useOptimalInstanceClasses: false', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n      instanceClasses: [ec2.InstanceClass.R4],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4',\n        ],\n      },\n    });\n  });\n\n  test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceClass()', () => {\n    // WHEN\n    const myCE = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n    });\n\n    myCE.addInstanceClass(ec2.InstanceClass.C4);\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'c4',\n        ],\n      },\n    });\n  });\n\n  test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceType()', () => {\n    // WHEN\n    const myCE = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n    });\n\n    myCE.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.XLARGE112));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'c4.112xlarge',\n        ],\n      },\n    });\n  });\n\n  test('creates and uses instanceProfile, even when instanceRole is specified', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceRole: new Role(stack, 'myRole', {\n        assumedBy: new ServicePrincipal('foo.amazonaws.com', {\n          region: 'bermuda-triangle-1337',\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        // instanceRole is unchanged from default\n      },\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', {\n      Roles: [{ Ref: 'myRoleE60D68E8' }],\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'foo.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('respects launch template', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      launchTemplate: new ec2.LaunchTemplate(stack, 'launchTemplate'),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        LaunchTemplate: {\n          LaunchTemplateId: { Ref: 'launchTemplateDEE5742D' },\n        },\n      },\n    });\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      computeEnvironmentName: 'NamedCE',\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeEnvironmentName: 'NamedCE',\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('respects placement group', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      placementGroup: new ec2.PlacementGroup(stack, 'myPlacementGroup'),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        PlacementGroup: {\n          'Fn::GetAtt': ['myPlacementGroup2E94D14E', 'GroupName'],\n        },\n      },\n    });\n  });\n\n  test('respects replaceComputeEnvironment', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      replaceComputeEnvironment: true,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      ReplaceComputeEnvironment: true,\n    });\n  });\n\n  test('respects security groups', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      securityGroups: [new ec2.SecurityGroup(stack, 'TestSG', {\n        vpc,\n        allowAllOutbound: false,\n      })],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        SecurityGroupIds: [{\n          'Fn::GetAtt': ['TestSG581D3391', 'GroupId'],\n        }],\n      },\n    });\n  });\n\n  test('respects service role', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      serviceRole: new Role(stack, 'TestSLR', {\n        assumedBy: new ServicePrincipal('cdk.amazonaws.com'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ServiceRole: {\n        'Fn::GetAtt': ['TestSLR05974C22', 'Arn'],\n      },\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('respects vpcSubnets', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpcSubnets: {\n        subnets: [new ec2.Subnet(stack, 'testSubnet', {\n          availabilityZone: 'az-3',\n          cidrBlock: '10.0.0.0/32',\n          vpcId: new ec2.Vpc(stack, 'subnetVpc').vpcId,\n        })],\n      },\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Subnets: [\n          { Ref: 'testSubnet42F0FA0C' },\n        ],\n      },\n    });\n  });\n\n  test('respects updateTimeout', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      updateTimeout: Duration.minutes(1),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      UpdatePolicy: {\n        JobExecutionTimeoutMinutes: 1,\n      },\n    });\n  });\n\n  test('respects terminateOnUpdate', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      terminateOnUpdate: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      UpdatePolicy: {\n        TerminateJobsOnUpdate: false,\n      },\n    });\n  });\n\n  test('respects updateToLatestImageVersion', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      updateToLatestImageVersion: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        UpdateToLatestImageVersion: false,\n      },\n    });\n  });\n\n  test('respects tags', () => {\n    // WHEN\n    const ce = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n    });\n\n    Tags.of(ce).add('superfood', 'acai');\n    Tags.of(ce).add('super', 'salamander');\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Tags: {\n          superfood: 'acai',\n          super: 'salamander',\n        },\n      },\n    });\n  });\n\n  test('can be imported from arn', () => {\n    // WHEN\n    const ce = ManagedEc2EcsComputeEnvironment.fromManagedEc2EcsComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n\n    // THEN\n    expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n  });\n\n  test('attach necessary managed policy to instance role', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      ManagedPolicyArns: [\n        {\n          'Fn::Join': [\n            '',\n            [\n              'arn:',\n              {\n                Ref: 'AWS::Partition',\n              },\n              ':iam::aws:policy/service-role/AmazonEC2ContainerServiceforEC2Role',\n            ],\n          ],\n        },\n      ],\n    });\n  });\n\n  test('throws when no instance types are provided', () => {\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      useOptimalInstanceClasses: false,\n      vpc,\n    });\n\n    expect(() => {\n      Template.fromStack(stack);\n    }).toThrow(/Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes/);\n  });\n\n  test('throws error when AllocationStrategy.SPOT_CAPACITY_OPTIMIZED is used without specfiying spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        allocationStrategy: AllocationStrategy.SPOT_CAPACITY_OPTIMIZED,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances/);\n  });\n\n  test('throws error when AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED is used without specfiying spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        allocationStrategy: AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances/);\n  });\n\n  test('throws error when spotBidPercentage is specified without spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 80,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/);\n  });\n\n  test('throws error when spotBidPercentage is specified and spot is false', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 80,\n        spot: false,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/);\n  });\n\n  test('throws error when spotBidPercentage > 100', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 120,\n        spot: true,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' > 100/);\n  });\n\n  test('throws error when spotBidPercentage < 0', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: -120,\n        spot: true,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' < 0/);\n  });\n\n  test('throws error when minvCpus > maxvCpus', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        maxvCpus: 512,\n        minvCpus: 1024,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = 1024 > 'maxvCpus' = 512; 'minvCpus' cannot be greater than 'maxvCpus'/);\n  });\n\n  test('throws error when minvCpus < 0', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        minvCpus: -256,\n      });\n    }).toThrowError(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = -256 < 0; 'minvCpus' cannot be less than zero/);\n  });\n});\n\ndescribe('ManagedEc2EcsComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n  });\n\n  test('respects spotFleetRole', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultEcsProps,\n      spot: true,\n      spotFleetRole: new Role(stack, 'SpotFleetRole', {\n        assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        AllocationStrategy: AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED,\n        Type: 'SPOT',\n        SpotIamFleetRole: {\n          'Fn::GetAtt': ['SpotFleetRole6D4F7558', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('image types are correctly rendered as EC2ConfigurationObjects', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultEcsProps,\n      vpc,\n      images: [\n        {\n          imageType: batch.EcsMachineImageType.ECS_AL2_NVIDIA,\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageType: 'ECS_AL2_NVIDIA',\n          },\n        ],\n      },\n    });\n  });\n\n  test('can use non-default allocation strategy', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      allocationStrategy: AllocationStrategy.BEST_FIT,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        AllocationStrategy: 'BEST_FIT',\n      },\n    });\n  });\n\n  test('spot and AllocationStrategy.BEST_FIT => a default spot fleet role is created', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      spot: true,\n      allocationStrategy: AllocationStrategy.BEST_FIT,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Type: 'SPOT',\n        AllocationStrategy: 'BEST_FIT',\n        SpotIamFleetRole: { 'Fn::GetAtt': ['MyCESpotFleetRole70BE30A0', 'Arn'] },\n      },\n    });\n  });\n\n  test('throws when spotFleetRole is specified without spot', () => {\n    // WHEN\n    expect(() => {\n      new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n        ...defaultEcsProps,\n        spotFleetRole: new Role(stack, 'SpotFleetRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'),\n        }),\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotFleetRole' without specifying 'spot'/);\n  });\n});\n\ndescribe('ManagedEc2EksComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n  });\n\n  test('default props', () => {\n    // WHEN\n    new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n      ...defaultEksProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEksProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('throws error when AllocationStrategy.BEST_FIT is used', () => {\n    // THEN\n    expect(() => {\n      new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        allocationStrategy: AllocationStrategy.BEST_FIT,\n      });\n    }).toThrow(/ManagedEc2EksComputeEnvironment 'MyCE' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'/);\n  });\n\n  test('image types are correctly rendered as EC2ConfigurationObjects', () => {\n    // WHEN\n    new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n      ...defaultEksProps,\n      vpc,\n      images: [\n        {\n          imageType: batch.EksMachineImageType.EKS_AL2_NVIDIA,\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEksProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageType: 'EKS_AL2_NVIDIA',\n          },\n        ],\n      },\n    });\n  });\n});\n\ndescribe('FargateComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new FargateComputeEnvironment(stack, 'maximalPropsFargate', {\n      vpc,\n      maxvCpus: 512,\n      computeEnvironmentName: 'maxPropsFargateCE',\n      replaceComputeEnvironment: true,\n      spot: true,\n      terminateOnUpdate: true,\n      updateTimeout: Duration.minutes(30),\n      updateToLatestImageVersion: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ComputeEnvironmentName: 'maxPropsFargateCE',\n    });\n  });\n\n  test('can be imported from arn', () => {\n    // WHEN\n    const ce = FargateComputeEnvironment.fromFargateComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n\n    // THEN\n    expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js new file mode 100644 index 0000000000000..0120ecf9bd8eb --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js @@ -0,0 +1,155 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); +const ecs = require("aws-cdk-lib/aws-ecs"); +const aws_cdk_lib_1 = require("aws-cdk-lib"); +const lib_1 = require("../lib"); +test('MultiNodeJobDefinition respects mainNode', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { + containers: [{ + container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 0, + endNode: 9, + }], + mainNode: 5, + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + NodeProperties: { + MainNode: 5, + NodeRangeProperties: [{ + Container: { + InstanceType: 'r4.large', + }, + TargetNodes: '0:9', + }], + NumNodes: 10, + }, + PlatformCapabilities: [lib_1.Compatibility.EC2], + }); +}); +test('EcsJobDefinition respects propagateTags', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { + propagateTags: true, + containers: [{ + container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 0, + endNode: 9, + }], + mainNode: 0, + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + PropagateTags: true, + }); +}); +test('MultiNodeJobDefinition one container', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { + containers: [{ + container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 0, + endNode: 9, + }], + mainNode: 0, + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + NodeProperties: { + MainNode: 0, + NodeRangeProperties: [{ + Container: { + InstanceType: 'r4.large', + }, + TargetNodes: '0:9', + }], + NumNodes: 10, + }, + PlatformCapabilities: [lib_1.Compatibility.EC2], + }); +}); +test('MultiNodeJobDefinition two containers', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { + containers: [ + { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer1', { + cpu: 256, + memory: aws_cdk_lib_1.Size.mebibytes(2048), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 0, + endNode: 9, + }, + { + container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer2', { + cpu: 512, + memory: aws_cdk_lib_1.Size.mebibytes(4096), + image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), + }), + startNode: 10, + endNode: 14, + }, + ], + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { + NodeProperties: { + MainNode: 0, + NodeRangeProperties: [ + { + Container: { + InstanceType: 'r4.large', + }, + TargetNodes: '0:9', + }, + { + Container: { + InstanceType: 'r4.large', + }, + TargetNodes: '10:14', + }, + ], + NumNodes: 15, + }, + PlatformCapabilities: [lib_1.Compatibility.EC2], + }); +}); +test('multinode job requires at least one container', () => { + // GIVEN + const stack = new aws_cdk_lib_1.Stack(); + // WHEN + new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { + instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.C4, aws_ec2_1.InstanceSize.LARGE), + }); + // THEN + expect(() => assertions_1.Template.fromStack(stack)).toThrow(/multinode job has no containers!/); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multinode-job-definition.test.js","sourceRoot":"","sources":["multinode-job-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport { Compatibility, EcsEc2ContainerDefinition, MultiNodeJobDefinition } from '../lib';\n\ntest('MultiNodeJobDefinition respects mainNode', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 5,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 5,\n      NodeRangeProperties: [{\n        Container: {\n          InstanceType: 'r4.large',\n        },\n        TargetNodes: '0:9',\n      }],\n      NumNodes: 10,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('EcsJobDefinition respects propagateTags', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    propagateTags: true,\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 0,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PropagateTags: true,\n  });\n});\n\ntest('MultiNodeJobDefinition one container', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 0,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 0,\n      NodeRangeProperties: [{\n        Container: {\n          InstanceType: 'r4.large',\n        },\n        TargetNodes: '0:9',\n      }],\n      NumNodes: 10,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('MultiNodeJobDefinition two containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [\n      {\n        container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer1', {\n          cpu: 256,\n          memory: Size.mebibytes(2048),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 0,\n        endNode: 9,\n      },\n      {\n        container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer2', {\n          cpu: 512,\n          memory: Size.mebibytes(4096),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 10,\n        endNode: 14,\n      },\n    ],\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 0,\n      NodeRangeProperties: [\n        {\n          Container: {\n            InstanceType: 'r4.large',\n          },\n          TargetNodes: '0:9',\n        },\n        {\n          Container: {\n            InstanceType: 'r4.large',\n          },\n          TargetNodes: '10:14',\n        },\n\n      ],\n      NumNodes: 15,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('multinode job requires at least one container', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    instanceType: InstanceType.of(InstanceClass.C4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  expect(() => Template.fromStack(stack)).toThrow(/multinode job has no containers!/);\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js new file mode 100644 index 0000000000000..b15d5d7caa7f6 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js @@ -0,0 +1,133 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const core_1 = require("aws-cdk-lib/core"); +const lib_1 = require("../lib"); +test('empty fairshare policy', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy'); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + FairsharePolicy: { + ShareDistribution: [], + }, + }); +}); +test('fairshare policy respects computeReservation', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { + computeReservation: 75, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + FairsharePolicy: { + ComputeReservation: 75, + ShareDistribution: [], + }, + }); +}); +test('fairshare policy respects name', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { + schedulingPolicyName: 'FairsharePolicyName', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + Name: 'FairsharePolicyName', + FairsharePolicy: { + ShareDistribution: [], + }, + }); +}); +test('fairshare policy respects shareDecay', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { + shareDecay: core_1.Duration.hours(1), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + FairsharePolicy: { + ShareDecaySeconds: 3600, + ShareDistribution: [], + }, + }); +}); +test('fairshare policy respects shares', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { + shares: [ + { + shareIdentifier: 'myShareId', + weightFactor: 0.5, + }, + { + shareIdentifier: 'myShareId2', + weightFactor: 1, + }, + ], + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + FairsharePolicy: { + ShareDistribution: [ + { + ShareIdentifier: 'myShareId', + WeightFactor: 0.5, + }, + { + ShareIdentifier: 'myShareId2', + WeightFactor: 1, + }, + ], + }, + }); +}); +test('addShare() works', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + const policy = new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { + shares: [{ + shareIdentifier: 'myShareId', + weightFactor: 0.5, + }], + }); + policy.addShare({ + shareIdentifier: 'addedShareId', + weightFactor: 0.5, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { + FairsharePolicy: { + ShareDistribution: [ + { + ShareIdentifier: 'myShareId', + WeightFactor: 0.5, + }, + { + ShareIdentifier: 'addedShareId', + WeightFactor: 0.5, + }, + ], + }, + }); +}); +test('can be imported from ARN', () => { + // GIVEN + const stack = new core_1.Stack(); + // WHEN + const policy = lib_1.FairshareSchedulingPolicy.fromFairshareSchedulingPolicyArn(stack, 'policyImport', 'arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport'); + // THEN + expect(policy.schedulingPolicyArn).toEqual('arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport'); +}); +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheduling-policy.test.js","sourceRoot":"","sources":["scheduling-policy.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { Duration, Stack } from 'aws-cdk-lib/core';\nimport { FairshareSchedulingPolicy } from '../lib';\n\ntest('empty fairshare policy', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy');\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects computeReservation', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    computeReservation: 75,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ComputeReservation: 75,\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects name', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    schedulingPolicyName: 'FairsharePolicyName',\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    Name: 'FairsharePolicyName',\n    FairsharePolicy: {\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects shareDecay', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shareDecay: Duration.hours(1),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDecaySeconds: 3600,\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects shares', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shares: [\n      {\n        shareIdentifier: 'myShareId',\n        weightFactor: 0.5,\n      },\n      {\n        shareIdentifier: 'myShareId2',\n        weightFactor: 1,\n      },\n    ],\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [\n        {\n          ShareIdentifier: 'myShareId',\n          WeightFactor: 0.5,\n        },\n        {\n          ShareIdentifier: 'myShareId2',\n          WeightFactor: 1,\n        },\n      ],\n    },\n  });\n});\n\ntest('addShare() works', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const policy = new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shares: [{\n      shareIdentifier: 'myShareId',\n      weightFactor: 0.5,\n    }],\n  });\n  policy.addShare({\n    shareIdentifier: 'addedShareId',\n    weightFactor: 0.5,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [\n        {\n          ShareIdentifier: 'myShareId',\n          WeightFactor: 0.5,\n        },\n        {\n          ShareIdentifier: 'addedShareId',\n          WeightFactor: 0.5,\n        },\n      ],\n    },\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const policy = FairshareSchedulingPolicy.fromFairshareSchedulingPolicyArn(stack, 'policyImport',\n    'arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport');\n\n  // THEN\n  expect(policy.schedulingPolicyArn).toEqual('arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport');\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts new file mode 100644 index 0000000000000..cb0ff5c3b541f --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts @@ -0,0 +1 @@ +export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js new file mode 100644 index 0000000000000..4c7fe0a2e433a --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js @@ -0,0 +1,90 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const assertions_1 = require("aws-cdk-lib/assertions"); +const aws_iam_1 = require("aws-cdk-lib/aws-iam"); +const core_1 = require("aws-cdk-lib/core"); +const utils_1 = require("./utils"); +const unmanaged_compute_environment_1 = require("../lib/unmanaged-compute-environment"); +const defaultExpectedProps = { + type: 'unmanaged', + computeEnvironmentName: undefined, + computeResources: undefined, + eksConfiguration: undefined, + replaceComputeEnvironment: undefined, + serviceRole: { + 'Fn::GetAtt': ['MyCEBatchServiceRole4FDA2CB6', 'Arn'], + }, + state: 'ENABLED', + tags: undefined, + unmanagedvCpus: undefined, + updatePolicy: undefined, +}; +let stack = new core_1.Stack(); +const pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedProps); +test('default props', () => { + // GIVEN + stack = new core_1.Stack(); + // WHEN + new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE'); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedProps, + }); +}); +test('respects enabled: false', () => { + // GIVEN + stack = new core_1.Stack(); + // WHEN + new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { + enabled: false, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedProps, + State: 'DISABLED', + }); +}); +test('respects name', () => { + // GIVEN + stack = new core_1.Stack(); + // WHEN + new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { + computeEnvironmentName: 'magic', + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedProps, + ComputeEnvironmentName: 'magic', + }); +}); +test('respects serviceRole', () => { + // GIVEN + stack = new core_1.Stack(); + // WHEN + new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { + serviceRole: new aws_iam_1.Role(stack, 'myMagicRole', { + assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), + }), + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedProps, + ServiceRole: { + 'Fn::GetAtt': ['myMagicRole2BBD827A', 'Arn'], + }, + }); +}); +test('respects unmanagedvCpus', () => { + // GIVEN + stack = new core_1.Stack(); + // WHEN + new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { + unmanagedvCpus: 256, + }); + // THEN + assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { + ...pascalCaseExpectedProps, + UnmanagedvCpus: 256, + }); +}); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx1REFBa0Q7QUFDbEQsaURBQTZEO0FBQzdELDJDQUF5QztBQUN6QyxtQ0FBa0Q7QUFFbEQsd0ZBQW1GO0FBRW5GLE1BQU0sb0JBQW9CLEdBQStCO0lBQ3ZELElBQUksRUFBRSxXQUFXO0lBQ2pCLHNCQUFzQixFQUFFLFNBQVM7SUFDakMsZ0JBQWdCLEVBQUUsU0FBUztJQUMzQixnQkFBZ0IsRUFBRSxTQUFTO0lBQzNCLHlCQUF5QixFQUFFLFNBQVM7SUFDcEMsV0FBVyxFQUFFO1FBQ1gsWUFBWSxFQUFFLENBQUMsOEJBQThCLEVBQUUsS0FBSyxDQUFDO0tBQy9DO0lBQ1IsS0FBSyxFQUFFLFNBQVM7SUFDaEIsSUFBSSxFQUFFLFNBQVM7SUFDZixjQUFjLEVBQUUsU0FBUztJQUN6QixZQUFZLEVBQUUsU0FBUztDQUN4QixDQUFDO0FBRUYsSUFBSSxLQUFLLEdBQUcsSUFBSSxZQUFLLEVBQUUsQ0FBQztBQUN4QixNQUFNLHVCQUF1QixHQUFHLElBQUEsK0JBQXVCLEVBQUMsS0FBSyxFQUFFLG9CQUFvQixDQUFDLENBQUM7QUFFckYsSUFBSSxDQUFDLGVBQWUsRUFBRSxHQUFHLEVBQUU7SUFDekIsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztJQUUvQyxPQUFPO0lBQ1AscUJBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMscUJBQXFCLENBQUMsZ0NBQWdDLEVBQUU7UUFDaEYsR0FBRyx1QkFBdUI7S0FDM0IsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLENBQUMseUJBQXlCLEVBQUUsR0FBRyxFQUFFO0lBQ25DLFFBQVE7SUFDUixLQUFLLEdBQUcsSUFBSSxZQUFLLEVBQUUsQ0FBQztJQUVwQixPQUFPO0lBQ1AsSUFBSSwyREFBMkIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFO1FBQzdDLE9BQU8sRUFBRSxLQUFLO0tBQ2YsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLGdDQUFnQyxFQUFFO1FBQ2hGLEdBQUcsdUJBQXVCO1FBQzFCLEtBQUssRUFBRSxVQUFVO0tBQ2xCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDO0FBRUgsSUFBSSxDQUFDLGVBQWUsRUFBRSxHQUFHLEVBQUU7SUFDekIsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0Msc0JBQXNCLEVBQUUsT0FBTztLQUNoQyxDQUFDLENBQUM7SUFFSCxPQUFPO0lBQ1AscUJBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMscUJBQXFCLENBQUMsZ0NBQWdDLEVBQUU7UUFDaEYsR0FBRyx1QkFBdUI7UUFDMUIsc0JBQXNCLEVBQUUsT0FBTztLQUNoQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyxzQkFBc0IsRUFBRSxHQUFHLEVBQUU7SUFDaEMsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0MsV0FBVyxFQUFFLElBQUksY0FBSSxDQUFDLEtBQUssRUFBRSxhQUFhLEVBQUU7WUFDMUMsU0FBUyxFQUFFLElBQUksMEJBQWdCLENBQUMscUJBQXFCLENBQUM7U0FDdkQsQ0FBQztLQUNILENBQUMsQ0FBQztJQUVILE9BQU87SUFDUCxxQkFBUSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQyxnQ0FBZ0MsRUFBRTtRQUNoRixHQUFHLHVCQUF1QjtRQUMxQixXQUFXLEVBQUU7WUFDWCxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxLQUFLLENBQUM7U0FDN0M7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyx5QkFBeUIsRUFBRSxHQUFHLEVBQUU7SUFDbkMsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0MsY0FBYyxFQUFFLEdBQUc7S0FDcEIsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLGdDQUFnQyxFQUFFO1FBQ2hGLEdBQUcsdUJBQXVCO1FBQzFCLGNBQWMsRUFBRSxHQUFHO0tBQ3BCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGUgfSBmcm9tICdhd3MtY2RrLWxpYi9hc3NlcnRpb25zJztcbmltcG9ydCB7IFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnYXdzLWNkay1saWIvY29yZSc7XG5pbXBvcnQgeyBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgQ2ZuQ29tcHV0ZUVudmlyb25tZW50UHJvcHMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtYmF0Y2gnO1xuaW1wb3J0IHsgVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IH0gZnJvbSAnLi4vbGliL3VubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50JztcblxuY29uc3QgZGVmYXVsdEV4cGVjdGVkUHJvcHM6IENmbkNvbXB1dGVFbnZpcm9ubWVudFByb3BzID0ge1xuICB0eXBlOiAndW5tYW5hZ2VkJyxcbiAgY29tcHV0ZUVudmlyb25tZW50TmFtZTogdW5kZWZpbmVkLFxuICBjb21wdXRlUmVzb3VyY2VzOiB1bmRlZmluZWQsXG4gIGVrc0NvbmZpZ3VyYXRpb246IHVuZGVmaW5lZCxcbiAgcmVwbGFjZUNvbXB1dGVFbnZpcm9ubWVudDogdW5kZWZpbmVkLFxuICBzZXJ2aWNlUm9sZToge1xuICAgICdGbjo6R2V0QXR0JzogWydNeUNFQmF0Y2hTZXJ2aWNlUm9sZTRGREEyQ0I2JywgJ0FybiddLFxuICB9IGFzIGFueSxcbiAgc3RhdGU6ICdFTkFCTEVEJyxcbiAgdGFnczogdW5kZWZpbmVkLFxuICB1bm1hbmFnZWR2Q3B1czogdW5kZWZpbmVkLFxuICB1cGRhdGVQb2xpY3k6IHVuZGVmaW5lZCxcbn07XG5cbmxldCBzdGFjayA9IG5ldyBTdGFjaygpO1xuY29uc3QgcGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMgPSBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhzdGFjaywgZGVmYXVsdEV4cGVjdGVkUHJvcHMpO1xuXG50ZXN0KCdkZWZhdWx0IHByb3BzJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnKTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnQnLCB7XG4gICAgLi4ucGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMsXG4gIH0pO1xufSk7XG5cbnRlc3QoJ3Jlc3BlY3RzIGVuYWJsZWQ6IGZhbHNlJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnLCB7XG4gICAgZW5hYmxlZDogZmFsc2UsXG4gIH0pO1xuXG4gIC8vIFRIRU5cbiAgVGVtcGxhdGUuZnJvbVN0YWNrKHN0YWNrKS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6QmF0Y2g6OkNvbXB1dGVFbnZpcm9ubWVudCcsIHtcbiAgICAuLi5wYXNjYWxDYXNlRXhwZWN0ZWRQcm9wcyxcbiAgICBTdGF0ZTogJ0RJU0FCTEVEJyxcbiAgfSk7XG59KTtcblxudGVzdCgncmVzcGVjdHMgbmFtZScsICgpID0+IHtcbiAgLy8gR0lWRU5cbiAgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAvLyBXSEVOXG4gIG5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdNeUNFJywge1xuICAgIGNvbXB1dGVFbnZpcm9ubWVudE5hbWU6ICdtYWdpYycsXG4gIH0pO1xuXG4gIC8vIFRIRU5cbiAgVGVtcGxhdGUuZnJvbVN0YWNrKHN0YWNrKS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6QmF0Y2g6OkNvbXB1dGVFbnZpcm9ubWVudCcsIHtcbiAgICAuLi5wYXNjYWxDYXNlRXhwZWN0ZWRQcm9wcyxcbiAgICBDb21wdXRlRW52aXJvbm1lbnROYW1lOiAnbWFnaWMnLFxuICB9KTtcbn0pO1xuXG50ZXN0KCdyZXNwZWN0cyBzZXJ2aWNlUm9sZScsICgpID0+IHtcbiAgLy8gR0lWRU5cbiAgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAvLyBXSEVOXG4gIG5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdNeUNFJywge1xuICAgIHNlcnZpY2VSb2xlOiBuZXcgUm9sZShzdGFjaywgJ215TWFnaWNSb2xlJywge1xuICAgICAgYXNzdW1lZEJ5OiBuZXcgU2VydmljZVByaW5jaXBhbCgnYmF0Y2guYW1hem9uYXdzLmNvbScpLFxuICAgIH0pLFxuICB9KTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnQnLCB7XG4gICAgLi4ucGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMsXG4gICAgU2VydmljZVJvbGU6IHtcbiAgICAgICdGbjo6R2V0QXR0JzogWydteU1hZ2ljUm9sZTJCQkQ4MjdBJywgJ0FybiddLFxuICAgIH0sXG4gIH0pO1xufSk7XG5cbnRlc3QoJ3Jlc3BlY3RzIHVubWFuYWdlZHZDcHVzJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnLCB7XG4gICAgdW5tYW5hZ2VkdkNwdXM6IDI1NixcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Q29tcHV0ZUVudmlyb25tZW50Jywge1xuICAgIC4uLnBhc2NhbENhc2VFeHBlY3RlZFByb3BzLFxuICAgIFVubWFuYWdlZHZDcHVzOiAyNTYsXG4gIH0pO1xufSk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts new file mode 100644 index 0000000000000..934fcac4357e0 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts @@ -0,0 +1,6 @@ +import { IConstruct } from 'constructs'; +/** + * Given an object, converts all keys to PascalCase given they are currently in camel case. + * @param obj The object. + */ +export declare function capitalizePropertyNames(construct: IConstruct, obj: any): any; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/utils.js b/packages/@aws-cdk/aws-batch-alpha/test/utils.js new file mode 100644 index 0000000000000..c804b15bf6337 --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/test/utils.js @@ -0,0 +1,28 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.capitalizePropertyNames = void 0; +const aws_cdk_lib_1 = require("aws-cdk-lib"); +/** + * Given an object, converts all keys to PascalCase given they are currently in camel case. + * @param obj The object. + */ +function capitalizePropertyNames(construct, obj) { + const stack = aws_cdk_lib_1.Stack.of(construct); + obj = stack.resolve(obj); + if (typeof (obj) !== 'object') { + return obj; + } + if (Array.isArray(obj)) { + return obj.map(x => capitalizePropertyNames(construct, x)); + } + const newObj = {}; + for (const key of Object.keys(obj)) { + const value = obj[key]; + const first = key.charAt(0).toUpperCase(); + const newKey = first + key.slice(1); + newObj[newKey] = capitalizePropertyNames(construct, value); + } + return newObj; +} +exports.capitalizePropertyNames = capitalizePropertyNames; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2Q0FBb0M7QUFHcEM7OztHQUdHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQUMsU0FBcUIsRUFBRSxHQUFRO0lBQ3JFLE1BQU0sS0FBSyxHQUFHLG1CQUFLLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2xDLEdBQUcsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXpCLElBQUksT0FBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLFFBQVEsRUFBRTtRQUM1QixPQUFPLEdBQUcsQ0FBQztLQUNaO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzVEO0lBRUQsTUFBTSxNQUFNLEdBQVEsRUFBRyxDQUFDO0lBQ3hCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNsQyxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdkIsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUMxQyxNQUFNLE1BQU0sR0FBRyxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsdUJBQXVCLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO0tBQzVEO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQXRCRCwwREFzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuLyoqXG4gKiBHaXZlbiBhbiBvYmplY3QsIGNvbnZlcnRzIGFsbCBrZXlzIHRvIFBhc2NhbENhc2UgZ2l2ZW4gdGhleSBhcmUgY3VycmVudGx5IGluIGNhbWVsIGNhc2UuXG4gKiBAcGFyYW0gb2JqIFRoZSBvYmplY3QuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhjb25zdHJ1Y3Q6IElDb25zdHJ1Y3QsIG9iajogYW55KTogYW55IHtcbiAgY29uc3Qgc3RhY2sgPSBTdGFjay5vZihjb25zdHJ1Y3QpO1xuICBvYmogPSBzdGFjay5yZXNvbHZlKG9iaik7XG5cbiAgaWYgKHR5cGVvZihvYmopICE9PSAnb2JqZWN0Jykge1xuICAgIHJldHVybiBvYmo7XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShvYmopKSB7XG4gICAgcmV0dXJuIG9iai5tYXAoeCA9PiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhjb25zdHJ1Y3QsIHgpKTtcbiAgfVxuXG4gIGNvbnN0IG5ld09iajogYW55ID0geyB9O1xuICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyhvYmopKSB7XG4gICAgY29uc3QgdmFsdWUgPSBvYmpba2V5XTtcblxuICAgIGNvbnN0IGZpcnN0ID0ga2V5LmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpO1xuICAgIGNvbnN0IG5ld0tleSA9IGZpcnN0ICsga2V5LnNsaWNlKDEpO1xuICAgIG5ld09ialtuZXdLZXldID0gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoY29uc3RydWN0LCB2YWx1ZSk7XG4gIH1cblxuICByZXR1cm4gbmV3T2JqO1xufVxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/tsconfig.json b/packages/@aws-cdk/aws-batch-alpha/tsconfig.json new file mode 100644 index 0000000000000..00315950564fd --- /dev/null +++ b/packages/@aws-cdk/aws-batch-alpha/tsconfig.json @@ -0,0 +1,53 @@ +{ + "compilerOptions": { + "declarationMap": false, + "inlineSourceMap": true, + "inlineSources": true, + "alwaysStrict": true, + "declaration": true, + "experimentalDecorators": true, + "incremental": true, + "lib": [ + "es2020" + ], + "module": "CommonJS", + "noEmitOnError": true, + "noFallthroughCasesInSwitch": true, + "noImplicitAny": true, + "noImplicitReturns": true, + "noImplicitThis": true, + "noUnusedLocals": true, + "noUnusedParameters": true, + "resolveJsonModule": true, + "skipLibCheck": true, + "strict": true, + "strictNullChecks": true, + "strictPropertyInitialization": true, + "stripInternal": false, + "target": "ES2020", + "composite": true, + "tsBuildInfoFile": "tsconfig.tsbuildinfo" + }, + "include": [ + "**/*.ts" + ], + "exclude": [ + "node_modules", + ".types-compat" + ], + "references": [ + { + "path": "../../../tools/@aws-cdk/cdk-build-tools" + }, + { + "path": "../integ-runner" + }, + { + "path": "../../../tools/@aws-cdk/pkglint" + }, + { + "path": "../integ-tests-alpha" + } + ], + "_generated_by_jsii_": "Generated by jsii - safe to delete, and ideally should be in .gitignore" +} \ No newline at end of file diff --git a/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts b/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts index e97e45bf48689..896a8105d2e3a 100644 --- a/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts +++ b/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts @@ -222,7 +222,7 @@ describe('parallel worker', () => { const results = await runIntegrationTestsInParallel({ pool, tests, - regions: ['us-east-1'], + regions: ['us-west-2'], }); expect(stderrMock.mock.calls[0][0]).toContain( @@ -408,7 +408,7 @@ describe('parallel worker', () => { const results = await runIntegrationTestsInParallel({ tests, pool, - regions: ['us-east-1'], + regions: ['us-west-2'], }); expect(stderrMock.mock.calls[1][0]).toContain( From 82d2e9448b35be16f99b30e47f0ead3a30cceb86 Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 18:57:08 -0500 Subject: [PATCH 3/7] oops --- packages/@aws-cdk/aws-batch-alpha/.jsii | 15284 ---------------- .../aws-batch-alpha/.warnings.jsii.js | 515 - .../lib/compute-environment-base.d.ts | 87 - .../lib/compute-environment-base.js | 20 - .../lib/ecs-container-definition.d.ts | 726 - .../lib/ecs-container-definition.js | 531 - .../lib/ecs-job-definition.d.ts | 67 - .../aws-batch-alpha/lib/ecs-job-definition.js | 102 - .../lib/eks-container-definition.d.ts | 728 - .../lib/eks-container-definition.js | 338 - .../lib/eks-job-definition.d.ts | 123 - .../aws-batch-alpha/lib/eks-job-definition.js | 134 - .../@aws-cdk/aws-batch-alpha/lib/index.d.ts | 12 - .../@aws-cdk/aws-batch-alpha/lib/index.js | 29 - .../lib/job-definition-base.d.ts | 217 - .../lib/job-definition-base.js | 153 - .../aws-batch-alpha/lib/job-queue.d.ts | 140 - .../@aws-cdk/aws-batch-alpha/lib/job-queue.js | 102 - .../aws-batch-alpha/lib/linux-parameters.d.ts | 196 - .../aws-batch-alpha/lib/linux-parameters.js | 175 - .../lib/managed-compute-environment.d.ts | 806 - .../lib/managed-compute-environment.js | 451 - .../lib/multinode-job-definition.d.ts | 107 - .../lib/multinode-job-definition.js | 104 - .../lib/scheduling-policy.d.ts | 188 - .../aws-batch-alpha/lib/scheduling-policy.js | 101 - .../lib/unmanaged-compute-environment.d.ts | 47 - .../lib/unmanaged-compute-environment.js | 70 - .../test/aws-events-targets/batch.test.d.ts | 1 - .../test/aws-events-targets/batch.test.js | 294 - .../run-batch-job.test.d.ts | 1 - .../run-batch-job.test.js | 286 - .../submit-job.test.d.ts | 1 - .../submit-job.test.js | 401 - .../test/ecs-container-definition.test.d.ts | 1 - .../test/ecs-container-definition.test.js | 998 - .../test/ecs-job-definition.test.d.ts | 1 - .../test/ecs-job-definition.test.js | 147 - .../test/eks-container-definition.test.d.ts | 1 - .../test/eks-container-definition.test.js | 712 - .../test/eks-job-definition.test.d.ts | 1 - .../test/eks-job-definition.test.js | 72 - .../test/integ.batch-unique-name.d.ts | 1 - .../test/integ.batch-unique-name.js | 34 - .../test/integ.ecs-job-definition.d.ts | 1 - .../test/integ.ecs-job-definition.js | 94 - .../test/integ.eks-job-definition.d.ts | 1 - .../test/integ.eks-job-definition.js | 59 - .../aws-batch-alpha/test/integ.grants.d.ts | 1 - .../aws-batch-alpha/test/integ.grants.js | 35 - .../aws-batch-alpha/test/integ.job-queue.d.ts | 1 - .../aws-batch-alpha/test/integ.job-queue.js | 41 - .../integ.managed-compute-environment.d.ts | 1 - .../test/integ.managed-compute-environment.js | 78 - .../test/integ.multinode-job-definition.d.ts | 1 - .../test/integ.multinode-job-definition.js | 48 - .../integ.unmanaged-compute-environment.d.ts | 1 - .../integ.unmanaged-compute-environment.js | 25 - .../test/job-definition-base.test.d.ts | 1 - .../test/job-definition-base.test.js | 205 - .../aws-batch-alpha/test/job-queue.test.d.ts | 1 - .../aws-batch-alpha/test/job-queue.test.js | 228 - .../managed-compute-environment.test.d.ts | 1 - .../test/managed-compute-environment.test.js | 860 - .../test/multinode-job-definition.test.d.ts | 1 - .../test/multinode-job-definition.test.js | 155 - .../test/scheduling-policy.test.d.ts | 1 - .../test/scheduling-policy.test.js | 133 - .../unmanaged-compute-environment.test.d.ts | 1 - .../unmanaged-compute-environment.test.js | 90 - .../@aws-cdk/aws-batch-alpha/test/utils.d.ts | 6 - .../@aws-cdk/aws-batch-alpha/test/utils.js | 28 - .../@aws-cdk/aws-batch-alpha/tsconfig.json | 53 - .../test/workers/integ-worker.test.ts | 4 +- 74 files changed, 2 insertions(+), 26658 deletions(-) delete mode 100644 packages/@aws-cdk/aws-batch-alpha/.jsii delete mode 100644 packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/index.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts delete mode 100644 packages/@aws-cdk/aws-batch-alpha/test/utils.js delete mode 100644 packages/@aws-cdk/aws-batch-alpha/tsconfig.json diff --git a/packages/@aws-cdk/aws-batch-alpha/.jsii b/packages/@aws-cdk/aws-batch-alpha/.jsii deleted file mode 100644 index c1ba9b1aeaab4..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/.jsii +++ /dev/null @@ -1,15284 +0,0 @@ -{ - "author": { - "name": "Amazon Web Services", - "organization": true, - "roles": [ - "author" - ], - "url": "https://aws.amazon.com" - }, - "dependencies": { - "aws-cdk-lib": "^0.0.0", - "constructs": "^10.0.0" - }, - "dependencyClosure": { - "@aws-cdk/asset-awscli-v1": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Asset.AwsCliV1", - "packageId": "Amazon.CDK.Asset.AwsCliV1" - }, - "go": { - "moduleName": "github.com/cdklabs/awscdk-asset-awscli-go", - "packageName": "awscliv1" - }, - "java": { - "maven": { - "artifactId": "cdk-asset-awscli-v1", - "groupId": "software.amazon.awscdk" - }, - "package": "software.amazon.awscdk.cdk.asset.awscli.v1" - }, - "js": { - "npm": "@aws-cdk/asset-awscli-v1" - }, - "python": { - "distName": "aws-cdk.asset-awscli-v1", - "module": "aws_cdk.asset_awscli_v1" - } - } - }, - "@aws-cdk/asset-kubectl-v20": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Asset.KubectlV20", - "packageId": "Amazon.CDK.Asset.KubectlV20" - }, - "go": { - "moduleName": "github.com/cdklabs/awscdk-asset-kubectl-go", - "packageName": "kubectlv20" - }, - "java": { - "maven": { - "artifactId": "cdk-asset-kubectl-v20", - "groupId": "software.amazon.awscdk" - }, - "package": "software.amazon.awscdk.cdk.asset.kubectl.v20" - }, - "js": { - "npm": "@aws-cdk/asset-kubectl-v20" - }, - "python": { - "distName": "aws-cdk.asset-kubectl-v20", - "module": "aws_cdk.asset_kubectl_v20" - } - } - }, - "@aws-cdk/asset-node-proxy-agent-v6": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Asset.NodeProxyAgentV6", - "packageId": "Amazon.CDK.Asset.NodeProxyAgentV6" - }, - "go": { - "moduleName": "github.com/cdklabs/awscdk-asset-node-proxy-agent-go", - "packageName": "nodeproxyagentv6" - }, - "java": { - "maven": { - "artifactId": "cdk-asset-node-proxy-agent-v6", - "groupId": "software.amazon.awscdk" - }, - "package": "software.amazon.awscdk.cdk.asset.node.proxy.agent.v6" - }, - "js": { - "npm": "@aws-cdk/asset-node-proxy-agent-v6" - }, - "python": { - "distName": "aws-cdk.asset-node-proxy-agent-v6", - "module": "aws_cdk.asset_node_proxy_agent_v6" - } - } - }, - "aws-cdk-lib": { - "submodules": { - "aws-cdk-lib.alexa_ask": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Alexa.Ask" - }, - "java": { - "package": "software.amazon.awscdk.alexa.ask" - }, - "python": { - "module": "aws_cdk.alexa_ask" - } - } - }, - "aws-cdk-lib.assertions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Assertions" - }, - "java": { - "package": "software.amazon.awscdk.assertions" - }, - "python": { - "module": "aws_cdk.assertions" - } - } - }, - "aws-cdk-lib.assets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Assets" - }, - "java": { - "package": "software.amazon.awscdk.assets" - }, - "python": { - "module": "aws_cdk.assets" - } - } - }, - "aws-cdk-lib.aws_accessanalyzer": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AccessAnalyzer" - }, - "java": { - "package": "software.amazon.awscdk.services.accessanalyzer" - }, - "python": { - "module": "aws_cdk.aws_accessanalyzer" - } - } - }, - "aws-cdk-lib.aws_acmpca": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ACMPCA" - }, - "java": { - "package": "software.amazon.awscdk.services.acmpca" - }, - "python": { - "module": "aws_cdk.aws_acmpca" - } - } - }, - "aws-cdk-lib.aws_amazonmq": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AmazonMQ" - }, - "java": { - "package": "software.amazon.awscdk.services.amazonmq" - }, - "python": { - "module": "aws_cdk.aws_amazonmq" - } - } - }, - "aws-cdk-lib.aws_amplify": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Amplify" - }, - "java": { - "package": "software.amazon.awscdk.services.amplify" - }, - "python": { - "module": "aws_cdk.aws_amplify" - } - } - }, - "aws-cdk-lib.aws_amplifyuibuilder": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AmplifyUIBuilder" - }, - "java": { - "package": "software.amazon.awscdk.services.amplifyuibuilder" - }, - "python": { - "module": "aws_cdk.aws_amplifyuibuilder" - } - } - }, - "aws-cdk-lib.aws_apigateway": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.APIGateway" - }, - "java": { - "package": "software.amazon.awscdk.services.apigateway" - }, - "python": { - "module": "aws_cdk.aws_apigateway" - } - } - }, - "aws-cdk-lib.aws_apigatewayv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Apigatewayv2" - }, - "java": { - "package": "software.amazon.awscdk.services.apigatewayv2" - }, - "python": { - "module": "aws_cdk.aws_apigatewayv2" - } - } - }, - "aws-cdk-lib.aws_appconfig": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppConfig" - }, - "java": { - "package": "software.amazon.awscdk.services.appconfig" - }, - "python": { - "module": "aws_cdk.aws_appconfig" - } - } - }, - "aws-cdk-lib.aws_appflow": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppFlow" - }, - "java": { - "package": "software.amazon.awscdk.services.appflow" - }, - "python": { - "module": "aws_cdk.aws_appflow" - } - } - }, - "aws-cdk-lib.aws_appintegrations": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppIntegrations" - }, - "java": { - "package": "software.amazon.awscdk.services.appintegrations" - }, - "python": { - "module": "aws_cdk.aws_appintegrations" - } - } - }, - "aws-cdk-lib.aws_applicationautoscaling": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ApplicationAutoScaling" - }, - "java": { - "package": "software.amazon.awscdk.services.applicationautoscaling" - }, - "python": { - "module": "aws_cdk.aws_applicationautoscaling" - } - } - }, - "aws-cdk-lib.aws_applicationinsights": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ApplicationInsights" - }, - "java": { - "package": "software.amazon.awscdk.services.applicationinsights" - }, - "python": { - "module": "aws_cdk.aws_applicationinsights" - } - } - }, - "aws-cdk-lib.aws_appmesh": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppMesh" - }, - "java": { - "package": "software.amazon.awscdk.services.appmesh" - }, - "python": { - "module": "aws_cdk.aws_appmesh" - } - } - }, - "aws-cdk-lib.aws_apprunner": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppRunner" - }, - "java": { - "package": "software.amazon.awscdk.services.apprunner" - }, - "python": { - "module": "aws_cdk.aws_apprunner" - } - } - }, - "aws-cdk-lib.aws_appstream": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppStream" - }, - "java": { - "package": "software.amazon.awscdk.services.appstream" - }, - "python": { - "module": "aws_cdk.aws_appstream" - } - } - }, - "aws-cdk-lib.aws_appsync": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AppSync" - }, - "java": { - "package": "software.amazon.awscdk.services.appsync" - }, - "python": { - "module": "aws_cdk.aws_appsync" - } - } - }, - "aws-cdk-lib.aws_aps": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.APS" - }, - "java": { - "package": "software.amazon.awscdk.services.aps" - }, - "python": { - "module": "aws_cdk.aws_aps" - } - } - }, - "aws-cdk-lib.aws_athena": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Athena" - }, - "java": { - "package": "software.amazon.awscdk.services.athena" - }, - "python": { - "module": "aws_cdk.aws_athena" - } - } - }, - "aws-cdk-lib.aws_auditmanager": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AuditManager" - }, - "java": { - "package": "software.amazon.awscdk.services.auditmanager" - }, - "python": { - "module": "aws_cdk.aws_auditmanager" - } - } - }, - "aws-cdk-lib.aws_autoscaling": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AutoScaling" - }, - "java": { - "package": "software.amazon.awscdk.services.autoscaling" - }, - "python": { - "module": "aws_cdk.aws_autoscaling" - } - } - }, - "aws-cdk-lib.aws_autoscaling_common": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AutoScaling.Common" - }, - "java": { - "package": "software.amazon.awscdk.services.autoscaling.common" - }, - "python": { - "module": "aws_cdk.aws_autoscaling_common" - } - } - }, - "aws-cdk-lib.aws_autoscaling_hooktargets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AutoScaling.HookTargets" - }, - "java": { - "package": "software.amazon.awscdk.services.autoscaling.hooktargets" - }, - "python": { - "module": "aws_cdk.aws_autoscaling_hooktargets" - } - } - }, - "aws-cdk-lib.aws_autoscalingplans": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.AutoScalingPlans" - }, - "java": { - "package": "software.amazon.awscdk.services.autoscalingplans" - }, - "python": { - "module": "aws_cdk.aws_autoscalingplans" - } - } - }, - "aws-cdk-lib.aws_backup": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Backup" - }, - "java": { - "package": "software.amazon.awscdk.services.backup" - }, - "python": { - "module": "aws_cdk.aws_backup" - } - } - }, - "aws-cdk-lib.aws_backupgateway": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.BackupGateway" - }, - "java": { - "package": "services.backupgateway" - }, - "python": { - "module": "aws_cdk.aws_backupgateway" - } - } - }, - "aws-cdk-lib.aws_batch": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Batch" - }, - "java": { - "package": "software.amazon.awscdk.services.batch" - }, - "python": { - "module": "aws_cdk.aws_batch" - } - } - }, - "aws-cdk-lib.aws_billingconductor": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.BillingConductor" - }, - "java": { - "package": "software.amazon.awscdk.services.billingconductor" - }, - "python": { - "module": "aws_cdk.aws_billingconductor" - } - } - }, - "aws-cdk-lib.aws_budgets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Budgets" - }, - "java": { - "package": "software.amazon.awscdk.services.budgets" - }, - "python": { - "module": "aws_cdk.aws_budgets" - } - } - }, - "aws-cdk-lib.aws_cassandra": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Cassandra" - }, - "java": { - "package": "software.amazon.awscdk.services.cassandra" - }, - "python": { - "module": "aws_cdk.aws_cassandra" - } - } - }, - "aws-cdk-lib.aws_ce": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CE" - }, - "java": { - "package": "software.amazon.awscdk.services.ce" - }, - "python": { - "module": "aws_cdk.aws_ce" - } - } - }, - "aws-cdk-lib.aws_certificatemanager": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CertificateManager" - }, - "java": { - "package": "software.amazon.awscdk.services.certificatemanager" - }, - "python": { - "module": "aws_cdk.aws_certificatemanager" - } - } - }, - "aws-cdk-lib.aws_chatbot": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Chatbot" - }, - "java": { - "package": "software.amazon.awscdk.services.chatbot" - }, - "python": { - "module": "aws_cdk.aws_chatbot" - } - } - }, - "aws-cdk-lib.aws_cleanrooms": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.CleanRooms" - }, - "java": { - "package": "services.cleanrooms" - }, - "python": { - "module": "aws_cdk.aws_cleanrooms" - } - } - }, - "aws-cdk-lib.aws_cloud9": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Cloud9" - }, - "java": { - "package": "software.amazon.awscdk.services.cloud9" - }, - "python": { - "module": "aws_cdk.aws_cloud9" - } - } - }, - "aws-cdk-lib.aws_cloudformation": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudFormation" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudformation" - }, - "python": { - "module": "aws_cdk.aws_cloudformation" - } - } - }, - "aws-cdk-lib.aws_cloudfront": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudFront" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudfront" - }, - "python": { - "module": "aws_cdk.aws_cloudfront" - } - } - }, - "aws-cdk-lib.aws_cloudfront.experimental": {}, - "aws-cdk-lib.aws_cloudfront_origins": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudFront.Origins" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudfront.origins" - }, - "python": { - "module": "aws_cdk.aws_cloudfront_origins" - } - } - }, - "aws-cdk-lib.aws_cloudtrail": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudTrail" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudtrail" - }, - "python": { - "module": "aws_cdk.aws_cloudtrail" - } - } - }, - "aws-cdk-lib.aws_cloudwatch": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudWatch" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudwatch" - }, - "python": { - "module": "aws_cdk.aws_cloudwatch" - } - } - }, - "aws-cdk-lib.aws_cloudwatch_actions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CloudWatch.Actions" - }, - "java": { - "package": "software.amazon.awscdk.services.cloudwatch.actions" - }, - "python": { - "module": "aws_cdk.aws_cloudwatch_actions" - } - } - }, - "aws-cdk-lib.aws_codeartifact": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeArtifact" - }, - "java": { - "package": "software.amazon.awscdk.services.codeartifact" - }, - "python": { - "module": "aws_cdk.aws_codeartifact" - } - } - }, - "aws-cdk-lib.aws_codebuild": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeBuild" - }, - "java": { - "package": "software.amazon.awscdk.services.codebuild" - }, - "python": { - "module": "aws_cdk.aws_codebuild" - } - } - }, - "aws-cdk-lib.aws_codecommit": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeCommit" - }, - "java": { - "package": "software.amazon.awscdk.services.codecommit" - }, - "python": { - "module": "aws_cdk.aws_codecommit" - } - } - }, - "aws-cdk-lib.aws_codedeploy": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeDeploy" - }, - "java": { - "package": "software.amazon.awscdk.services.codedeploy" - }, - "python": { - "module": "aws_cdk.aws_codedeploy" - } - } - }, - "aws-cdk-lib.aws_codeguruprofiler": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeGuruProfiler" - }, - "java": { - "package": "software.amazon.awscdk.services.codeguruprofiler" - }, - "python": { - "module": "aws_cdk.aws_codeguruprofiler" - } - } - }, - "aws-cdk-lib.aws_codegurureviewer": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeGuruReviewer" - }, - "java": { - "package": "software.amazon.awscdk.services.codegurureviewer" - }, - "python": { - "module": "aws_cdk.aws_codegurureviewer" - } - } - }, - "aws-cdk-lib.aws_codepipeline": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodePipeline" - }, - "java": { - "package": "software.amazon.awscdk.services.codepipeline" - }, - "python": { - "module": "aws_cdk.aws_codepipeline" - } - } - }, - "aws-cdk-lib.aws_codepipeline_actions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodePipeline.Actions" - }, - "java": { - "package": "software.amazon.awscdk.services.codepipeline.actions" - }, - "python": { - "module": "aws_cdk.aws_codepipeline_actions" - } - } - }, - "aws-cdk-lib.aws_codestar": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Codestar" - }, - "java": { - "package": "software.amazon.awscdk.services.codestar" - }, - "python": { - "module": "aws_cdk.aws_codestar" - } - } - }, - "aws-cdk-lib.aws_codestarconnections": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeStarConnections" - }, - "java": { - "package": "software.amazon.awscdk.services.codestarconnections" - }, - "python": { - "module": "aws_cdk.aws_codestarconnections" - } - } - }, - "aws-cdk-lib.aws_codestarnotifications": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CodeStarNotifications" - }, - "java": { - "package": "software.amazon.awscdk.services.codestarnotifications" - }, - "python": { - "module": "aws_cdk.aws_codestarnotifications" - } - } - }, - "aws-cdk-lib.aws_cognito": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Cognito" - }, - "java": { - "package": "software.amazon.awscdk.services.cognito" - }, - "python": { - "module": "aws_cdk.aws_cognito" - } - } - }, - "aws-cdk-lib.aws_comprehend": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Comprehend" - }, - "java": { - "package": "software.amazon.awscdk.services.comprehend" - }, - "python": { - "module": "aws_cdk.aws_comprehend" - } - } - }, - "aws-cdk-lib.aws_config": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Config" - }, - "java": { - "package": "software.amazon.awscdk.services.config" - }, - "python": { - "module": "aws_cdk.aws_config" - } - } - }, - "aws-cdk-lib.aws_connect": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Connect" - }, - "java": { - "package": "software.amazon.awscdk.services.connect" - }, - "python": { - "module": "aws_cdk.aws_connect" - } - } - }, - "aws-cdk-lib.aws_connectcampaigns": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ConnectCampaigns" - }, - "java": { - "package": "software.amazon.awscdk.services.connectcampaigns" - }, - "python": { - "module": "aws_cdk.aws_connectcampaigns" - } - } - }, - "aws-cdk-lib.aws_controltower": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ControlTower" - }, - "java": { - "package": "software.amazon.awscdk.services.controltower" - }, - "python": { - "module": "aws_cdk.aws_controltower" - } - } - }, - "aws-cdk-lib.aws_cur": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CUR" - }, - "java": { - "package": "software.amazon.awscdk.services.cur" - }, - "python": { - "module": "aws_cdk.aws_cur" - } - } - }, - "aws-cdk-lib.aws_customerprofiles": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.CustomerProfiles" - }, - "java": { - "package": "software.amazon.awscdk.services.customerprofiles" - }, - "python": { - "module": "aws_cdk.aws_customerprofiles" - } - } - }, - "aws-cdk-lib.aws_databrew": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DataBrew" - }, - "java": { - "package": "software.amazon.awscdk.services.databrew" - }, - "python": { - "module": "aws_cdk.aws_databrew" - } - } - }, - "aws-cdk-lib.aws_datapipeline": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DataPipeline" - }, - "java": { - "package": "software.amazon.awscdk.services.datapipeline" - }, - "python": { - "module": "aws_cdk.aws_datapipeline" - } - } - }, - "aws-cdk-lib.aws_datasync": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DataSync" - }, - "java": { - "package": "software.amazon.awscdk.services.datasync" - }, - "python": { - "module": "aws_cdk.aws_datasync" - } - } - }, - "aws-cdk-lib.aws_dax": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DAX" - }, - "java": { - "package": "software.amazon.awscdk.services.dax" - }, - "python": { - "module": "aws_cdk.aws_dax" - } - } - }, - "aws-cdk-lib.aws_detective": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Detective" - }, - "java": { - "package": "software.amazon.awscdk.services.detective" - }, - "python": { - "module": "aws_cdk.aws_detective" - } - } - }, - "aws-cdk-lib.aws_devicefarm": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DeviceFarm" - }, - "java": { - "package": "software.amazon.awscdk.services.devicefarm" - }, - "python": { - "module": "aws_cdk.aws_devicefarm" - } - } - }, - "aws-cdk-lib.aws_devopsguru": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DevOpsGuru" - }, - "java": { - "package": "software.amazon.awscdk.services.devopsguru" - }, - "python": { - "module": "aws_cdk.aws_devopsguru" - } - } - }, - "aws-cdk-lib.aws_directoryservice": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DirectoryService" - }, - "java": { - "package": "software.amazon.awscdk.services.directoryservice" - }, - "python": { - "module": "aws_cdk.aws_directoryservice" - } - } - }, - "aws-cdk-lib.aws_dlm": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DLM" - }, - "java": { - "package": "software.amazon.awscdk.services.dlm" - }, - "python": { - "module": "aws_cdk.aws_dlm" - } - } - }, - "aws-cdk-lib.aws_dms": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DMS" - }, - "java": { - "package": "software.amazon.awscdk.services.dms" - }, - "python": { - "module": "aws_cdk.aws_dms" - } - } - }, - "aws-cdk-lib.aws_docdb": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DocDB" - }, - "java": { - "package": "software.amazon.awscdk.services.docdb" - }, - "python": { - "module": "aws_cdk.aws_docdb" - } - } - }, - "aws-cdk-lib.aws_docdbelastic": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DocDBElastic" - }, - "java": { - "package": "software.amazon.awscdk.services.docdbelastic" - }, - "python": { - "module": "aws_cdk.aws_docdbelastic" - } - } - }, - "aws-cdk-lib.aws_dynamodb": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.DynamoDB" - }, - "java": { - "package": "software.amazon.awscdk.services.dynamodb" - }, - "python": { - "module": "aws_cdk.aws_dynamodb" - } - } - }, - "aws-cdk-lib.aws_ec2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EC2" - }, - "java": { - "package": "software.amazon.awscdk.services.ec2" - }, - "python": { - "module": "aws_cdk.aws_ec2" - } - } - }, - "aws-cdk-lib.aws_ecr": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ECR" - }, - "java": { - "package": "software.amazon.awscdk.services.ecr" - }, - "python": { - "module": "aws_cdk.aws_ecr" - } - } - }, - "aws-cdk-lib.aws_ecr_assets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Ecr.Assets" - }, - "java": { - "package": "software.amazon.awscdk.services.ecr.assets" - }, - "python": { - "module": "aws_cdk.aws_ecr_assets" - } - } - }, - "aws-cdk-lib.aws_ecs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ECS" - }, - "java": { - "package": "software.amazon.awscdk.services.ecs" - }, - "python": { - "module": "aws_cdk.aws_ecs" - } - } - }, - "aws-cdk-lib.aws_ecs_patterns": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ECS.Patterns" - }, - "java": { - "package": "software.amazon.awscdk.services.ecs.patterns" - }, - "python": { - "module": "aws_cdk.aws_ecs_patterns" - } - } - }, - "aws-cdk-lib.aws_efs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EFS" - }, - "java": { - "package": "software.amazon.awscdk.services.efs" - }, - "python": { - "module": "aws_cdk.aws_efs" - } - } - }, - "aws-cdk-lib.aws_eks": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EKS" - }, - "java": { - "package": "software.amazon.awscdk.services.eks" - }, - "python": { - "module": "aws_cdk.aws_eks" - } - } - }, - "aws-cdk-lib.aws_elasticache": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElastiCache" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticache" - }, - "python": { - "module": "aws_cdk.aws_elasticache" - } - } - }, - "aws-cdk-lib.aws_elasticbeanstalk": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElasticBeanstalk" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticbeanstalk" - }, - "python": { - "module": "aws_cdk.aws_elasticbeanstalk" - } - } - }, - "aws-cdk-lib.aws_elasticloadbalancing": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElasticLoadBalancing" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticloadbalancing" - }, - "python": { - "module": "aws_cdk.aws_elasticloadbalancing" - } - } - }, - "aws-cdk-lib.aws_elasticloadbalancingv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElasticLoadBalancingV2" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticloadbalancingv2" - }, - "python": { - "module": "aws_cdk.aws_elasticloadbalancingv2" - } - } - }, - "aws-cdk-lib.aws_elasticloadbalancingv2_actions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElasticLoadBalancingV2.Actions" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticloadbalancingv2.actions" - }, - "python": { - "module": "aws_cdk.aws_elasticloadbalancingv2_actions" - } - } - }, - "aws-cdk-lib.aws_elasticloadbalancingv2_targets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ElasticLoadBalancingV2.Targets" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticloadbalancingv2.targets" - }, - "python": { - "module": "aws_cdk.aws_elasticloadbalancingv2_targets" - } - } - }, - "aws-cdk-lib.aws_elasticsearch": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Elasticsearch" - }, - "java": { - "package": "software.amazon.awscdk.services.elasticsearch" - }, - "python": { - "module": "aws_cdk.aws_elasticsearch" - } - } - }, - "aws-cdk-lib.aws_emr": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EMR" - }, - "java": { - "package": "software.amazon.awscdk.services.emr" - }, - "python": { - "module": "aws_cdk.aws_emr" - } - } - }, - "aws-cdk-lib.aws_emrcontainers": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EMRContainers" - }, - "java": { - "package": "software.amazon.awscdk.services.emrcontainers" - }, - "python": { - "module": "aws_cdk.aws_emrcontainers" - } - } - }, - "aws-cdk-lib.aws_emrserverless": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EMRServerless" - }, - "java": { - "package": "software.amazon.awscdk.services.emrserverless" - }, - "python": { - "module": "aws_cdk.aws_emrserverless" - } - } - }, - "aws-cdk-lib.aws_events": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Events" - }, - "java": { - "package": "software.amazon.awscdk.services.events" - }, - "python": { - "module": "aws_cdk.aws_events" - } - } - }, - "aws-cdk-lib.aws_events_targets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Events.Targets" - }, - "java": { - "package": "software.amazon.awscdk.services.events.targets" - }, - "python": { - "module": "aws_cdk.aws_events_targets" - } - } - }, - "aws-cdk-lib.aws_eventschemas": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.EventSchemas" - }, - "java": { - "package": "software.amazon.awscdk.services.eventschemas" - }, - "python": { - "module": "aws_cdk.aws_eventschemas" - } - } - }, - "aws-cdk-lib.aws_evidently": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Evidently" - }, - "java": { - "package": "software.amazon.awscdk.services.evidently" - }, - "python": { - "module": "aws_cdk.aws_evidently" - } - } - }, - "aws-cdk-lib.aws_finspace": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.FinSpace" - }, - "java": { - "package": "software.amazon.awscdk.services.finspace" - }, - "python": { - "module": "aws_cdk.aws_finspace" - } - } - }, - "aws-cdk-lib.aws_fis": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.FIS" - }, - "java": { - "package": "software.amazon.awscdk.services.fis" - }, - "python": { - "module": "aws_cdk.aws_fis" - } - } - }, - "aws-cdk-lib.aws_fms": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.FMS" - }, - "java": { - "package": "software.amazon.awscdk.services.fms" - }, - "python": { - "module": "aws_cdk.aws_fms" - } - } - }, - "aws-cdk-lib.aws_forecast": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Forecast" - }, - "java": { - "package": "software.amazon.awscdk.services.forecast" - }, - "python": { - "module": "aws_cdk.aws_forecast" - } - } - }, - "aws-cdk-lib.aws_frauddetector": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.FraudDetector" - }, - "java": { - "package": "software.amazon.awscdk.services.frauddetector" - }, - "python": { - "module": "aws_cdk.aws_frauddetector" - } - } - }, - "aws-cdk-lib.aws_fsx": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.FSx" - }, - "java": { - "package": "software.amazon.awscdk.services.fsx" - }, - "python": { - "module": "aws_cdk.aws_fsx" - } - } - }, - "aws-cdk-lib.aws_gamelift": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GameLift" - }, - "java": { - "package": "software.amazon.awscdk.services.gamelift" - }, - "python": { - "module": "aws_cdk.aws_gamelift" - } - } - }, - "aws-cdk-lib.aws_globalaccelerator": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GlobalAccelerator" - }, - "java": { - "package": "software.amazon.awscdk.services.globalaccelerator" - }, - "python": { - "module": "aws_cdk.aws_globalaccelerator" - } - } - }, - "aws-cdk-lib.aws_globalaccelerator_endpoints": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GlobalAccelerator.Endpoints" - }, - "java": { - "package": "software.amazon.awscdk.services.globalaccelerator.endpoints" - }, - "python": { - "module": "aws_cdk.aws_globalaccelerator_endpoints" - } - } - }, - "aws-cdk-lib.aws_glue": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Glue" - }, - "java": { - "package": "software.amazon.awscdk.services.glue" - }, - "python": { - "module": "aws_cdk.aws_glue" - } - } - }, - "aws-cdk-lib.aws_grafana": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Grafana" - }, - "java": { - "package": "software.amazon.awscdk.services.grafana" - }, - "python": { - "module": "aws_cdk.aws_grafana" - } - } - }, - "aws-cdk-lib.aws_greengrass": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Greengrass" - }, - "java": { - "package": "software.amazon.awscdk.services.greengrass" - }, - "python": { - "module": "aws_cdk.aws_greengrass" - } - } - }, - "aws-cdk-lib.aws_greengrassv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GreengrassV2" - }, - "java": { - "package": "software.amazon.awscdk.services.greengrassv2" - }, - "python": { - "module": "aws_cdk.aws_greengrassv2" - } - } - }, - "aws-cdk-lib.aws_groundstation": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GroundStation" - }, - "java": { - "package": "software.amazon.awscdk.services.groundstation" - }, - "python": { - "module": "aws_cdk.aws_groundstation" - } - } - }, - "aws-cdk-lib.aws_guardduty": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.GuardDuty" - }, - "java": { - "package": "software.amazon.awscdk.services.guardduty" - }, - "python": { - "module": "aws_cdk.aws_guardduty" - } - } - }, - "aws-cdk-lib.aws_healthlake": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.HealthLake" - }, - "java": { - "package": "software.amazon.awscdk.services.healthlake" - }, - "python": { - "module": "aws_cdk.aws_healthlake" - } - } - }, - "aws-cdk-lib.aws_iam": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IAM" - }, - "java": { - "package": "software.amazon.awscdk.services.iam" - }, - "python": { - "module": "aws_cdk.aws_iam" - } - } - }, - "aws-cdk-lib.aws_identitystore": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IdentityStore" - }, - "java": { - "package": "software.amazon.awscdk.services.identitystore" - }, - "python": { - "module": "aws_cdk.aws_identitystore" - } - } - }, - "aws-cdk-lib.aws_imagebuilder": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ImageBuilder" - }, - "java": { - "package": "software.amazon.awscdk.services.imagebuilder" - }, - "python": { - "module": "aws_cdk.aws_imagebuilder" - } - } - }, - "aws-cdk-lib.aws_inspector": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Inspector" - }, - "java": { - "package": "software.amazon.awscdk.services.inspector" - }, - "python": { - "module": "aws_cdk.aws_inspector" - } - } - }, - "aws-cdk-lib.aws_inspectorv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.InspectorV2" - }, - "java": { - "package": "software.amazon.awscdk.services.inspectorv2" - }, - "python": { - "module": "aws_cdk.aws_inspectorv2" - } - } - }, - "aws-cdk-lib.aws_internetmonitor": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.InternetMonitor" - }, - "java": { - "package": "software.amazon.awscdk.services.internetmonitor" - }, - "python": { - "module": "aws_cdk.aws_internetmonitor" - } - } - }, - "aws-cdk-lib.aws_iot": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoT" - }, - "java": { - "package": "software.amazon.awscdk.services.iot" - }, - "python": { - "module": "aws_cdk.aws_iot" - } - } - }, - "aws-cdk-lib.aws_iot1click": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoT1Click" - }, - "java": { - "package": "software.amazon.awscdk.services.iot1click" - }, - "python": { - "module": "aws_cdk.aws_iot1click" - } - } - }, - "aws-cdk-lib.aws_iotanalytics": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTAnalytics" - }, - "java": { - "package": "software.amazon.awscdk.services.iotanalytics" - }, - "python": { - "module": "aws_cdk.aws_iotanalytics" - } - } - }, - "aws-cdk-lib.aws_iotcoredeviceadvisor": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTCoreDeviceAdvisor" - }, - "java": { - "package": "software.amazon.awscdk.services.iotcoredeviceadvisor" - }, - "python": { - "module": "aws_cdk.aws_iotcoredeviceadvisor" - } - } - }, - "aws-cdk-lib.aws_iotevents": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTEvents" - }, - "java": { - "package": "software.amazon.awscdk.services.iotevents" - }, - "python": { - "module": "aws_cdk.aws_iotevents" - } - } - }, - "aws-cdk-lib.aws_iotfleethub": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTFleetHub" - }, - "java": { - "package": "software.amazon.awscdk.services.iotfleethub" - }, - "python": { - "module": "aws_cdk.aws_iotfleethub" - } - } - }, - "aws-cdk-lib.aws_iotfleetwise": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTFleetWise" - }, - "java": { - "package": "software.amazon.awscdk.services.iotfleetwise" - }, - "python": { - "module": "aws_cdk.aws_iotfleetwise" - } - } - }, - "aws-cdk-lib.aws_iotsitewise": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTSiteWise" - }, - "java": { - "package": "software.amazon.awscdk.services.iotsitewise" - }, - "python": { - "module": "aws_cdk.aws_iotsitewise" - } - } - }, - "aws-cdk-lib.aws_iotthingsgraph": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTThingsGraph" - }, - "java": { - "package": "software.amazon.awscdk.services.iotthingsgraph" - }, - "python": { - "module": "aws_cdk.aws_iotthingsgraph" - } - } - }, - "aws-cdk-lib.aws_iottwinmaker": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTTwinMaker" - }, - "java": { - "package": "software.amazon.awscdk.services.iottwinmaker" - }, - "python": { - "module": "aws_cdk.aws_iottwinmaker" - } - } - }, - "aws-cdk-lib.aws_iotwireless": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IoTWireless" - }, - "java": { - "package": "software.amazon.awscdk.services.iotwireless" - }, - "python": { - "module": "aws_cdk.aws_iotwireless" - } - } - }, - "aws-cdk-lib.aws_ivs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Ivs" - }, - "java": { - "package": "software.amazon.awscdk.services.ivs" - }, - "python": { - "module": "aws_cdk.aws_ivs" - } - } - }, - "aws-cdk-lib.aws_ivschat": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.IVSChat" - }, - "java": { - "package": "software.amazon.awscdk.services.ivschat" - }, - "python": { - "module": "aws_cdk.aws_ivschat" - } - } - }, - "aws-cdk-lib.aws_kafkaconnect": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KafkaConnect" - }, - "java": { - "package": "software.amazon.awscdk.services.kafkaconnect" - }, - "python": { - "module": "aws_cdk.aws_kafkaconnect" - } - } - }, - "aws-cdk-lib.aws_kendra": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Kendra" - }, - "java": { - "package": "software.amazon.awscdk.services.kendra" - }, - "python": { - "module": "aws_cdk.aws_kendra" - } - } - }, - "aws-cdk-lib.aws_kendraranking": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KendraRanking" - }, - "java": { - "package": "software.amazon.awscdk.services.kendraranking" - }, - "python": { - "module": "aws_cdk.aws_kendraranking" - } - } - }, - "aws-cdk-lib.aws_kinesis": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Kinesis" - }, - "java": { - "package": "software.amazon.awscdk.services.kinesis" - }, - "python": { - "module": "aws_cdk.aws_kinesis" - } - } - }, - "aws-cdk-lib.aws_kinesisanalytics": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KinesisAnalytics" - }, - "java": { - "package": "software.amazon.awscdk.services.kinesisanalytics" - }, - "python": { - "module": "aws_cdk.aws_kinesisanalytics" - } - } - }, - "aws-cdk-lib.aws_kinesisanalyticsv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KinesisAnalyticsV2" - }, - "java": { - "package": "software.amazon.awscdk.services.kinesisanalyticsv2" - }, - "python": { - "module": "aws_cdk.aws_kinesisanalyticsv2" - } - } - }, - "aws-cdk-lib.aws_kinesisfirehose": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KinesisFirehose" - }, - "java": { - "package": "software.amazon.awscdk.services.kinesisfirehose" - }, - "python": { - "module": "aws_cdk.aws_kinesisfirehose" - } - } - }, - "aws-cdk-lib.aws_kinesisvideo": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KinesisVideo" - }, - "java": { - "package": "software.amazon.awscdk.services.kinesisvideo" - }, - "python": { - "module": "aws_cdk.aws_kinesisvideo" - } - } - }, - "aws-cdk-lib.aws_kms": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.KMS" - }, - "java": { - "package": "software.amazon.awscdk.services.kms" - }, - "python": { - "module": "aws_cdk.aws_kms" - } - } - }, - "aws-cdk-lib.aws_lakeformation": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.LakeFormation" - }, - "java": { - "package": "software.amazon.awscdk.services.lakeformation" - }, - "python": { - "module": "aws_cdk.aws_lakeformation" - } - } - }, - "aws-cdk-lib.aws_lambda": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lambda" - }, - "java": { - "package": "software.amazon.awscdk.services.lambda" - }, - "python": { - "module": "aws_cdk.aws_lambda" - } - } - }, - "aws-cdk-lib.aws_lambda_destinations": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lambda.Destinations" - }, - "java": { - "package": "software.amazon.awscdk.services.lambda.destinations" - }, - "python": { - "module": "aws_cdk.aws_lambda_destinations" - } - } - }, - "aws-cdk-lib.aws_lambda_event_sources": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lambda.EventSources" - }, - "java": { - "package": "software.amazon.awscdk.services.lambda.eventsources" - }, - "python": { - "module": "aws_cdk.aws_lambda_event_sources" - } - } - }, - "aws-cdk-lib.aws_lambda_nodejs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lambda.Nodejs" - }, - "java": { - "package": "software.amazon.awscdk.services.lambda.nodejs" - }, - "python": { - "module": "aws_cdk.aws_lambda_nodejs" - } - } - }, - "aws-cdk-lib.aws_lex": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lex" - }, - "java": { - "package": "software.amazon.awscdk.services.lex" - }, - "python": { - "module": "aws_cdk.aws_lex" - } - } - }, - "aws-cdk-lib.aws_licensemanager": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.LicenseManager" - }, - "java": { - "package": "software.amazon.awscdk.services.licensemanager" - }, - "python": { - "module": "aws_cdk.aws_licensemanager" - } - } - }, - "aws-cdk-lib.aws_lightsail": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Lightsail" - }, - "java": { - "package": "software.amazon.awscdk.services.lightsail" - }, - "python": { - "module": "aws_cdk.aws_lightsail" - } - } - }, - "aws-cdk-lib.aws_location": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Location" - }, - "java": { - "package": "software.amazon.awscdk.services.location" - }, - "python": { - "module": "aws_cdk.aws_location" - } - } - }, - "aws-cdk-lib.aws_logs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Logs" - }, - "java": { - "package": "software.amazon.awscdk.services.logs" - }, - "python": { - "module": "aws_cdk.aws_logs" - } - } - }, - "aws-cdk-lib.aws_logs_destinations": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Logs.Destinations" - }, - "java": { - "package": "software.amazon.awscdk.services.logs.destinations" - }, - "python": { - "module": "aws_cdk.aws_logs_destinations" - } - } - }, - "aws-cdk-lib.aws_lookoutequipment": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.LookoutEquipment" - }, - "java": { - "package": "software.amazon.awscdk.services.lookoutequipment" - }, - "python": { - "module": "aws_cdk.aws_lookoutequipment" - } - } - }, - "aws-cdk-lib.aws_lookoutmetrics": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.LookoutMetrics" - }, - "java": { - "package": "software.amazon.awscdk.services.lookoutmetrics" - }, - "python": { - "module": "aws_cdk.aws_lookoutmetrics" - } - } - }, - "aws-cdk-lib.aws_lookoutvision": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.LookoutVision" - }, - "java": { - "package": "software.amazon.awscdk.services.lookoutvision" - }, - "python": { - "module": "aws_cdk.aws_lookoutvision" - } - } - }, - "aws-cdk-lib.aws_m2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.M2" - }, - "java": { - "package": "software.amazon.awscdk.services.m2" - }, - "python": { - "module": "aws_cdk.aws_m2" - } - } - }, - "aws-cdk-lib.aws_macie": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Macie" - }, - "java": { - "package": "software.amazon.awscdk.services.macie" - }, - "python": { - "module": "aws_cdk.aws_macie" - } - } - }, - "aws-cdk-lib.aws_managedblockchain": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ManagedBlockchain" - }, - "java": { - "package": "software.amazon.awscdk.services.managedblockchain" - }, - "python": { - "module": "aws_cdk.aws_managedblockchain" - } - } - }, - "aws-cdk-lib.aws_mediaconnect": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaConnect" - }, - "java": { - "package": "software.amazon.awscdk.services.mediaconnect" - }, - "python": { - "module": "aws_cdk.aws_mediaconnect" - } - } - }, - "aws-cdk-lib.aws_mediaconvert": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaConvert" - }, - "java": { - "package": "software.amazon.awscdk.services.mediaconvert" - }, - "python": { - "module": "aws_cdk.aws_mediaconvert" - } - } - }, - "aws-cdk-lib.aws_medialive": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaLive" - }, - "java": { - "package": "software.amazon.awscdk.services.medialive" - }, - "python": { - "module": "aws_cdk.aws_medialive" - } - } - }, - "aws-cdk-lib.aws_mediapackage": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaPackage" - }, - "java": { - "package": "software.amazon.awscdk.services.mediapackage" - }, - "python": { - "module": "aws_cdk.aws_mediapackage" - } - } - }, - "aws-cdk-lib.aws_mediastore": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaStore" - }, - "java": { - "package": "software.amazon.awscdk.services.mediastore" - }, - "python": { - "module": "aws_cdk.aws_mediastore" - } - } - }, - "aws-cdk-lib.aws_mediatailor": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MediaTailor" - }, - "java": { - "package": "software.amazon.awscdk.services.mediatailor" - }, - "python": { - "module": "aws_cdk.aws_mediatailor" - } - } - }, - "aws-cdk-lib.aws_memorydb": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MemoryDB" - }, - "java": { - "package": "software.amazon.awscdk.services.memorydb" - }, - "python": { - "module": "aws_cdk.aws_memorydb" - } - } - }, - "aws-cdk-lib.aws_msk": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MSK" - }, - "java": { - "package": "software.amazon.awscdk.services.msk" - }, - "python": { - "module": "aws_cdk.aws_msk" - } - } - }, - "aws-cdk-lib.aws_mwaa": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.MWAA" - }, - "java": { - "package": "software.amazon.awscdk.services.mwaa" - }, - "python": { - "module": "aws_cdk.aws_mwaa" - } - } - }, - "aws-cdk-lib.aws_neptune": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Neptune" - }, - "java": { - "package": "software.amazon.awscdk.services.neptune" - }, - "python": { - "module": "aws_cdk.aws_neptune" - } - } - }, - "aws-cdk-lib.aws_networkfirewall": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.NetworkFirewall" - }, - "java": { - "package": "software.amazon.awscdk.services.networkfirewall" - }, - "python": { - "module": "aws_cdk.aws_networkfirewall" - } - } - }, - "aws-cdk-lib.aws_networkmanager": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.NetworkManager" - }, - "java": { - "package": "software.amazon.awscdk.services.networkmanager" - }, - "python": { - "module": "aws_cdk.aws_networkmanager" - } - } - }, - "aws-cdk-lib.aws_nimblestudio": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.NimbleStudio" - }, - "java": { - "package": "software.amazon.awscdk.services.nimblestudio" - }, - "python": { - "module": "aws_cdk.aws_nimblestudio" - } - } - }, - "aws-cdk-lib.aws_oam": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Oam" - }, - "java": { - "package": "software.amazon.awscdk.services.oam" - }, - "python": { - "module": "aws_cdk.aws_oam" - } - } - }, - "aws-cdk-lib.aws_omics": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Omics" - }, - "java": { - "package": "software.amazon.awscdk.services.omics" - }, - "python": { - "module": "aws_cdk.aws_omics" - } - } - }, - "aws-cdk-lib.aws_opensearchserverless": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.OpenSearchServerless" - }, - "java": { - "package": "software.amazon.awscdk.services.opensearchserverless" - }, - "python": { - "module": "aws_cdk.aws_opensearchserverless" - } - } - }, - "aws-cdk-lib.aws_opensearchservice": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.OpenSearchService" - }, - "java": { - "package": "software.amazon.awscdk.services.opensearchservice" - }, - "python": { - "module": "aws_cdk.aws_opensearchservice" - } - } - }, - "aws-cdk-lib.aws_opsworks": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.OpsWorks" - }, - "java": { - "package": "software.amazon.awscdk.services.opsworks" - }, - "python": { - "module": "aws_cdk.aws_opsworks" - } - } - }, - "aws-cdk-lib.aws_opsworkscm": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.OpsWorksCM" - }, - "java": { - "package": "software.amazon.awscdk.services.opsworkscm" - }, - "python": { - "module": "aws_cdk.aws_opsworkscm" - } - } - }, - "aws-cdk-lib.aws_organizations": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Organizations" - }, - "java": { - "package": "software.amazon.awscdk.services.organizations" - }, - "python": { - "module": "aws_cdk.aws_organizations" - } - } - }, - "aws-cdk-lib.aws_osis": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.OSIS" - }, - "java": { - "package": "services.osis" - }, - "python": { - "module": "aws_cdk.aws_osis" - } - } - }, - "aws-cdk-lib.aws_panorama": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Panorama" - }, - "java": { - "package": "software.amazon.awscdk.services.panorama" - }, - "python": { - "module": "aws_cdk.aws_panorama" - } - } - }, - "aws-cdk-lib.aws_personalize": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Personalize" - }, - "java": { - "package": "software.amazon.awscdk.services.personalize" - }, - "python": { - "module": "aws_cdk.aws_personalize" - } - } - }, - "aws-cdk-lib.aws_pinpoint": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Pinpoint" - }, - "java": { - "package": "software.amazon.awscdk.services.pinpoint" - }, - "python": { - "module": "aws_cdk.aws_pinpoint" - } - } - }, - "aws-cdk-lib.aws_pinpointemail": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.PinpointEmail" - }, - "java": { - "package": "software.amazon.awscdk.services.pinpointemail" - }, - "python": { - "module": "aws_cdk.aws_pinpointemail" - } - } - }, - "aws-cdk-lib.aws_pipes": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Pipes" - }, - "java": { - "package": "software.amazon.awscdk.services.pipes" - }, - "python": { - "module": "aws_cdk.aws_pipes" - } - } - }, - "aws-cdk-lib.aws_proton": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.Proton" - }, - "java": { - "package": "services.proton" - }, - "python": { - "module": "aws_cdk.aws_proton" - } - } - }, - "aws-cdk-lib.aws_qldb": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.QLDB" - }, - "java": { - "package": "software.amazon.awscdk.services.qldb" - }, - "python": { - "module": "aws_cdk.aws_qldb" - } - } - }, - "aws-cdk-lib.aws_quicksight": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.QuickSight" - }, - "java": { - "package": "software.amazon.awscdk.services.quicksight" - }, - "python": { - "module": "aws_cdk.aws_quicksight" - } - } - }, - "aws-cdk-lib.aws_ram": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RAM" - }, - "java": { - "package": "software.amazon.awscdk.services.ram" - }, - "python": { - "module": "aws_cdk.aws_ram" - } - } - }, - "aws-cdk-lib.aws_rds": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RDS" - }, - "java": { - "package": "software.amazon.awscdk.services.rds" - }, - "python": { - "module": "aws_cdk.aws_rds" - } - } - }, - "aws-cdk-lib.aws_redshift": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Redshift" - }, - "java": { - "package": "software.amazon.awscdk.services.redshift" - }, - "python": { - "module": "aws_cdk.aws_redshift" - } - } - }, - "aws-cdk-lib.aws_redshiftserverless": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RedshiftServerless" - }, - "java": { - "package": "software.amazon.awscdk.services.redshiftserverless" - }, - "python": { - "module": "aws_cdk.aws_redshiftserverless" - } - } - }, - "aws-cdk-lib.aws_refactorspaces": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RefactorSpaces" - }, - "java": { - "package": "software.amazon.awscdk.services.refactorspaces" - }, - "python": { - "module": "aws_cdk.aws_refactorspaces" - } - } - }, - "aws-cdk-lib.aws_rekognition": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Rekognition" - }, - "java": { - "package": "software.amazon.awscdk.services.rekognition" - }, - "python": { - "module": "aws_cdk.aws_rekognition" - } - } - }, - "aws-cdk-lib.aws_resiliencehub": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ResilienceHub" - }, - "java": { - "package": "software.amazon.awscdk.services.resiliencehub" - }, - "python": { - "module": "aws_cdk.aws_resiliencehub" - } - } - }, - "aws-cdk-lib.aws_resourceexplorer2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ResourceExplorer2" - }, - "java": { - "package": "software.amazon.awscdk.services.resourceexplorer2" - }, - "python": { - "module": "aws_cdk.aws_resourceexplorer2" - } - } - }, - "aws-cdk-lib.aws_resourcegroups": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ResourceGroups" - }, - "java": { - "package": "software.amazon.awscdk.services.resourcegroups" - }, - "python": { - "module": "aws_cdk.aws_resourcegroups" - } - } - }, - "aws-cdk-lib.aws_robomaker": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RoboMaker" - }, - "java": { - "package": "software.amazon.awscdk.services.robomaker" - }, - "python": { - "module": "aws_cdk.aws_robomaker" - } - } - }, - "aws-cdk-lib.aws_rolesanywhere": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RolesAnywhere" - }, - "java": { - "package": "software.amazon.awscdk.services.rolesanywhere" - }, - "python": { - "module": "aws_cdk.aws_rolesanywhere" - } - } - }, - "aws-cdk-lib.aws_route53": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53" - }, - "java": { - "package": "software.amazon.awscdk.services.route53" - }, - "python": { - "module": "aws_cdk.aws_route53" - } - } - }, - "aws-cdk-lib.aws_route53_patterns": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53.Patterns" - }, - "java": { - "package": "software.amazon.awscdk.services.route53.patterns" - }, - "python": { - "module": "aws_cdk.aws_route53_patterns" - } - } - }, - "aws-cdk-lib.aws_route53_targets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53.Targets" - }, - "java": { - "package": "software.amazon.awscdk.services.route53.targets" - }, - "python": { - "module": "aws_cdk.aws_route53_targets" - } - } - }, - "aws-cdk-lib.aws_route53recoverycontrol": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53RecoveryControl" - }, - "java": { - "package": "software.amazon.awscdk.services.route53recoverycontrol" - }, - "python": { - "module": "aws_cdk.aws_route53recoverycontrol" - } - } - }, - "aws-cdk-lib.aws_route53recoveryreadiness": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53RecoveryReadiness" - }, - "java": { - "package": "software.amazon.awscdk.services.route53recoveryreadiness" - }, - "python": { - "module": "aws_cdk.aws_route53recoveryreadiness" - } - } - }, - "aws-cdk-lib.aws_route53resolver": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Route53Resolver" - }, - "java": { - "package": "software.amazon.awscdk.services.route53resolver" - }, - "python": { - "module": "aws_cdk.aws_route53resolver" - } - } - }, - "aws-cdk-lib.aws_rum": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.RUM" - }, - "java": { - "package": "software.amazon.awscdk.services.rum" - }, - "python": { - "module": "aws_cdk.aws_rum" - } - } - }, - "aws-cdk-lib.aws_s3": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3" - }, - "java": { - "package": "software.amazon.awscdk.services.s3" - }, - "python": { - "module": "aws_cdk.aws_s3" - } - } - }, - "aws-cdk-lib.aws_s3_assets": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3.Assets" - }, - "java": { - "package": "software.amazon.awscdk.services.s3.assets" - }, - "python": { - "module": "aws_cdk.aws_s3_assets" - } - } - }, - "aws-cdk-lib.aws_s3_deployment": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3.Deployment" - }, - "java": { - "package": "software.amazon.awscdk.services.s3.deployment" - }, - "python": { - "module": "aws_cdk.aws_s3_deployment" - } - } - }, - "aws-cdk-lib.aws_s3_notifications": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3.Notifications" - }, - "java": { - "package": "software.amazon.awscdk.services.s3.notifications" - }, - "python": { - "module": "aws_cdk.aws_s3_notifications" - } - } - }, - "aws-cdk-lib.aws_s3objectlambda": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3ObjectLambda" - }, - "java": { - "package": "software.amazon.awscdk.services.s3objectlambda" - }, - "python": { - "module": "aws_cdk.aws_s3objectlambda" - } - } - }, - "aws-cdk-lib.aws_s3outposts": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.S3Outposts" - }, - "java": { - "package": "software.amazon.awscdk.services.s3outposts" - }, - "python": { - "module": "aws_cdk.aws_s3outposts" - } - } - }, - "aws-cdk-lib.aws_sagemaker": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Sagemaker" - }, - "java": { - "package": "software.amazon.awscdk.services.sagemaker" - }, - "python": { - "module": "aws_cdk.aws_sagemaker" - } - } - }, - "aws-cdk-lib.aws_sam": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SAM" - }, - "java": { - "package": "software.amazon.awscdk.services.sam" - }, - "python": { - "module": "aws_cdk.aws_sam" - } - } - }, - "aws-cdk-lib.aws_scheduler": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Scheduler" - }, - "java": { - "package": "software.amazon.awscdk.services.scheduler" - }, - "python": { - "module": "aws_cdk.aws_scheduler" - } - } - }, - "aws-cdk-lib.aws_sdb": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SDB" - }, - "java": { - "package": "software.amazon.awscdk.services.sdb" - }, - "python": { - "module": "aws_cdk.aws_sdb" - } - } - }, - "aws-cdk-lib.aws_secretsmanager": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SecretsManager" - }, - "java": { - "package": "software.amazon.awscdk.services.secretsmanager" - }, - "python": { - "module": "aws_cdk.aws_secretsmanager" - } - } - }, - "aws-cdk-lib.aws_securityhub": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SecurityHub" - }, - "java": { - "package": "software.amazon.awscdk.services.securityhub" - }, - "python": { - "module": "aws_cdk.aws_securityhub" - } - } - }, - "aws-cdk-lib.aws_servicecatalog": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Servicecatalog" - }, - "java": { - "package": "software.amazon.awscdk.services.servicecatalog" - }, - "python": { - "module": "aws_cdk.aws_servicecatalog" - } - } - }, - "aws-cdk-lib.aws_servicecatalogappregistry": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Servicecatalogappregistry" - }, - "java": { - "package": "software.amazon.awscdk.services.servicecatalogappregistry" - }, - "python": { - "module": "aws_cdk.aws_servicecatalogappregistry" - } - } - }, - "aws-cdk-lib.aws_servicediscovery": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.ServiceDiscovery" - }, - "java": { - "package": "software.amazon.awscdk.services.servicediscovery" - }, - "python": { - "module": "aws_cdk.aws_servicediscovery" - } - } - }, - "aws-cdk-lib.aws_ses": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SES" - }, - "java": { - "package": "software.amazon.awscdk.services.ses" - }, - "python": { - "module": "aws_cdk.aws_ses" - } - } - }, - "aws-cdk-lib.aws_ses_actions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SES.Actions" - }, - "java": { - "package": "software.amazon.awscdk.services.ses.actions" - }, - "python": { - "module": "aws_cdk.aws_ses_actions" - } - } - }, - "aws-cdk-lib.aws_shield": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.Shield" - }, - "java": { - "package": "services.shield" - }, - "python": { - "module": "aws_cdk.aws_shield" - } - } - }, - "aws-cdk-lib.aws_signer": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Signer" - }, - "java": { - "package": "software.amazon.awscdk.services.signer" - }, - "python": { - "module": "aws_cdk.aws_signer" - } - } - }, - "aws-cdk-lib.aws_simspaceweaver": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SimSpaceWeaver" - }, - "java": { - "package": "software.amazon.awscdk.services.simspaceweaver" - }, - "python": { - "module": "aws_cdk.aws_simspaceweaver" - } - } - }, - "aws-cdk-lib.aws_sns": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SNS" - }, - "java": { - "package": "software.amazon.awscdk.services.sns" - }, - "python": { - "module": "aws_cdk.aws_sns" - } - } - }, - "aws-cdk-lib.aws_sns_subscriptions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SNS.Subscriptions" - }, - "java": { - "package": "software.amazon.awscdk.services.sns.subscriptions" - }, - "python": { - "module": "aws_cdk.aws_sns_subscriptions" - } - } - }, - "aws-cdk-lib.aws_sqs": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SQS" - }, - "java": { - "package": "software.amazon.awscdk.services.sqs" - }, - "python": { - "module": "aws_cdk.aws_sqs" - } - } - }, - "aws-cdk-lib.aws_ssm": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SSM" - }, - "java": { - "package": "software.amazon.awscdk.services.ssm" - }, - "python": { - "module": "aws_cdk.aws_ssm" - } - } - }, - "aws-cdk-lib.aws_ssmcontacts": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SSMContacts" - }, - "java": { - "package": "software.amazon.awscdk.services.ssmcontacts" - }, - "python": { - "module": "aws_cdk.aws_ssmcontacts" - } - } - }, - "aws-cdk-lib.aws_ssmincidents": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SSMIncidents" - }, - "java": { - "package": "software.amazon.awscdk.services.ssmincidents" - }, - "python": { - "module": "aws_cdk.aws_ssmincidents" - } - } - }, - "aws-cdk-lib.aws_sso": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SSO" - }, - "java": { - "package": "software.amazon.awscdk.services.sso" - }, - "python": { - "module": "aws_cdk.aws_sso" - } - } - }, - "aws-cdk-lib.aws_stepfunctions": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.StepFunctions" - }, - "java": { - "package": "software.amazon.awscdk.services.stepfunctions" - }, - "python": { - "module": "aws_cdk.aws_stepfunctions" - } - } - }, - "aws-cdk-lib.aws_stepfunctions_tasks": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.StepFunctions.Tasks" - }, - "java": { - "package": "software.amazon.awscdk.services.stepfunctions.tasks" - }, - "python": { - "module": "aws_cdk.aws_stepfunctions_tasks" - } - } - }, - "aws-cdk-lib.aws_supportapp": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SupportApp" - }, - "java": { - "package": "software.amazon.awscdk.services.supportapp" - }, - "python": { - "module": "aws_cdk.aws_supportapp" - } - } - }, - "aws-cdk-lib.aws_synthetics": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Synthetics" - }, - "java": { - "package": "software.amazon.awscdk.services.synthetics" - }, - "python": { - "module": "aws_cdk.aws_synthetics" - } - } - }, - "aws-cdk-lib.aws_systemsmanagersap": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.SystemsManagerSAP" - }, - "java": { - "package": "software.amazon.awscdk.services.systemsmanagersap" - }, - "python": { - "module": "aws_cdk.aws_systemsmanagersap" - } - } - }, - "aws-cdk-lib.aws_timestream": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Timestream" - }, - "java": { - "package": "software.amazon.awscdk.services.timestream" - }, - "python": { - "module": "aws_cdk.aws_timestream" - } - } - }, - "aws-cdk-lib.aws_transfer": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Transfer" - }, - "java": { - "package": "software.amazon.awscdk.services.transfer" - }, - "python": { - "module": "aws_cdk.aws_transfer" - } - } - }, - "aws-cdk-lib.aws_verifiedpermissions": { - "targets": { - "dotnet": { - "package": "Amazon.CDK.AWS.VerifiedPermissions" - }, - "java": { - "package": "services.verifiedpermissions" - }, - "python": { - "module": "aws_cdk.aws_verifiedpermissions" - } - } - }, - "aws-cdk-lib.aws_voiceid": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.VoiceID" - }, - "java": { - "package": "software.amazon.awscdk.services.voiceid" - }, - "python": { - "module": "aws_cdk.aws_voiceid" - } - } - }, - "aws-cdk-lib.aws_vpclattice": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.VpcLattice" - }, - "java": { - "package": "software.amazon.awscdk.services.vpclattice" - }, - "python": { - "module": "aws_cdk.aws_vpclattice" - } - } - }, - "aws-cdk-lib.aws_waf": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.WAF" - }, - "java": { - "package": "software.amazon.awscdk.services.waf" - }, - "python": { - "module": "aws_cdk.aws_waf" - } - } - }, - "aws-cdk-lib.aws_wafregional": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.WAFRegional" - }, - "java": { - "package": "software.amazon.awscdk.services.waf.regional" - }, - "python": { - "module": "aws_cdk.aws_wafregional" - } - } - }, - "aws-cdk-lib.aws_wafv2": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.WAFv2" - }, - "java": { - "package": "software.amazon.awscdk.services.wafv2" - }, - "python": { - "module": "aws_cdk.aws_wafv2" - } - } - }, - "aws-cdk-lib.aws_wisdom": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.Wisdom" - }, - "java": { - "package": "software.amazon.awscdk.services.wisdom" - }, - "python": { - "module": "aws_cdk.aws_wisdom" - } - } - }, - "aws-cdk-lib.aws_workspaces": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.WorkSpaces" - }, - "java": { - "package": "software.amazon.awscdk.services.workspaces" - }, - "python": { - "module": "aws_cdk.aws_workspaces" - } - } - }, - "aws-cdk-lib.aws_xray": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.AWS.XRay" - }, - "java": { - "package": "software.amazon.awscdk.services.xray" - }, - "python": { - "module": "aws_cdk.aws_xray" - } - } - }, - "aws-cdk-lib.cloud_assembly_schema": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.CloudAssembly.Schema" - }, - "java": { - "package": "software.amazon.awscdk.cloudassembly.schema" - }, - "python": { - "module": "aws_cdk.cloud_assembly_schema" - } - } - }, - "aws-cdk-lib.cloudformation_include": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.CloudFormation.Include" - }, - "java": { - "package": "software.amazon.awscdk.cloudformation.include" - }, - "python": { - "module": "aws_cdk.cloudformation_include" - } - } - }, - "aws-cdk-lib.custom_resources": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.CustomResources" - }, - "java": { - "package": "software.amazon.awscdk.customresources" - }, - "python": { - "module": "aws_cdk.custom_resources" - } - } - }, - "aws-cdk-lib.cx_api": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.CXAPI" - }, - "java": { - "package": "software.amazon.awscdk.cxapi" - }, - "python": { - "module": "aws_cdk.cx_api" - } - } - }, - "aws-cdk-lib.lambda_layer_awscli": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.LambdaLayer.AwsCli" - }, - "java": { - "package": "software.amazon.awscdk.lambdalayer.awscli" - }, - "python": { - "module": "aws_cdk.lambda_layer_awscli" - } - } - }, - "aws-cdk-lib.lambda_layer_kubectl": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.LambdaLayer.Kubectl" - }, - "java": { - "package": "software.amazon.awscdk.lambdalayer.kubectl" - }, - "python": { - "module": "aws_cdk.lambda_layer_kubectl" - } - } - }, - "aws-cdk-lib.lambda_layer_node_proxy_agent": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.LambdaLayer.NodeProxyAgent" - }, - "java": { - "package": "software.amazon.awscdk.lambda.layer.node.proxy.agent" - }, - "python": { - "module": "aws_cdk.lambda_layer_node_proxy_agent" - } - } - }, - "aws-cdk-lib.pipelines": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Pipelines" - }, - "java": { - "package": "software.amazon.awscdk.pipelines" - }, - "python": { - "module": "aws_cdk.pipelines" - } - } - }, - "aws-cdk-lib.region_info": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.RegionInfo" - }, - "java": { - "package": "software.amazon.awscdk.regioninfo" - }, - "python": { - "module": "aws_cdk.region_info" - } - } - }, - "aws-cdk-lib.triggers": { - "targets": { - "dotnet": { - "namespace": "Amazon.CDK.Triggers" - }, - "java": { - "package": "software.amazon.awscdk.triggers" - }, - "python": { - "module": "aws_cdk.triggers" - } - } - } - }, - "targets": { - "dotnet": { - "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png", - "namespace": "Amazon.CDK", - "packageId": "Amazon.CDK.Lib" - }, - "go": { - "moduleName": "github.com/aws/aws-cdk-go", - "packageName": "awscdk" - }, - "java": { - "maven": { - "artifactId": "aws-cdk-lib", - "groupId": "software.amazon.awscdk" - }, - "package": "software.amazon.awscdk" - }, - "js": { - "npm": "aws-cdk-lib" - }, - "python": { - "distName": "aws-cdk-lib", - "module": "aws_cdk" - } - } - }, - "constructs": { - "targets": { - "dotnet": { - "namespace": "Constructs", - "packageId": "Constructs" - }, - "go": { - "moduleName": "github.com/aws/constructs-go" - }, - "java": { - "maven": { - "artifactId": "constructs", - "groupId": "software.constructs" - }, - "package": "software.constructs" - }, - "js": { - "npm": "constructs" - }, - "python": { - "distName": "constructs", - "module": "constructs" - } - } - } - }, - "description": "The CDK Construct Library for AWS::Batch", - "docs": { - "stability": "experimental" - }, - "homepage": "https://github.com/aws/aws-cdk", - "jsiiVersion": "5.1.12 (build 0675712)", - "keywords": [ - "aws", - "cdk", - "constructs", - "batch" - ], - "license": "Apache-2.0", - "metadata": { - "jsii": { - "compiledWithDeprecationWarnings": true, - "pacmak": { - "hasDefaultInterfaces": true - }, - "rosetta": { - "strict": true - } - } - }, - "name": "@aws-cdk/aws-batch-alpha", - "readme": { - "markdown": "# AWS Batch Construct Library\n\n\n---\n\n![cdk-constructs: Developer Preview](https://img.shields.io/badge/cdk--constructs-developer--preview-informational.svg?style=for-the-badge)\n\n> The APIs of higher level constructs in this module are in **developer preview** before they\n> become stable. We will only make breaking changes to address unforeseen API issues. Therefore,\n> these APIs are not subject to [Semantic Versioning](https://semver.org/), and breaking changes\n> will be announced in release notes. This means that while you may use them, you may need to\n> update your source code when upgrading to a newer version of this package.\n\n---\n\n\n\nThis module is part of the [AWS Cloud Development Kit](https://github.com/aws/aws-cdk) project.\n\nAWS Batch is a batch processing tool for efficiently running hundreds of thousands computing jobs in AWS.\nBatch can dynamically provision [Amazon EC2](https://aws.amazon.com/ec2/) Instances to meet the resource requirements of submitted jobs\nand simplifies the planning, scheduling, and executions of your batch workloads. Batch achieves this through four different resources:\n\n* ComputeEnvironments: Contain the resources used to execute Jobs\n* JobDefinitions: Define a type of Job that can be submitted\n* JobQueues: Route waiting Jobs to ComputeEnvironments\n* SchedulingPolicies: Applied to Queues to control how and when Jobs exit the JobQueue and enter the ComputeEnvironment\n\n`ComputeEnvironment`s can be managed or unmanaged. Batch will automatically provision EC2 Instances in a managed `ComputeEnvironment` and will\nnot provision any Instances in an unmanaged `ComputeEnvironment`. Managed `ComputeEnvironment`s can use ECS, Fargate, or EKS resources to spin up\nEC2 Instances in (ensure your EKS Cluster has [been configured](https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html)\nto support a Batch ComputeEnvironment before linking it). You can use Launch Templates and Placement Groups to configure exactly how these resources\nwill be provisioned.\n\n`JobDefinition`s can use either ECS resources or EKS resources. ECS `JobDefinition`s can use multiple containers to execute distributed workloads.\nEKS `JobDefinition`s can only execute a single container. Submitted Jobs use `JobDefinition`s as templates.\n\n`JobQueue`s must link at least one `ComputeEnvironment`. Jobs exit the Queue in FIFO order unless a `SchedulingPolicy` is specified.\n\n`SchedulingPolicy`s tell the Scheduler how to choose which Jobs should be executed next by the ComputeEnvironment.\n\n## Use Cases & Examples\n\n### Cost Optimization\n\n#### Spot Instances\n\nSpot instances are significantly discounted EC2 instances that can be reclaimed at any time by AWS.\nWorkloads that are fault-tolerant or stateless can take advantage of spot pricing.\nTo use spot spot instances, set `spot` to `true` on a managed Ec2 or Fargate Compute Environment:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\nnew batch.FargateComputeEnvironment(this, 'myFargateComputeEnv', {\n vpc,\n spot: true,\n});\n```\n\nBatch allows you to specify the percentage of the on-demand instance that the current spot price\nmust be to provision the instance using the `spotBidPercentage`.\nThis defaults to 100%, which is the recommended value.\nThis value cannot be specified for `FargateComputeEnvironment`s\nand only applies to `ManagedEc2EcsComputeEnvironment`s.\nThe following code configures a Compute Environment to only use spot instances that\nare at most 20% the price of the on-demand instance price:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n spot: true,\n spotBidPercentage: 20,\n});\n```\n\nFor stateful or otherwise non-interruption-tolerant workflows, omit `spot` or set it to `false` to only provision on-demand instances.\n\n#### Choosing Your Instance Types\n\nBatch allows you to choose the instance types or classes that will run your workload.\nThis example configures your `ComputeEnvironment` to use only the `M5AD.large` instance:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\n\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE)],\n});\n```\n\nBatch allows you to specify only the instance class and to let it choose the size, which you can do like this:\n\n```ts\nconst vpc = new ec2.Vpc(this, 'VPC');\n\ndeclare const computeEnv: batch.IManagedEc2EcsComputeEnvironment\ncomputeEnv.addInstanceClass(ec2.InstanceClass.M5AD);\n// Or, specify it on the constructor:\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.R4],\n});\n```\n\nUnless you explicitly specify `useOptimalInstanceClasses: false`, this compute environment will use `'optimal'` instances,\nwhich tells Batch to pick an instance from the C4, M4, and R4 instance families.\n*Note*: Batch does not allow specifying instance types or classes with different architectures.\nFor example, `InstanceClass.A1` cannot be specified alongside `'optimal'`,\nbecause `A1` uses ARM and `'optimal'` uses x86_64.\nYou can specify both `'optimal'` alongside several different instance types in the same compute environment:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE)],\n useOptimalInstanceClasses: true, // default\n vpc,\n});\n// Note: this is equivalent to specifying\ncomputeEnv.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.M5AD, ec2.InstanceSize.LARGE));\ncomputeEnv.addInstanceClass(ec2.InstanceClass.C4);\ncomputeEnv.addInstanceClass(ec2.InstanceClass.M4);\ncomputeEnv.addInstanceClass(ec2.InstanceClass.R4);\n```\n\n#### Allocation Strategies\n\n| Allocation Strategy | Optimized for | Downsides |\n| ----------------------- | ------------- | ----------------------------- |\n| BEST_FIT | Cost | May limit throughput |\n| BEST_FIT_PROGRESSIVE | Throughput | May increase cost |\n| SPOT_CAPACITY_OPTIMIZED | Least interruption | Only useful on Spot instances |\n| SPOT_PRICE_CAPACITY_OPTIMIZED | Least interruption + Price | Only useful on Spot instances |\n\nBatch provides different Allocation Strategies to help it choose which instances to provision.\nIf your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment`\nand use `SPOT_PRICE_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled).\nThis will tell Batch to choose the instance types from the ones you’ve specified that have\nthe most spot capacity available to minimize the chance of interruption and have the lowest price.\nTo get the most benefit from your spot instances,\nyou should allow Batch to choose from as many different instance types as possible.\nIf you only care about minimal interruptions and not want Batch to optimize for cost, use\n`SPOT_CAPACITY_OPTIMIZED`. `SPOT_PRICE_CAPACITY_OPTIMIZED` is recommended over `SPOT_CAPACITY_OPTIMIZED`\nfor most use cases.\n\nIf your workflow does not tolerate interruptions and you want to minimize your costs at the expense\nof potentially longer waiting times, use `AllocationStrategy.BEST_FIT`.\nThis will choose the lowest-cost instance type that fits all the jobs in the queue.\nIf instances of that type are not available,\nthe queue will not choose a new type; instead, it will wait for the instance to become available.\nThis can stall your `Queue`, with your compute environment only using part of its max capacity\n(or none at all) until the `BEST_FIT` instance becomes available.\n\nIf you are running a workflow that does not tolerate interruptions and you want to maximize throughput,\nyou can use `AllocationStrategy.BEST_FIT_PROGRESSIVE`.\nThis is the default Allocation Strategy if `spot` is `false` or unspecified.\nThis strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\nof the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\nHowever, if not all of the capacity can be filled with this instance type,\nit will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\nTo make the most use of this allocation strategy,\nit is recommended to use as many instance classes as is feasible for your workload.\nThis example shows a `ComputeEnvironment` that uses `BEST_FIT_PROGRESSIVE`\nwith `'optimal'` and `InstanceClass.M5` instance types:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.M5],\n});\n```\n\nThis example shows a `ComputeEnvironment` that uses `BEST_FIT` with `'optimal'` instances:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nconst computeEnv = new batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n allocationStrategy: batch.AllocationStrategy.BEST_FIT,\n});\n```\n\n*Note*: `allocationStrategy` cannot be specified on Fargate Compute Environments.\n\n### Controlling vCPU allocation\n\nYou can specify the maximum and minimum vCPUs a managed `ComputeEnvironment` can have at any given time.\nBatch will *always* maintain `minvCpus` worth of instances in your ComputeEnvironment, even if it is not executing any jobs,\nand even if it is disabled. Batch will scale the instances up to `maxvCpus` worth of instances as\njobs exit the JobQueue and enter the ComputeEnvironment. If you use `AllocationStrategy.BEST_FIT_PROGRESSIVE`,\n`AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED`, or `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`,\nbatch may exceed `maxvCpus`; it will never exceed `maxvCpus` by more than a single instance type. This example configures a\n`minvCpus` of 10 and a `maxvCpus` of 100:\n\n```ts\ndeclare const vpc: ec2.IVpc;\n\nnew batch.ManagedEc2EcsComputeEnvironment(this, 'myEc2ComputeEnv', {\n vpc,\n instanceClasses: [ec2.InstanceClass.R4],\n minvCpus: 10,\n maxvCpus: 100,\n});\n```\n\n### Tagging Instances\n\nYou can tag any instances launched by your managed EC2 ComputeEnvironments by using the CDK `Tags` API:\n\n```ts\nimport { Tags } from 'aws-cdk-lib';\n\ndeclare const vpc: ec2.IVpc;\n\nconst tagCE = new batch.ManagedEc2EcsComputeEnvironment(this, 'CEThatMakesTaggedInstnaces', {\n vpc,\n});\n\nTags.of(tagCE).add('super', 'salamander');\n```\n\nUnmanaged `ComputeEnvironment`s do not support `maxvCpus` or `minvCpus` because you must provision and manage the instances yourself;\nthat is, Batch will not scale them up and down as needed.\n\n### Sharing a ComputeEnvironment between multiple JobQueues\n\nMultiple `JobQueue`s can share the same `ComputeEnvironment`.\nIf multiple Queues are attempting to submit Jobs to the same `ComputeEnvironment`,\nBatch will pick the Job from the Queue with the highest priority.\nThis example creates two `JobQueue`s that share a `ComputeEnvironment`:\n\n```ts\ndeclare const vpc: ec2.IVpc;\nconst sharedComputeEnv = new batch.FargateComputeEnvironment(this, 'spotEnv', {\n vpc,\n spot: true,\n});\nconst lowPriorityQueue = new batch.JobQueue(this, 'JobQueue', {\n priority: 1,\n});\nconst highPriorityQueue = new batch.JobQueue(this, 'JobQueue', {\n priority: 10,\n});\nlowPriorityQueue.addComputeEnvironment(sharedComputeEnv, 1);\nhighPriorityQueue.addComputeEnvironment(sharedComputeEnv, 1);\n```\n\n### Fairshare Scheduling\n\nBatch `JobQueue`s execute Jobs submitted to them in FIFO order unless you specify a `SchedulingPolicy`.\nFIFO queuing can cause short-running jobs to be starved while long-running jobs fill the compute environment.\nTo solve this, Jobs can be associated with a share.\n\nShares consist of a `shareIdentifier` and a `weightFactor`, which is inversely correlated with the vCPU allocated to that share identifier.\nWhen submitting a Job, you can specify its `shareIdentifier` to associate that particular job with that share.\nLet's see how the scheduler uses this information to schedule jobs.\n\nFor example, if there are two shares defined as follows:\n\n| Share Identifier | Weight Factor |\n| ---------------- | ------------- |\n| A | 1 |\n| B | 1 |\n\nThe weight factors share the following relationship:\n\n```math\nA_{vCpus} / A_{Weight} = B_{vCpus} / B_{Weight}\n```\n\nwhere `BvCpus` is the number of vCPUs allocated to jobs with share identifier `'B'`, and `B_weight` is the weight factor of `B`.\n\nThe total number of vCpus allocated to a share is equal to the amount of jobs in that share times the number of vCpus necessary for every job.\nLet's say that each A job needs 32 VCpus (`A_requirement` = 32) and each B job needs 64 vCpus (`B_requirement` = 64):\n\n```math\nA_{vCpus} = A_{Jobs} * A_{Requirement}\n```\n\n```math\nB_{vCpus} = B_{Jobs} * B_{Requirement}\n```\n\nWe have:\n\n```math\nA_{vCpus} / A_{Weight} = B_{vCpus} / B_{Weight}\n```\n\n```math\nA_{Jobs} * A_{Requirement} / A_{Weight} = B_{Jobs} * B_{Requirement} / B_{Weight}\n```\n\n```math\nA_{Jobs} * 32 / 1 = B_{Jobs} * 64 / 1\n```\n\n```math\nA_{Jobs} * 32 = B_{Jobs} * 64\n```\n\n```math\nA_{Jobs} = B_{Jobs} * 2\n```\n\nThus the scheduler will schedule two `'A'` jobs for each `'B'` job.\n\nYou can control the weight factors to change these ratios, but note that\nweight factors are inversely correlated with the vCpus allocated to the corresponding share.\n\nThis example would be configured like this:\n\n```ts\nconst fairsharePolicy = new batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy');\n\nfairsharePolicy.addShare({\n shareIdentifier: 'A',\n weightFactor: 1,\n});\nfairsharePolicy.addShare({\n shareIdentifier: 'B',\n weightFactor: 1,\n});\nnew batch.JobQueue(this, 'JobQueue', {\n schedulingPolicy: fairsharePolicy,\n});\n```\n\n*Note*: The scheduler will only consider the current usage of the compute environment unless you specify `shareDecay`.\nFor example, a `shareDecay` of 5 minutes in the above example means that at any given point in time, twice as many `'A'` jobs\nwill be scheduled for each `'B'` job, but only for the past 5 minutes. If `'B'` jobs run longer than 5 minutes, then\nthe scheduler is allowed to put more than two `'A'` jobs for each `'B'` job, because the usage of those long-running\n`'B'` jobs will no longer be considered after 5 minutes. `shareDecay` linearly decreases the usage of\nlong running jobs for calculation purposes. For example if share decay is 60 seconds,\nthen jobs that run for 30 seconds have their usage considered to be only 50% of what it actually is,\nbut after a whole minute the scheduler pretends they don't exist for fairness calculations.\n\nThe following code specifies a `shareDecay` of 5 minutes:\n\n```ts\nimport * as cdk from 'aws-cdk-lib'\nconst fairsharePolicy = new batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy', {\n shareDecay: cdk.Duration.minutes(5),\n});\n```\n\nIf you have high priority jobs that should always be executed as soon as they arrive,\nyou can define a `computeReservation` to specify the percentage of the\nmaximum vCPU capacity that should be reserved for shares that are *not in the queue*.\nThe actual reserved percentage is defined by Batch as:\n\n```math\n (\\frac{computeReservation}{100}) ^ {ActiveFairShares}\n```\n\nwhere `ActiveFairShares` is the number of shares for which there exists\nat least one job in the queue with a unique share identifier.\n\nThis is best illustrated with an example.\nSuppose there are three shares with share identifiers `A`, `B` and `C` respectively\nand we specify the `computeReservation` to be 75%. The queue is currently empty,\nand no other shares exist.\n\nThere are no active fair shares, since the queue is empty.\nThus (75/100)^0 = 1 = 100% of the maximum vCpus are reserved for all shares.\n\nA job with identifier `A` enters the queue.\n\nThe number of active fair shares is now 1, hence\n(75/100)^1 = .75 = 75% of the maximum vCpus are reserved for all shares that do not have the identifier `A`;\nfor this example, this is `B` and `C`,\n(but if jobs are submitted with a share identifier not covered by this fairshare policy, those would be considered just as `B` and `C` are).\n\nNow a `B` job enters the queue. The number of active fair shares is now 2,\nso (75/100)^2 = .5625 = 56.25% of the maximum vCpus are reserved for all shares that do not have the identifier `A` or `B`.\n\nNow a second `A` job enters the queue. The number of active fair shares is still 2,\nso the percentage reserved is still 56.25%\n\nNow a `C` job enters the queue. The number of active fair shares is now 3,\nso (75/100)^3 = .421875 = 42.1875% of the maximum vCpus are reserved for all shares that do not have the identifier `A`, `B`, or `C`.\n\nIf there are no other shares that your jobs can specify, this means that 42.1875% of your capacity will never be used!\n\nNow, `A`, `B`, and `C` can only consume 100% - 42.1875% = 57.8125% of the maximum vCpus.\nNote that the this percentage is **not** split between `A`, `B`, and `C`.\nInstead, the scheduler will use their `weightFactor`s to decide which jobs to schedule;\nthe only difference is that instead of competing for 100% of the max capacity, jobs compete for 57.8125% of the max capacity.\n\nThis example specifies a `computeReservation` of 75% that will behave as explained in the example above:\n\n```ts\nnew batch.FairshareSchedulingPolicy(this, 'myFairsharePolicy', {\n computeReservation: 75,\n shares: [\n { weightFactor: 1, shareIdentifier: 'A' },\n { weightFactor: 0.5, shareIdentifier: 'B' },\n { weightFactor: 2, shareIdentifier: 'C' },\n ],\n});\n```\n\nYou can specify a `priority` on your `JobDefinition`s to tell the scheduler to prioritize certain jobs that share the same share identifier.\n\n### Configuring Job Retry Policies\n\nCertain workflows may result in Jobs failing due to intermittent issues.\nJobs can specify retry policies to respond to different failures with different actions.\nThere are three different ways information about the way a Job exited can be conveyed;\n\n* `exitCode`: the exit code returned from the process executed by the container. Will only match non-zero exit codes.\n* `reason`: any middleware errors, like your Docker registry being down.\n* `statusReason`: infrastructure errors, most commonly your spot instance being reclaimed.\n\nFor most use cases, only one of these will be associated with a particular action at a time.\nTo specify common `exitCode`s, `reason`s, or `statusReason`s, use the corresponding value from\nthe `Reason` class. This example shows some common failure reasons:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n }),\n retryAttempts: 5,\n retryStrategies: [\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n ],\n});\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.SPOT_INSTANCE_RECLAIMED),\n);\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n);\njobDefn.addRetryStrategy(\n batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.custom({\n onExitCode: '40*',\n onReason: 'some reason',\n })),\n);\n```\n\nWhen specifying a custom reason,\nyou can specify a glob string to match each of these and react to different failures accordingly.\nUp to five different retry strategies can be configured for each Job,\nand each strategy can match against some or all of `exitCode`, `reason`, and `statusReason`.\nYou can optionally configure the number of times a job will be retried,\nbut you cannot configure different retry counts for different strategies; they all share the same count.\nIf multiple conditions are specified in a given retry strategy,\nthey must all match for the action to be taken; the conditions are ANDed together, not ORed.\n\n### Running single-container ECS workflows\n\nBatch can run jobs on ECS or EKS. ECS jobs can be defined as single container or multinode.\nThis example creates a `JobDefinition` that runs a single container with ECS:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as efs from 'aws-cdk-lib/aws-efs';\n\ndeclare const myFileSystem: efs.IFileSystem;\ndeclare const myJobRole: iam.Role;\nmyFileSystem.grantRead(myJobRole);\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n volumes: [batch.EcsVolume.efs({\n name: 'myVolume',\n fileSystem: myFileSystem,\n containerPath: '/Volumes/myVolume',\n useJobRole: true,\n })],\n jobRole: myJobRole,\n }),\n});\n```\n\nFor workflows that need persistent storage, batch supports mounting `Volume`s to the container.\nYou can both provision the volume and mount it to the container in a single operation:\n\n```ts\nimport * as efs from 'aws-cdk-lib/aws-efs';\n\ndeclare const myFileSystem: efs.IFileSystem;\ndeclare const jobDefn: batch.EcsJobDefinition;\n\njobDefn.container.addVolume(batch.EcsVolume.efs({\n name: 'myVolume',\n fileSystem: myFileSystem,\n containerPath: '/Volumes/myVolume',\n}));\n```\n\n### Secrets\n\nYou can expose SecretsManager Secret ARNs or SSM Parameters to your container as environment variables.\nThe following example defines the `MY_SECRET_ENV_VAR` environment variable that contains the\nARN of the Secret defined by `mySecret`:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\n\ndeclare const mySecret: secretsmanager.ISecret;\n\nconst jobDefn = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n secrets: {\n MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(mySecret),\n }\n }),\n});\n```\n\n### Running Kubernetes Workflows\n\nBatch also supports running workflows on EKS. The following example creates a `JobDefinition` that runs on EKS:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nconst jobDefn = new batch.EksJobDefinition(this, 'eksf2', {\n container: new batch.EksContainerDefinition(this, 'container', {\n image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n volumes: [batch.EksVolume.emptyDir({\n name: 'myEmptyDirVolume',\n mountPath: '/mount/path',\n medium: batch.EmptyDirMediumType.MEMORY,\n readonly: true,\n sizeLimit: cdk.Size.mebibytes(2048),\n })],\n }),\n});\n```\n\nYou can mount `Volume`s to these containers in a single operation:\n\n```ts\ndeclare const jobDefn: batch.EksJobDefinition;\njobDefn.container.addVolume(batch.EksVolume.emptyDir({\n name: 'emptyDir',\n mountPath: '/Volumes/emptyDir',\n}));\njobDefn.container.addVolume(batch.EksVolume.hostPath({\n name: 'hostPath',\n hostPath: '/sys',\n mountPath: '/Volumes/hostPath',\n}));\njobDefn.container.addVolume(batch.EksVolume.secret({\n name: 'secret',\n optional: true,\n mountPath: '/Volumes/secret',\n secretName: 'mySecret',\n}));\n```\n\n### Running Distributed Workflows\n\nSome workflows benefit from parallellization and are most powerful when run in a distributed environment,\nsuch as certain numerical calculations or simulations. Batch offers `MultiNodeJobDefinition`s,\nwhich allow a single job to run on multiple instances in parallel, for this purpose.\nMessage Passing Interface (MPI) is often used with these workflows.\nYou must configure your containers to use MPI properly,\nbut Batch allows different nodes running different containers to communicate easily with one another.\nYou must configure your containers to use certain environment variables that Batch will provide them,\nwhich lets them know which one is the main node, among other information.\nFor an in-depth example on using MPI to perform numerical computations on Batch,\nsee this [blog post](https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/)\nIn particular, the environment variable that tells the containers which one is the main node can be configured on your `MultiNodeJobDefinition` as follows:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nconst multiNodeJob = new batch.MultiNodeJobDefinition(this, 'JobDefinition', {\n instanceType: ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE),\n containers: [{\n container: new batch.EcsEc2ContainerDefinition(this, 'mainMPIContainer', {\n image: ecs.ContainerImage.fromRegistry('yourregsitry.com/yourMPIImage:latest'),\n cpu: 256,\n memory: cdk.Size.mebibytes(2048),\n }),\n startNode: 0,\n endNode: 5,\n }],\n});\n// convenience method\nmultiNodeJob.addContainer({\n startNode: 6,\n endNode: 10,\n container: new batch.EcsEc2ContainerDefinition(this, 'multiContainer', {\n image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n cpu: 256,\n memory: cdk.Size.mebibytes(2048),\n }),\n});\n```\n\nIf you need to set the control node to an index other than 0, specify it in directly:\n\n```ts\nconst multiNodeJob = new batch.MultiNodeJobDefinition(this, 'JobDefinition', {\n mainNode: 5,\n instanceType: ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE),\n});\n```\n\n### Pass Parameters to a Job\n\nBatch allows you define parameters in your `JobDefinition`, which can be referenced in the container command. For example:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nnew batch.EcsJobDefinition(this, 'JobDefn', {\n parameters: { echoParam: 'foobar' },\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n command: [\n 'echo',\n 'Ref::echoParam',\n ],\n }),\n});\n```\n\n### Understanding Progressive Allocation Strategies\n\nAWS Batch uses an [allocation strategy](https://docs.aws.amazon.com/batch/latest/userguide/allocation-strategies.html) to determine what compute resource will efficiently handle incoming job requests. By default, **BEST_FIT** will pick an available compute instance based on vCPU requirements. If none exist, the job will wait until resources become available. However, with this strategy, you may have jobs waiting in the queue unnecessarily despite having more powerful instances available. Below is an example of how that situation might look like:\n\n```plaintext\nCompute Environment:\n\n1. m5.xlarge => 4 vCPU\n2. m5.2xlarge => 8 vCPU\n```\n\n```plaintext\nJob Queue:\n---------\n| A | B |\n---------\n\nJob Requirements:\nA => 4 vCPU - ALLOCATED TO m5.xlarge\nB => 2 vCPU - WAITING\n```\n\nIn this situation, Batch will allocate **Job A** to compute resource #1 because it is the most cost efficient resource that matches the vCPU requirement. However, with this `BEST_FIT` strategy, **Job B** will not be allocated to our other available compute resource even though it is strong enough to handle it. Instead, it will wait until the first job is finished processing or wait a similar `m5.xlarge` resource to be provisioned.\n\nThe alternative would be to use the `BEST_FIT_PROGRESSIVE` strategy in order for the remaining job to be handled in larger containers regardless of vCPU requirement and costs.\n\n### Permissions\n\nYou can grant any Principal the `batch:submitJob` permission on both a job definition and a job queue like this:\n\n```ts\nimport * as cdk from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\ndeclare const vpc: ec2.IVpc;\n\nconst ecsJob = new batch.EcsJobDefinition(this, 'JobDefn', {\n container: new batch.EcsEc2ContainerDefinition(this, 'containerDefn', {\n image: ecs.ContainerImage.fromRegistry('public.ecr.aws/amazonlinux/amazonlinux:latest'),\n memory: cdk.Size.mebibytes(2048),\n cpu: 256,\n }),\n});\n\nconst queue = new batch.JobQueue(this, 'JobQueue', {\n computeEnvironments: [{\n computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(this, 'managedEc2CE', {\n vpc,\n }),\n order: 1,\n }],\n priority: 10,\n});\n\nconst user = new iam.User(this, 'MyUser');\necsJob.grantSubmitJob(user, queue);\n```\n" - }, - "repository": { - "directory": "packages/@aws-cdk/aws-batch-alpha", - "type": "git", - "url": "https://github.com/aws/aws-cdk.git" - }, - "schema": "jsii/0.10.0", - "targets": { - "dotnet": { - "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/main/logo/default-256-dark.png", - "namespace": "Amazon.CDK.AWS.Batch.Alpha", - "packageId": "Amazon.CDK.AWS.Batch.Alpha" - }, - "go": { - "moduleName": "github.com/aws/aws-cdk-go", - "packageName": "awscdkbatchalpha" - }, - "java": { - "maven": { - "artifactId": "batch-alpha", - "groupId": "software.amazon.awscdk" - }, - "package": "software.amazon.awscdk.services.batch.alpha" - }, - "js": { - "npm": "@aws-cdk/aws-batch-alpha" - }, - "python": { - "classifiers": [ - "Framework :: AWS CDK", - "Framework :: AWS CDK :: 2" - ], - "distName": "aws-cdk.aws-batch-alpha", - "module": "aws_cdk.aws_batch_alpha" - } - }, - "types": { - "@aws-cdk/aws-batch-alpha.Action": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "The Action to take when all specified conditions in a RetryStrategy are met." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Action", - "kind": "enum", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 159 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "The job will not retry." - }, - "name": "EXIT" - }, - { - "docs": { - "remarks": "It can be retried up to the number of times specified in `retryAttempts`.", - "stability": "experimental", - "summary": "The job will retry." - }, - "name": "RETRY" - } - ], - "name": "Action", - "symbolId": "lib/job-definition-base:Action" - }, - "@aws-cdk/aws-batch-alpha.AllocationStrategy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "see": "https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/", - "stability": "experimental", - "summary": "Determines how this compute environment chooses instances to spawn." - }, - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy", - "kind": "enum", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 423 - }, - "members": [ - { - "docs": { - "remarks": "If instances of that type are not available, the queue will not choose a new type;\ninstead, it will wait for the instance to become available.\nThis can stall your `Queue`, with your compute environment only using part of its max capacity\n(or none at all) until the `BEST_FIT` instance becomes available.\nThis allocation strategy keeps costs lower but can limit scaling.\n`BEST_FIT` isn't supported when updating compute environments", - "stability": "experimental", - "summary": "Batch chooses the lowest-cost instance type that fits all the jobs in the queue." - }, - "name": "BEST_FIT" - }, - { - "docs": { - "remarks": "This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\nof the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\nHowever, if not all of the capacity can be filled with this instance type,\nit will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\nTo make the most use of this allocation strategy,\nit is recommended to use as many instance classes as is feasible for your workload.", - "stability": "experimental", - "summary": "This is the default Allocation Strategy if `spot` is `false` or unspecified." - }, - "name": "BEST_FIT_PROGRESSIVE" - }, - { - "docs": { - "remarks": "This will tell Batch to choose the instance types from the ones you’ve specified that have\nthe most spot capacity available to minimize the chance of interruption.\nTo get the most benefit from your spot instances,\nyou should allow Batch to choose from as many different instance types as possible.", - "stability": "experimental", - "summary": "If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled)." - }, - "name": "SPOT_CAPACITY_OPTIMIZED" - }, - { - "docs": { - "remarks": "The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances.", - "stability": "experimental", - "summary": "The price and capacity optimized allocation strategy looks at both price and capacity to select the Spot Instance pools that are the least likely to be interrupted and have the lowest possible price." - }, - "name": "SPOT_PRICE_CAPACITY_OPTIMIZED" - } - ], - "name": "AllocationStrategy", - "symbolId": "lib/managed-compute-environment:AllocationStrategy" - }, - "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props common to all ComputeEnvironments." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 50 - }, - "name": "ComputeEnvironmentProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- generated by CloudFormation", - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 56 - }, - "name": "computeEnvironmentName", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 81 - }, - "name": "enabled", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- a serviceRole will be created for managed CEs, none for unmanaged CEs", - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 64 - }, - "name": "serviceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - } - ], - "symbolId": "lib/compute-environment-base:ComputeEnvironmentProps" - }, - "@aws-cdk/aws-batch-alpha.CustomReason": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "The corresponding Action will only be taken if *all* of the conditions specified here are met." - }, - "fqn": "@aws-cdk/aws-batch-alpha.CustomReason", - "kind": "interface", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 173 - }, - "name": "CustomReason", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- will not match on the exit code", - "remarks": "For example, `'40*'` will match 400, 404, 40123456789012", - "stability": "experimental", - "summary": "A glob string that will match on the job exit code." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 179 - }, - "name": "onExitCode", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- will not match on the reason", - "stability": "experimental", - "summary": "A glob string that will match on the reason returned by the exiting job For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 195 - }, - "name": "onReason", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- will not match on the status reason", - "remarks": "For example, `'Host EC2*'` indicates that the spot instance has been reclaimed.", - "stability": "experimental", - "summary": "A glob string that will match on the statusReason returned by the exiting job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 187 - }, - "name": "onStatusReason", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/job-definition-base:CustomReason" - }, - "@aws-cdk/aws-batch-alpha.Device": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "A container instance host device." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Device", - "kind": "interface", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 143 - }, - "name": "Device", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The path for the device on the host container instance." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 154 - }, - "name": "hostPath", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "Same path as the host", - "stability": "experimental", - "summary": "The path inside the container at which to expose the host device." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 149 - }, - "name": "containerPath", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "Readonly", - "remarks": "By default, the container has permissions for read, write, and mknod for the device.", - "stability": "experimental", - "summary": "The explicit permissions to provide to the container for the device." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 162 - }, - "name": "permissions", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.DevicePermission" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/linux-parameters:Device" - }, - "@aws-cdk/aws-batch-alpha.DevicePermission": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Permissions for device access." - }, - "fqn": "@aws-cdk/aws-batch-alpha.DevicePermission", - "kind": "enum", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 191 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "Read." - }, - "name": "READ" - }, - { - "docs": { - "stability": "experimental", - "summary": "Write." - }, - "name": "WRITE" - }, - { - "docs": { - "stability": "experimental", - "summary": "Make a node." - }, - "name": "MKNOD" - } - ], - "name": "DevicePermission", - "symbolId": "lib/linux-parameters:DevicePermission" - }, - "@aws-cdk/aws-batch-alpha.DnsPolicy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", - "stability": "experimental", - "summary": "The DNS Policy for the pod used by the Job Definition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy", - "kind": "enum", - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 100 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "The Pod inherits the name resolution configuration from the node that the Pods run on." - }, - "name": "DEFAULT" - }, - { - "docs": { - "stability": "experimental", - "summary": "Any DNS query that does not match the configured cluster domain suffix, such as `\"www.kubernetes.io\"`, is forwarded to an upstream nameserver by the DNS server. Cluster administrators may have extra stub-domain and upstream DNS servers configured." - }, - "name": "CLUSTER_FIRST" - }, - { - "docs": { - "remarks": "Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy.", - "stability": "experimental", - "summary": "For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`." - }, - "name": "CLUSTER_FIRST_WITH_HOST_NET" - } - ], - "name": "DnsPolicy", - "symbolId": "lib/eks-job-definition:DnsPolicy" - }, - "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure an EcsContainerDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 472 - }, - "name": "EcsContainerDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", - "stability": "experimental", - "summary": "The number of vCPUs reserved for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 483 - }, - "name": "cpu", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 476 - }, - "name": "image", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "abstract": true, - "docs": { - "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", - "stability": "experimental", - "summary": "The memory hard limit present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 490 - }, - "name": "memory", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "- no command", - "see": "https://docs.docker.com/engine/reference/builder/#cmd", - "stability": "experimental", - "summary": "The command that's passed to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 499 - }, - "name": "command", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no environment variables", - "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", - "stability": "experimental", - "summary": "The environment variables to pass to a container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 508 - }, - "name": "environment", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- a Role will be created", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html", - "stability": "experimental", - "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 517 - }, - "name": "executionRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "- no job role", - "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html", - "stability": "experimental", - "summary": "The role that the container can assume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 526 - }, - "name": "jobRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "stability": "experimental", - "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 533 - }, - "name": "linuxParameters", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" - } - }, - { - "abstract": true, - "docs": { - "default": "- the log configuration of the Docker daemon", - "stability": "experimental", - "summary": "The loging configuration for this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 540 - }, - "name": "logging", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ecs.LogDriver" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Gives the container readonly access to its root filesystem." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 547 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- no secrets", - "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html", - "stability": "experimental", - "summary": "A map from environment variable names to the secrets for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 557 - }, - "name": "secrets", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no user", - "stability": "experimental", - "summary": "The user name to use inside the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 564 - }, - "name": "user", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- no volumes", - "remarks": "Automatically added to the job definition.", - "stability": "experimental", - "summary": "The volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 571 - }, - "name": "volumes", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsContainerDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "constructs.Construct", - "docs": { - "stability": "experimental", - "summary": "A container orchestrated by ECS that uses EC2 resources." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 900 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 895 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Add a ulimit to this container." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 934 - }, - "name": "addUlimit", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "parameters": [ - { - "name": "ulimit", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" - } - } - ] - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a Volume to this container." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 706 - }, - "name": "addVolume", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "parameters": [ - { - "name": "volume", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - } - } - ] - } - ], - "name": "EcsEc2ContainerDefinition", - "properties": [ - { - "docs": { - "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", - "stability": "experimental", - "summary": "The number of vCPUs reserved for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 579 - }, - "name": "cpu", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 583 - }, - "name": "executionRole", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 578 - }, - "name": "image", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "docs": { - "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", - "stability": "experimental", - "summary": "The memory hard limit present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 580 - }, - "name": "memory", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Limits to set for the user this docker container will run as." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 897 - }, - "name": "ulimits", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "Automatically added to the job definition.", - "stability": "experimental", - "summary": "The volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 590 - }, - "name": "volumes", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The command that's passed to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 581 - }, - "name": "command", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", - "stability": "experimental", - "summary": "The environment variables to pass to a container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 582 - }, - "name": "environment", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "docs": { - "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", - "stability": "experimental", - "summary": "The number of physical GPUs to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 898 - }, - "name": "gpu", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role that the container can assume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 584 - }, - "name": "jobRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 585 - }, - "name": "linuxParameters", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The configuration of the log driver." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 586 - }, - "name": "logDriverConfig", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 896 - }, - "name": "privileged", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Gives the container readonly access to its root filesystem." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 587 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", - "stability": "experimental", - "summary": "A map from environment variable names to the secrets for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 588 - }, - "name": "secrets", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - }, - "kind": "map" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The user name to use inside the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 589 - }, - "name": "user", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsEc2ContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure an EcsEc2ContainerDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinitionProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 867 - }, - "name": "EcsEc2ContainerDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- no gpus", - "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", - "stability": "experimental", - "summary": "The number of physical GPUs to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 889 - }, - "name": "gpu", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 873 - }, - "name": "privileged", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- no ulimits", - "stability": "experimental", - "summary": "Limits to set for the user this docker container will run as." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 880 - }, - "name": "ulimits", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsEc2ContainerDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "constructs.Construct", - "docs": { - "stability": "experimental", - "summary": "A container orchestrated by ECS that uses Fargate resources." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1022 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", - "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1017 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Add a Volume to this container." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 706 - }, - "name": "addVolume", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "parameters": [ - { - "name": "volume", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - } - } - ] - } - ], - "name": "EcsFargateContainerDefinition", - "properties": [ - { - "docs": { - "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", - "stability": "experimental", - "summary": "The number of vCPUs reserved for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 579 - }, - "name": "cpu", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 583 - }, - "name": "executionRole", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 578 - }, - "name": "image", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "docs": { - "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", - "stability": "experimental", - "summary": "The memory hard limit present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 580 - }, - "name": "memory", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "remarks": "Automatically added to the job definition.", - "stability": "experimental", - "summary": "The volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 590 - }, - "name": "volumes", - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", - "stability": "experimental", - "summary": "Indicates whether the job has a public IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1019 - }, - "name": "assignPublicIp", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The command that's passed to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 581 - }, - "name": "command", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", - "stability": "experimental", - "summary": "The environment variables to pass to a container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 582 - }, - "name": "environment", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The size for ephemeral storage." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1020 - }, - "name": "ephemeralStorageSize", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Which version of Fargate to use when running this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1018 - }, - "name": "fargatePlatformVersion", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role that the container can assume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 584 - }, - "name": "jobRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 585 - }, - "name": "linuxParameters", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The configuration of the log driver." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 586 - }, - "name": "logDriverConfig", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Gives the container readonly access to its root filesystem." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 587 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", - "stability": "experimental", - "summary": "A map from environment variable names to the secrets for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 588 - }, - "name": "secrets", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - }, - "kind": "map" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The user name to use inside the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 589 - }, - "name": "user", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsFargateContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure an EcsFargateContainerDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinitionProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EcsContainerDefinitionProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 987 - }, - "name": "EcsFargateContainerDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", - "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html", - "stability": "experimental", - "summary": "Indicates whether the job has a public IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 997 - }, - "name": "assignPublicIp", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- 20 GiB", - "stability": "experimental", - "summary": "The size for ephemeral storage." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1011 - }, - "name": "ephemeralStorageSize", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "LATEST", - "stability": "experimental", - "summary": "Which version of Fargate to use when running this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 1004 - }, - "name": "fargatePlatformVersion", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsFargateContainerDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EcsJobDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::JobDefinition" - }, - "stability": "experimental", - "summary": "A JobDefinition that uses ECS orchestration." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 84 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IJobDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 58 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Import a JobDefinition by its arn." - }, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 62 - }, - "name": "fromJobDefinitionArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "jobDefinitionArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a RetryStrategy to this JobDefinition." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 259 - }, - "name": "addRetryStrategy", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "parameters": [ - { - "name": "strategy", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - } - } - ] - }, - { - "docs": { - "stability": "experimental", - "summary": "Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue`." - }, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 110 - }, - "name": "grantSubmitJob", - "parameters": [ - { - "name": "identity", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IGrantable" - } - }, - { - "name": "queue", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue" - } - } - ] - } - ], - "name": "EcsJobDefinition", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The container that this job will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 78 - }, - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 81 - }, - "name": "jobDefinitionArn", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 82 - }, - "name": "jobDefinitionName", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Defines the retry behavior for this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 243 - }, - "name": "retryStrategies", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 241 - }, - "name": "parameters", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "any" - }, - "kind": "map" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 79 - }, - "name": "propagateTags", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "The job is retried on failure the same number of attempts as the value.", - "stability": "experimental", - "summary": "The number of times to retry a job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 242 - }, - "name": "retryAttempts", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", - "stability": "experimental", - "summary": "The priority of this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 244 - }, - "name": "schedulingPriority", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", - "stability": "experimental", - "summary": "The timeout time for jobs that are submitted with this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 245 - }, - "name": "timeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/ecs-job-definition:EcsJobDefinition" - }, - "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for EcsJobDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsJobDefinitionProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.JobDefinitionProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 38 - }, - "name": "EcsJobDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The container that this job will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 42 - }, - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-job-definition.ts", - "line": 50 - }, - "name": "propagateTags", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-job-definition:EcsJobDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EcsMachineImage": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "A Batch MachineImage that is compatible with ECS." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage", - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 367 - }, - "name": "EcsMachineImage", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- chosen by batch", - "stability": "experimental", - "summary": "The machine image to use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 361 - }, - "name": "image", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IMachineImage" - } - }, - { - "abstract": true, - "docs": { - "default": "- 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances", - "stability": "experimental", - "summary": "Tells Batch which instance type to launch this image on." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 373 - }, - "name": "imageType", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImageType" - } - } - ], - "symbolId": "lib/managed-compute-environment:EcsMachineImage" - }, - "@aws-cdk/aws-batch-alpha.EcsMachineImageType": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Maps the image to instance types." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImageType", - "kind": "enum", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 391 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "Tells Batch that this machine image runs on non-GPU instances." - }, - "name": "ECS_AL2" - }, - { - "docs": { - "stability": "experimental", - "summary": "Tells Batch that this machine image runs on GPU instances." - }, - "name": "ECS_AL2_NVIDIA" - } - ], - "name": "EcsMachineImageType", - "symbolId": "lib/managed-compute-environment:EcsMachineImageType" - }, - "@aws-cdk/aws-batch-alpha.EcsVolume": { - "abstract": true, - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Represents a Volume that can be mounted to a container that uses ECS." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 162 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 126 - }, - "methods": [ - { - "docs": { - "remarks": "this volume can grow and shrink as needed", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html", - "stability": "experimental", - "summary": "Creates a Volume that uses an AWS Elastic File System (EFS);" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 132 - }, - "name": "efs", - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EfsVolume" - } - }, - "static": true - }, - { - "docs": { - "remarks": "This volume will persist on the host at the specified `hostPath`.\nIf the `hostPath` is not specified, Docker will choose the host path. In this case,\nthe data may not persist after the containers that use it stop running.", - "stability": "experimental", - "summary": "Creates a Host volume." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 141 - }, - "name": "host", - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostVolume" - } - }, - "static": true - } - ], - "name": "EcsVolume", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The path on the container that this volume will be mounted to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 153 - }, - "name": "containerPath", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 148 - }, - "name": "name", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Whether or not the container has readonly access to this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 160 - }, - "name": "readonly", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsVolume" - }, - "@aws-cdk/aws-batch-alpha.EcsVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Options to configure an EcsVolume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolumeOptions", - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 104 - }, - "name": "EcsVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "the path on the container where this volume is mounted." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 113 - }, - "name": "containerPath", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "the name of this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 108 - }, - "name": "name", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "if set, the container will have readonly access to the volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 120 - }, - "name": "readonly", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:EcsVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.EfsVolume": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "@aws-cdk/aws-batch-alpha.EcsVolume", - "docs": { - "remarks": "this volume can grow and shrink as needed", - "stability": "experimental", - "summary": "A Volume that uses an AWS Elastic File System (EFS);" - }, - "fqn": "@aws-cdk/aws-batch-alpha.EfsVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 297 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 233 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Returns true if x is an EfsVolume, false otherwise." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 237 - }, - "name": "isEfsVolume", - "parameters": [ - { - "name": "x", - "type": { - "primitive": "any" - } - } - ], - "returns": { - "type": { - "primitive": "boolean" - } - }, - "static": true - } - ], - "name": "EfsVolume", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The EFS File System that supports this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 244 - }, - "name": "fileSystem", - "type": { - "fqn": "aws-cdk-lib.aws_efs.IFileSystem" - } - }, - { - "docs": { - "default": "- no accessPointId", - "remarks": "If an access point is specified, `rootDirectory` must either be omitted or set to `/`\nwhich enforces the path set on the EFS access point.\nIf an access point is used, `enableTransitEncryption` must be `true`.", - "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html", - "stability": "experimental", - "summary": "The Amazon EFS access point ID to use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 285 - }, - "name": "accessPointId", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "false", - "see": "https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html", - "stability": "experimental", - "summary": "Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 263 - }, - "name": "enableTransitEncryption", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "default": "- root of the EFS File System", - "remarks": "If this parameter is omitted, the root of the Amazon EFS volume is used instead.\nSpecifying `/` has the same effect as omitting this parameter.\nThe maximum length is 4,096 characters.", - "stability": "experimental", - "summary": "The directory within the Amazon EFS file system to mount as the root directory inside the host." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 254 - }, - "name": "rootDirectory", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "- chosen by the EFS Mount Helper", - "remarks": "The value must be between 0 and 65,535.", - "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html", - "stability": "experimental", - "summary": "The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 273 - }, - "name": "transitEncryptionPort", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "docs": { - "default": "false", - "remarks": "If specified, `enableTransitEncryption` must be `true`.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints", - "stability": "experimental", - "summary": "Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 295 - }, - "name": "useJobRole", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:EfsVolume" - }, - "@aws-cdk/aws-batch-alpha.EfsVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Options for configuring an EfsVolume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EfsVolumeOptions", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 172 - }, - "name": "EfsVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The EFS File System that supports this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 176 - }, - "name": "fileSystem", - "type": { - "fqn": "aws-cdk-lib.aws_efs.IFileSystem" - } - }, - { - "abstract": true, - "docs": { - "default": "- no accessPointId", - "remarks": "If an access point is specified, `rootDirectory` must either be omitted or set to `/`\nwhich enforces the path set on the EFS access point.\nIf an access point is used, `enableTransitEncryption` must be `true`.", - "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html", - "stability": "experimental", - "summary": "The Amazon EFS access point ID to use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 217 - }, - "name": "accessPointId", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "see": "https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html", - "stability": "experimental", - "summary": "Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 195 - }, - "name": "enableTransitEncryption", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- root of the EFS File System", - "remarks": "If this parameter is omitted, the root of the Amazon EFS volume is used instead.\nSpecifying `/` has the same effect as omitting this parameter.\nThe maximum length is 4,096 characters.", - "stability": "experimental", - "summary": "The directory within the Amazon EFS file system to mount as the root directory inside the host." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 186 - }, - "name": "rootDirectory", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- chosen by the EFS Mount Helper", - "remarks": "The value must be between 0 and 65,535.", - "see": "https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html", - "stability": "experimental", - "summary": "The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 205 - }, - "name": "transitEncryptionPort", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "If specified, `enableTransitEncryption` must be `true`.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints", - "stability": "experimental", - "summary": "Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 227 - }, - "name": "useJobRole", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:EfsVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.EksContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "constructs.Construct", - "docs": { - "stability": "experimental", - "summary": "A container that can be run with EKS orchestration on EC2 resources." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 555 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEksContainerDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 533 - }, - "methods": [ - { - "docs": { - "remarks": "Automatically added to the Pod.", - "stability": "experimental", - "summary": "Mount a Volume to this container." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 579 - }, - "name": "addVolume", - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "parameters": [ - { - "name": "volume", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" - } - } - ] - } - ], - "name": "EksContainerDefinition", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 534 - }, - "name": "image", - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "docs": { - "remarks": "Automatically added to the Pod.", - "stability": "experimental", - "summary": "The Volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 551 - }, - "name": "volumes", - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", - "stability": "experimental", - "summary": "An array of arguments to the entrypoint." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 535 - }, - "name": "args", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", - "stability": "experimental", - "summary": "The entrypoint for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 536 - }, - "name": "command", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "stability": "experimental", - "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 542 - }, - "name": "cpuLimit", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 543 - }, - "name": "cpuReservation", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", - "stability": "experimental", - "summary": "The environment variables to pass to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 537 - }, - "name": "env", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "docs": { - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "stability": "experimental", - "summary": "The hard limit of GPUs to present to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 544 - }, - "name": "gpuLimit", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 545 - }, - "name": "gpuReservation", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The image pull policy for this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 538 - }, - "name": "imagePullPolicy", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" - } - }, - { - "docs": { - "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "stability": "experimental", - "summary": "The amount (in MiB) of memory to present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 540 - }, - "name": "memoryLimit", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "stability": "experimental", - "summary": "The soft limit (in MiB) of memory to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 541 - }, - "name": "memoryReservation", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 539 - }, - "name": "name", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "stability": "experimental", - "summary": "If specified, gives this container elevated permissions on the host container instance." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 546 - }, - "name": "privileged", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "stability": "experimental", - "summary": "If specified, gives this container readonly access to its root file system." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 547 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "stability": "experimental", - "summary": "If specified, the container is run as the specified group ID (`gid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 548 - }, - "name": "runAsGroup", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "stability": "experimental", - "summary": "If specified, the container is run as a user with a `uid` other than 0." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 549 - }, - "name": "runAsRoot", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "stability": "experimental", - "summary": "If specified, this container is run as the specified user ID (`uid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 550 - }, - "name": "runAsUser", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/eks-container-definition:EksContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure an EksContainerDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinitionProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 287 - }, - "name": "EksContainerDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 291 - }, - "name": "image", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "abstract": true, - "docs": { - "default": "- no args", - "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", - "see": "https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/", - "stability": "experimental", - "summary": "An array of arguments to the entrypoint." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 308 - }, - "name": "args", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no command", - "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", - "see": "https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint", - "stability": "experimental", - "summary": "The entrypoint for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 327 - }, - "name": "command", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- No CPU limit", - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 411 - }, - "name": "cpuLimit", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- No CPUs reserved", - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 426 - }, - "name": "cpuReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no environment variables", - "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", - "stability": "experimental", - "summary": "The environment variables to pass to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 337 - }, - "name": "env", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- No GPU limit", - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The hard limit of GPUs to present to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 439 - }, - "name": "gpuLimit", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- No GPUs reserved", - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 453 - }, - "name": "gpuReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise", - "see": "https://kubernetes.io/docs/concepts/containers/images/#updating-images", - "stability": "experimental", - "summary": "The image pull policy for this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 346 - }, - "name": "imagePullPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" - } - }, - { - "abstract": true, - "docs": { - "default": "- No memory limit", - "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", - "stability": "experimental", - "summary": "The amount (in MiB) of memory to present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 371 - }, - "name": "memoryLimit", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "- No memory reserved", - "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", - "stability": "experimental", - "summary": "The soft limit (in MiB) of memory to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 396 - }, - "name": "memoryReservation", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": ": `'Default'`", - "stability": "experimental", - "summary": "The name of this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 353 - }, - "name": "name", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", - "stability": "experimental", - "summary": "If specified, gives this container elevated permissions on the host container instance." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 467 - }, - "name": "privileged", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", - "stability": "experimental", - "summary": "If specified, gives this container readonly access to its root file system." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 480 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, the container is run as the specified group ID (`gid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 493 - }, - "name": "runAsGroup", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- the container is *not* required to run as a non-root user", - "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, the container is run as a user with a `uid` other than 0." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 505 - }, - "name": "runAsRoot", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- the user that is specified in the image metadata.", - "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, this container is run as the specified user ID (`uid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 517 - }, - "name": "runAsUser", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no volumes", - "remarks": "Automatically added to the Pod.", - "see": "https://kubernetes.io/docs/concepts/storage/volumes/", - "stability": "experimental", - "summary": "The Volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 527 - }, - "name": "volumes", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/eks-container-definition:EksContainerDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EksJobDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::JobDefinition" - }, - "stability": "experimental", - "summary": "A JobDefinition that uses Eks orchestration." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 151 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "@aws-cdk/aws-batch-alpha.IJobDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 125 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Import an EksJobDefinition by its arn." - }, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 129 - }, - "name": "fromEksJobDefinitionArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "eksJobDefinitionArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IEksJobDefinition" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a RetryStrategy to this JobDefinition." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 259 - }, - "name": "addRetryStrategy", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "parameters": [ - { - "name": "strategy", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - } - } - ] - } - ], - "name": "EksJobDefinition", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The container this Job Definition will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 143 - }, - "name": "container", - "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 148 - }, - "name": "jobDefinitionArn", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 149 - }, - "name": "jobDefinitionName", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Defines the retry behavior for this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 243 - }, - "name": "retryStrategies", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The DNS Policy of the pod used by this Job Definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 144 - }, - "name": "dnsPolicy", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 241 - }, - "name": "parameters", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "any" - }, - "kind": "map" - } - } - }, - { - "docs": { - "remarks": "The job is retried on failure the same number of attempts as the value.", - "stability": "experimental", - "summary": "The number of times to retry a job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 242 - }, - "name": "retryAttempts", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", - "stability": "experimental", - "summary": "The priority of this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 244 - }, - "name": "schedulingPriority", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", - "stability": "experimental", - "summary": "The name of the service account that's used to run the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 146 - }, - "name": "serviceAccount", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", - "stability": "experimental", - "summary": "The timeout time for jobs that are submitted with this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 245 - }, - "name": "timeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "docs": { - "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", - "stability": "experimental", - "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 145 - }, - "name": "useHostNetwork", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-job-definition:EksJobDefinition" - }, - "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for EksJobDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksJobDefinitionProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.JobDefinitionProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 54 - }, - "name": "EksJobDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The container this Job Definition will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 58 - }, - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" - } - }, - { - "abstract": true, - "docs": { - "default": "`DnsPolicy.CLUSTER_FIRST`", - "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", - "stability": "experimental", - "summary": "The DNS Policy of the pod used by this Job Definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 67 - }, - "name": "dnsPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" - } - }, - { - "abstract": true, - "docs": { - "default": "- the default service account of the container", - "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", - "see": "https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html", - "stability": "experimental", - "summary": "The name of the service account that's used to run the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 92 - }, - "name": "serviceAccount", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", - "see": "https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking", - "stability": "experimental", - "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 79 - }, - "name": "useHostNetwork", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-job-definition:EksJobDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.EksMachineImage": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "A Batch MachineImage that is compatible with EKS." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage", - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 379 - }, - "name": "EksMachineImage", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- chosen by batch", - "stability": "experimental", - "summary": "The machine image to use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 361 - }, - "name": "image", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IMachineImage" - } - }, - { - "abstract": true, - "docs": { - "default": "- 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances", - "stability": "experimental", - "summary": "Tells Batch which instance type to launch this image on." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 385 - }, - "name": "imageType", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImageType" - } - } - ], - "symbolId": "lib/managed-compute-environment:EksMachineImage" - }, - "@aws-cdk/aws-batch-alpha.EksMachineImageType": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Maps the image to instance types." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImageType", - "kind": "enum", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 406 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "Tells Batch that this machine image runs on non-GPU instances." - }, - "name": "EKS_AL2" - }, - { - "docs": { - "stability": "experimental", - "summary": "Tells Batch that this machine image runs on GPU instances." - }, - "name": "EKS_AL2_NVIDIA" - } - ], - "name": "EksMachineImageType", - "symbolId": "lib/managed-compute-environment:EksMachineImageType" - }, - "@aws-cdk/aws-batch-alpha.EksVolume": { - "abstract": true, - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A Volume that can be mounted to a container supported by EKS." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 717 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 668 - }, - "methods": [ - { - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", - "stability": "experimental", - "summary": "Creates a Kubernetes EmptyDir volume." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 674 - }, - "name": "emptyDir", - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolume" - } - }, - "static": true - }, - { - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", - "stability": "experimental", - "summary": "Creates a Kubernetes HostPath volume." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 682 - }, - "name": "hostPath", - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolume" - } - }, - "static": true - }, - { - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", - "stability": "experimental", - "summary": "Creates a Kubernetes Secret volume." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 690 - }, - "name": "secret", - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolume" - } - }, - "static": true - } - ], - "name": "EksVolume", - "properties": [ - { - "docs": { - "remarks": "The name must be a valid DNS subdomain name.", - "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", - "stability": "experimental", - "summary": "The name of this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 700 - }, - "name": "name", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "- the container is not mounted", - "stability": "experimental", - "summary": "The path on the container where the container is mounted." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 707 - }, - "name": "containerPath", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "false", - "remarks": "Otherwise, the container has read/write access.", - "stability": "experimental", - "summary": "If specified, the container has readonly access to the volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 715 - }, - "name": "readonly", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-container-definition:EksVolume" - }, - "@aws-cdk/aws-batch-alpha.EksVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Options to configure an EksVolume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EksVolumeOptions", - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 640 - }, - "name": "EksVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "The name must be a valid DNS subdomain name.", - "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", - "stability": "experimental", - "summary": "The name of this volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 647 - }, - "name": "name", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- the volume is not mounted", - "stability": "experimental", - "summary": "The path on the container where the volume is mounted." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 654 - }, - "name": "mountPath", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "Otherwise, the container has read/write access.", - "stability": "experimental", - "summary": "If specified, the container has readonly access to the volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 662 - }, - "name": "readonly", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-container-definition:EksVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.EmptyDirMediumType": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "What medium the volume will live in." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType", - "kind": "enum", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 748 - }, - "members": [ - { - "docs": { - "remarks": "Items written here will survive node reboots.", - "stability": "experimental", - "summary": "Use the disk storage of the node." - }, - "name": "DISK" - }, - { - "docs": { - "remarks": "Items written here will *not* survive node reboots.", - "stability": "experimental", - "summary": "Use the `tmpfs` volume that is backed by RAM of the node." - }, - "name": "MEMORY" - } - ], - "name": "EmptyDirMediumType", - "symbolId": "lib/eks-container-definition:EmptyDirMediumType" - }, - "@aws-cdk/aws-batch-alpha.EmptyDirVolume": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "@aws-cdk/aws-batch-alpha.EksVolume", - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", - "stability": "experimental", - "summary": "A Kubernetes EmptyDir volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 789 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 767 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Returns `true` if `x` is an EmptyDirVolume, `false` otherwise." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 771 - }, - "name": "isEmptyDirVolume", - "parameters": [ - { - "name": "x", - "type": { - "primitive": "any" - } - } - ], - "returns": { - "type": { - "primitive": "boolean" - } - }, - "static": true - } - ], - "name": "EmptyDirVolume", - "properties": [ - { - "docs": { - "default": "`EmptyDirMediumType.DISK`", - "stability": "experimental", - "summary": "The storage type to use for this Volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 780 - }, - "name": "medium", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType" - } - }, - { - "docs": { - "default": "- no size limit", - "stability": "experimental", - "summary": "The maximum size for this Volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 787 - }, - "name": "sizeLimit", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - } - ], - "symbolId": "lib/eks-container-definition:EmptyDirVolume" - }, - "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#emptydir", - "stability": "experimental", - "summary": "Options for a Kubernetes EmptyDir volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirVolumeOptions", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EksVolumeOptions" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 729 - }, - "name": "EmptyDirVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "default": "`EmptyDirMediumType.DISK`", - "stability": "experimental", - "summary": "The storage type to use for this Volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 735 - }, - "name": "medium", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EmptyDirMediumType" - } - }, - { - "abstract": true, - "docs": { - "default": "- no size limit", - "stability": "experimental", - "summary": "The maximum size for this Volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 742 - }, - "name": "sizeLimit", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - } - ], - "symbolId": "lib/eks-container-definition:EmptyDirVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::SchedulingPolicy" - }, - "remarks": "The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\nThe scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\neach share are currently being executed by the ComputeEnvironment*. The weight factors associated with\neach share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\nfairshare policies.", - "stability": "experimental", - "summary": "Represents a Fairshare Scheduling Policy. Instructs the scheduler to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers." - }, - "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 212 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", - "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 191 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Reference an exisiting Scheduling Policy by its ARN." - }, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 195 - }, - "name": "fromFairshareSchedulingPolicyArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "fairshareSchedulingPolicyArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a share this to this Fairshare SchedulingPolicy." - }, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 242 - }, - "name": "addShare", - "parameters": [ - { - "name": "share", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Share" - } - } - ] - } - ], - "name": "FairshareSchedulingPolicy", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The arn of this scheduling policy." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 209 - }, - "name": "schedulingPolicyArn", - "overrides": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this scheduling policy." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 210 - }, - "name": "schedulingPolicyName", - "overrides": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", - "stability": "experimental", - "summary": "The shares that this Scheduling Policy applies to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 208 - }, - "name": "shares", - "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Share" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", - "stability": "experimental", - "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 206 - }, - "name": "computeReservation", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", - "stability": "experimental", - "summary": "The amount of time to use to measure the usage of each job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 207 - }, - "name": "shareDecay", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/scheduling-policy:FairshareSchedulingPolicy" - }, - "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Fairshare SchedulingPolicy configuration." - }, - "fqn": "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicyProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 136 - }, - "name": "FairshareSchedulingPolicyProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- no vCPU is reserved", - "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", - "stability": "experimental", - "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 155 - }, - "name": "computeReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- generated by CloudFormation", - "stability": "experimental", - "summary": "The name of this SchedulingPolicy." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 34 - }, - "name": "schedulingPolicyName", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- 0: only the current job usage is considered", - "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", - "stability": "experimental", - "summary": "The amount of time to use to measure the usage of each job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 167 - }, - "name": "shareDecay", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "abstract": true, - "docs": { - "default": "- no shares", - "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", - "stability": "experimental", - "summary": "The shares that this Scheduling Policy applies to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 176 - }, - "name": "shares", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Share" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/scheduling-policy:FairshareSchedulingPolicyProps" - }, - "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::ComputeEnvironment" - }, - "stability": "experimental", - "summary": "A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances." - }, - "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1096 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1072 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Reference an existing FargateComputeEnvironment by its arn." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1076 - }, - "name": "fromFargateComputeEnvironmentArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "fargateComputeEnvironmentArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment" - } - }, - "static": true - } - ], - "name": "FargateComputeEnvironment", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this compute environment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1094 - }, - "name": "computeEnvironmentArn", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1093 - }, - "name": "computeEnvironmentName", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The network connections associated with this resource." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 210 - }, - "name": "connections", - "overrides": "aws-cdk-lib.aws_ec2.IConnectable", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.Connections" - } - }, - { - "docs": { - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 92 - }, - "name": "enabled", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", - "stability": "experimental", - "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 201 - }, - "name": "maxvCpus", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The security groups this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 206 - }, - "name": "securityGroups", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "TagManager to set, remove and format tags." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 208 - }, - "name": "tags", - "overrides": "aws-cdk-lib.ITaggable", - "type": { - "fqn": "aws-cdk-lib.TagManager" - } - }, - { - "docs": { - "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", - "stability": "experimental", - "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 202 - }, - "name": "replaceComputeEnvironment", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 91 - }, - "name": "serviceRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", - "stability": "experimental", - "summary": "Whether or not to use spot instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 203 - }, - "name": "spot", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", - "stability": "experimental", - "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 205 - }, - "name": "terminateOnUpdate", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", - "stability": "experimental", - "summary": "Only meaningful if `terminateOnUpdate` is `false`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 204 - }, - "name": "updateTimeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "docs": { - "remarks": "If you specify a specific AMI, this property will be ignored.", - "stability": "experimental", - "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 207 - }, - "name": "updateToLatestImageVersion", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:FargateComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for a FargateComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.FargateComputeEnvironmentProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1065 - }, - "name": "FargateComputeEnvironmentProps", - "symbolId": "lib/managed-compute-environment:FargateComputeEnvironmentProps" - }, - "@aws-cdk/aws-batch-alpha.HostPathVolume": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "@aws-cdk/aws-batch-alpha.EksVolume", - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", - "stability": "experimental", - "summary": "A Kubernetes HostPath volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 840 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 823 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "returns `true` if `x` is a HostPathVolume, `false` otherwise." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 827 - }, - "name": "isHostPathVolume", - "parameters": [ - { - "name": "x", - "type": { - "primitive": "any" - } - } - ], - "returns": { - "type": { - "primitive": "boolean" - } - }, - "static": true - } - ], - "name": "HostPathVolume", - "properties": [ - { - "docs": { - "remarks": "*Note*: HothPath Volumes present many security risks, and should be avoided when possible.", - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", - "stability": "experimental", - "summary": "The path of the file or directory on the host to mount into containers on the pod." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 838 - }, - "name": "path", - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/eks-container-definition:HostPathVolume" - }, - "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", - "stability": "experimental", - "summary": "Options for a kubernetes HostPath volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.HostPathVolumeOptions", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EksVolumeOptions" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 807 - }, - "name": "HostPathVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "*Note*: HothPath Volumes present many security risks, and should be avoided when possible.", - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#hostpath", - "stability": "experimental", - "summary": "The path of the file or directory on the host to mount into containers on the pod." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 815 - }, - "name": "hostPath", - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/eks-container-definition:HostPathVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.HostVolume": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "@aws-cdk/aws-batch-alpha.EcsVolume", - "docs": { - "remarks": "This volume will persist on the host at the specified `hostPath`.\nIf the `hostPath` is not specified, Docker will choose the host path. In this case,\nthe data may not persist after the containers that use it stop running.", - "stability": "experimental", - "summary": "Creates a Host volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.HostVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 346 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 333 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "returns `true` if `x` is a `HostVolume`, `false` otherwise." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 337 - }, - "name": "isHostVolume", - "parameters": [ - { - "name": "x", - "type": { - "primitive": "any" - } - } - ], - "returns": { - "type": { - "primitive": "boolean" - } - }, - "static": true - } - ], - "name": "HostVolume", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The path on the host machine this container will have access to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 344 - }, - "name": "hostPath", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:HostVolume" - }, - "@aws-cdk/aws-batch-alpha.HostVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Options for configuring an ECS HostVolume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.HostVolumeOptions", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EcsVolumeOptions" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 318 - }, - "name": "HostVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- Docker will choose the host path.\nThe data may not persist after the containers that use it stop running.", - "stability": "experimental", - "summary": "The path on the host machine this container will have access to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 325 - }, - "name": "hostPath", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:HostVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.IComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Represents a ComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "interfaces": [ - "aws-cdk-lib.IResource" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 8 - }, - "name": "IComputeEnvironment", - "properties": [ - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The ARN of this compute environment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 21 - }, - "name": "computeEnvironmentArn", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 14 - }, - "name": "computeEnvironmentName", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 44 - }, - "name": "enabled", - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- a serviceRole will be created for managed CEs, none for unmanaged CEs", - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 29 - }, - "name": "serviceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - } - ], - "symbolId": "lib/compute-environment-base:IComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A container that can be run with ECS orchestration." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition", - "interfaces": [ - "constructs.IConstruct" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 361 - }, - "methods": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Add a Volume to this container." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 466 - }, - "name": "addVolume", - "parameters": [ - { - "name": "volume", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - } - } - ] - } - ], - "name": "IEcsContainerDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "Each vCPU is equivalent to 1,024 CPU shares.\nFor containers running on EC2 resources, you must specify at least one vCPU.", - "stability": "experimental", - "summary": "The number of vCPUs reserved for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 372 - }, - "name": "cpu", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "see": "https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html", - "stability": "experimental", - "summary": "The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 402 - }, - "name": "executionRole", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 365 - }, - "name": "image", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "abstract": true, - "docs": { - "remarks": "If your container attempts to exceed the memory specified, the container is terminated.\nYou must specify at least 4 MiB of memory for a job.", - "stability": "experimental", - "summary": "The memory hard limit present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 379 - }, - "name": "memory", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "- no volumes", - "remarks": "Automatically added to the job definition.", - "stability": "experimental", - "summary": "The volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 454 - }, - "name": "volumes", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsVolume" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "see": "https://docs.docker.com/engine/reference/builder/#cmd", - "stability": "experimental", - "summary": "The command that's passed to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 386 - }, - "name": "command", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no environment variables", - "remarks": "Cannot start with `AWS_BATCH`.\nWe don't recommend using plaintext environment variables for sensitive information, such as credential data.", - "stability": "experimental", - "summary": "The environment variables to pass to a container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 395 - }, - "name": "environment", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no jobRole", - "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html", - "stability": "experimental", - "summary": "The role that the container can assume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 411 - }, - "name": "jobRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "stability": "experimental", - "summary": "Linux-specific modifications that are applied to the container, such as details for device mappings." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 418 - }, - "name": "linuxParameters", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The configuration of the log driver." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 423 - }, - "name": "logDriverConfig", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ecs.LogDriverConfig" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Gives the container readonly access to its root filesystem." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 430 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- no secrets", - "remarks": "Allows your job definitions\nto reference the secret by the environment variable name defined in this property.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html", - "stability": "experimental", - "summary": "A map from environment variable names to the secrets for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 440 - }, - "name": "secrets", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no user", - "stability": "experimental", - "summary": "The user name to use inside the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 447 - }, - "name": "user", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:IEcsContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A container orchestrated by ECS that uses EC2 resources." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IEcsEc2ContainerDefinition", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 836 - }, - "methods": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Add a ulimit to this container." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 861 - }, - "name": "addUlimit", - "parameters": [ - { - "name": "ulimit", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" - } - } - ] - } - ], - "name": "IEcsEc2ContainerDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Limits to set for the user this docker container will run as." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 847 - }, - "name": "ulimits", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no gpus", - "remarks": "Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\nthe number of available GPUs on the compute resource that the job is launched on.", - "stability": "experimental", - "summary": "The number of physical GPUs to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 856 - }, - "name": "gpu", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 842 - }, - "name": "privileged", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:IEcsEc2ContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IEcsFargateContainerDefinition", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 957 - }, - "name": "IEcsFargateContainerDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n(for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.", - "see": "https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html", - "stability": "experimental", - "summary": "Indicates whether the job has a public IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 967 - }, - "name": "assignPublicIp", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- 20 GiB", - "stability": "experimental", - "summary": "The size for ephemeral storage." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 981 - }, - "name": "ephemeralStorageSize", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "LATEST", - "stability": "experimental", - "summary": "Which version of Fargate to use when running this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 974 - }, - "name": "fargatePlatformVersion", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ecs.FargatePlatformVersion" - } - } - ], - "symbolId": "lib/ecs-container-definition:IEcsFargateContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.IEksContainerDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A container that can be run with EKS orchestration on EC2 resources." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IEksContainerDefinition", - "interfaces": [ - "constructs.IConstruct" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 13 - }, - "methods": [ - { - "abstract": true, - "docs": { - "remarks": "Automatically added to the Pod.", - "stability": "experimental", - "summary": "Mount a Volume to this container." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 250 - }, - "name": "addVolume", - "parameters": [ - { - "name": "volume", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" - } - } - ] - } - ], - "name": "IEksContainerDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The image that this container will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 17 - }, - "name": "image", - "type": { - "fqn": "aws-cdk-lib.aws_ecs.ContainerImage" - } - }, - { - "abstract": true, - "docs": { - "remarks": "Automatically added to the Pod.", - "see": "https://kubernetes.io/docs/concepts/storage/volumes/", - "stability": "experimental", - "summary": "The Volumes to mount to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 245 - }, - "name": "volumes", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EksVolume" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "remarks": "If this isn't specified, the CMD of the container image is used.\nThis corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\nthe command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\nor example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.", - "see": "https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/", - "stability": "experimental", - "summary": "An array of arguments to the entrypoint." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 32 - }, - "name": "args", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "remarks": "This isn't run within a shell.\nIf this isn't specified, the `ENTRYPOINT` of the container image is used.\nEnvironment variable references are expanded using the container's environment.\nIf the referenced environment variable doesn't exist, the reference in the command isn't changed.\nFor example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\nthe command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\nFor example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\nThe entrypoint can't be updated.", - "see": "https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint", - "stability": "experimental", - "summary": "The entrypoint for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 49 - }, - "name": "command", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- No CPU limit", - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The hard limit of CPUs to present to this container. Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 131 - }, - "name": "cpuLimit", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- No CPUs reserved", - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nAt least one of `cpuReservation` and `cpuLimit` is required.\nIf both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 146 - }, - "name": "cpuReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "remarks": "*Note*: Environment variables cannot start with \"AWS_BATCH\".\nThis naming convention is reserved for variables that AWS Batch sets.", - "stability": "experimental", - "summary": "The environment variables to pass to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 57 - }, - "name": "env", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "string" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- No GPU limit", - "remarks": "If your container attempts to exceed this limit, it will be terminated.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The hard limit of GPUs to present to this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 159 - }, - "name": "gpuLimit", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- No GPUs reserved", - "remarks": "The container will given at least this many CPUs, but may consume more.\n\nIf both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.", - "see": "https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/", - "stability": "experimental", - "summary": "The soft limit of CPUs to reserve for the container Must be an even multiple of 0.25." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 173 - }, - "name": "gpuReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise", - "see": "https://kubernetes.io/docs/concepts/containers/images/#updating-images", - "stability": "experimental", - "summary": "The image pull policy for this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 66 - }, - "name": "imagePullPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy" - } - }, - { - "abstract": true, - "docs": { - "default": "- No memory limit", - "remarks": "If your container attempts to exceed the allocated memory, it will be terminated.\n\nMust be larger that 4 MiB\n\nAt least one of `memoryLimit` and `memoryReservation` is required\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", - "stability": "experimental", - "summary": "The amount (in MiB) of memory to present to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 91 - }, - "name": "memoryLimit", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "- No memory reserved", - "remarks": "Your container will be given at least this much memory, but may consume more.\n\nMust be larger that 4 MiB\n\nWhen system memory is under heavy contention, Docker attempts to keep the\ncontainer memory to this soft limit. However, your container can consume more\nmemory when it needs to, up to either the hard limit specified with the memory\nparameter (if applicable), or all of the available memory on the container\ninstance, whichever comes first.\n\nAt least one of `memoryLimit` and `memoryReservation` is required.\nIf both are specified, then `memoryLimit` must be equal to `memoryReservation`\n\n*Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\nfor the specific instance type that you are using.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html", - "stability": "experimental", - "summary": "The soft limit (in MiB) of memory to reserve for the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 116 - }, - "name": "memoryReservation", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": ": `'Default'`", - "stability": "experimental", - "summary": "The name of this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 73 - }, - "name": "name", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "The level of permissions are similar to the root user permissions.\n\nThis parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", - "stability": "experimental", - "summary": "If specified, gives this container elevated permissions on the host container instance." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 187 - }, - "name": "privileged", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems", - "stability": "experimental", - "summary": "If specified, gives this container readonly access to its root file system." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 200 - }, - "name": "readonlyRootFilesystem", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "If this parameter isn't specified, the default is the group that's specified in the image metadata.\nThis parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, the container is run as the specified group ID (`gid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 213 - }, - "name": "runAsGroup", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- the container is *not* required to run as a non-root user", - "remarks": "Otherwise, no such rule is enforced.\nThis parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, the container is run as a user with a `uid` other than 0." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 225 - }, - "name": "runAsRoot", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- the user that is specified in the image metadata.", - "remarks": "This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n\n*Note*: this is only compatible with Kubernetes < v1.25", - "see": "https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups", - "stability": "experimental", - "summary": "If specified, this container is run as the specified user ID (`uid`)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 237 - }, - "name": "runAsUser", - "optional": true, - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/eks-container-definition:IEksContainerDefinition" - }, - "@aws-cdk/aws-batch-alpha.IEksJobDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A JobDefinition that uses Eks orchestration." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IEksJobDefinition", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IJobDefinition" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 10 - }, - "name": "IEksJobDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The container this Job Definition will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 14 - }, - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.EksContainerDefinition" - } - }, - { - "abstract": true, - "docs": { - "default": "`DnsPolicy.CLUSTER_FIRST`", - "see": "https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy", - "stability": "experimental", - "summary": "The DNS Policy of the pod used by this Job Definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 23 - }, - "name": "dnsPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.DnsPolicy" - } - }, - { - "abstract": true, - "docs": { - "default": "- the default service account of the container", - "remarks": "service accounts are Kubernetes method of identification and authentication,\nroughly analogous to IAM users.", - "see": "https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html", - "stability": "experimental", - "summary": "The name of the service account that's used to run the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 48 - }, - "name": "serviceAccount", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "Otherwise, the Kubernetes pod networking model is enabled.\nMost AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.", - "see": "https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking", - "stability": "experimental", - "summary": "If specified, the Pod used by this Job Definition will use the host's network IP address." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-job-definition.ts", - "line": 35 - }, - "name": "useHostNetwork", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-job-definition:IEksJobDefinition" - }, - "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "remarks": "The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\nIt does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\neach share are currently being executed by the ComputeEnvironment*. The weight factors associated with\neach share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\nfairshare policies.", - "stability": "experimental", - "summary": "Represents a Fairshare Scheduling Policy. Instructs the scheduler to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IFairshareSchedulingPolicy", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 92 - }, - "name": "IFairshareSchedulingPolicy", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "*Note*: It is possible to submit Jobs to the queue with Share Identifiers that\nare not recognized by the Scheduling Policy.", - "stability": "experimental", - "summary": "The shares that this Scheduling Policy applies to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 130 - }, - "name": "shares", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Share" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no vCPU is reserved", - "remarks": "The percentage reserved is defined by the Scheduler as:\n`(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n\nFor example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\nmaximum available vCPU if there's only one fair share identifier.\nIt reserves 25% if there are two fair share identifiers.\nIt reserves 12.5% if there are three fair share identifiers.\n\nA computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\nmaximum available vCPU if there's only one fair share identifier,\n6.25% if there are two fair share identifiers,\nand 1.56% if there are three fair share identifiers.", - "stability": "experimental", - "summary": "Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 111 - }, - "name": "computeReservation", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- 0: only the current job usage is considered", - "remarks": "The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\nA value of zero (0) indicates that only current usage is measured.\nThe decay is linear and gives preference to newer jobs.\n\nThe maximum supported value is 604800 seconds (1 week).", - "stability": "experimental", - "summary": "The amount of time to use to measure the usage of each job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 123 - }, - "name": "shareDecay", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/scheduling-policy:IFairshareSchedulingPolicy" - }, - "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IFargateComputeEnvironment", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1060 - }, - "name": "IFargateComputeEnvironment", - "symbolId": "lib/managed-compute-environment:IFargateComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.IJobDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Represents a JobDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "interfaces": [ - "aws-cdk-lib.IResource" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 8 - }, - "methods": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Add a RetryStrategy to this JobDefinition." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 70 - }, - "name": "addRetryStrategy", - "parameters": [ - { - "name": "strategy", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - } - } - ] - } - ], - "name": "IJobDefinition", - "properties": [ - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The ARN of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 14 - }, - "name": "jobDefinitionArn", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The name of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 21 - }, - "name": "jobDefinitionName", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- no `RetryStrategy`", - "stability": "experimental", - "summary": "Defines the retry behavior for this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 47 - }, - "name": "retryStrategies", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters", - "stability": "experimental", - "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 32 - }, - "name": "parameters", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "any" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "1", - "remarks": "The job is retried on failure the same number of attempts as the value.", - "stability": "experimental", - "summary": "The number of times to retry a job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 40 - }, - "name": "retryAttempts", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", - "stability": "experimental", - "summary": "The priority of this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 56 - }, - "name": "schedulingPriority", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no timeout", - "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", - "stability": "experimental", - "summary": "The timeout time for jobs that are submitted with this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 65 - }, - "name": "timeout", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/job-definition-base:IJobDefinition" - }, - "@aws-cdk/aws-batch-alpha.IJobQueue": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Represents a JobQueue." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue", - "interfaces": [ - "aws-cdk-lib.IResource" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 10 - }, - "methods": [ - { - "abstract": true, - "docs": { - "remarks": "The Queue will prefer lower-order `ComputeEnvironment`s.", - "stability": "experimental", - "summary": "Add a `ComputeEnvironment` to this Queue." - }, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 66 - }, - "name": "addComputeEnvironment", - "parameters": [ - { - "name": "computeEnvironment", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - } - }, - { - "name": "order", - "type": { - "primitive": "number" - } - } - ] - } - ], - "name": "IJobQueue", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", - "stability": "experimental", - "summary": "The set of compute environments mapped to a job queue and their order relative to each other." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 37 - }, - "name": "computeEnvironments", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The ARN of this job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 24 - }, - "name": "jobQueueArn", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", - "stability": "experimental", - "summary": "The name of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 17 - }, - "name": "jobQueueName", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.", - "stability": "experimental", - "summary": "The priority of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 45 - }, - "name": "priority", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", - "stability": "experimental", - "summary": "If the job queue is enabled, it is able to accept jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 53 - }, - "name": "enabled", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- no scheduling policy", - "remarks": "Instructs the Scheduler how to schedule different jobs.", - "stability": "experimental", - "summary": "The SchedulingPolicy for this JobQueue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 60 - }, - "name": "schedulingPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" - } - } - ], - "symbolId": "lib/job-queue:IJobQueue" - }, - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "remarks": "Batch will provision EC2 Instances to\nmeet the requirements of the jobs executing in this ComputeEnvironment.", - "stability": "experimental", - "summary": "Represents a Managed ComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "aws-cdk-lib.aws_ec2.IConnectable", - "aws-cdk-lib.ITaggable" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 14 - }, - "name": "IManagedComputeEnvironment", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", - "stability": "experimental", - "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 23 - }, - "name": "maxvCpus", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The security groups this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 78 - }, - "name": "securityGroups", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", - "see": "https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html", - "stability": "experimental", - "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 42 - }, - "name": "replaceComputeEnvironment", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", - "stability": "experimental", - "summary": "Whether or not to use spot instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 52 - }, - "name": "spot", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", - "stability": "experimental", - "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 73 - }, - "name": "terminateOnUpdate", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "30 minutes", - "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", - "stability": "experimental", - "summary": "Only meaningful if `terminateOnUpdate` is `false`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 62 - }, - "name": "updateTimeout", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "If you specify a specific AMI, this property will be ignored.", - "stability": "experimental", - "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 93 - }, - "name": "updateToLatestImageVersion", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The VPC Subnets this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 83 - }, - "name": "vpcSubnets", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.SubnetSelection" - } - } - ], - "symbolId": "lib/managed-compute-environment:IManagedComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 235 - }, - "methods": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Add an instance class to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 348 - }, - "name": "addInstanceClass", - "parameters": [ - { - "name": "instanceClass", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - } - } - ] - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Add an instance type to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 343 - }, - "name": "addInstanceType", - "parameters": [ - { - "name": "instanceType", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - } - } - ] - } - ], - "name": "IManagedEc2EcsComputeEnvironment", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the size.", - "stability": "experimental", - "summary": "The instance classes that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 287 - }, - "name": "instanceClasses", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 280 - }, - "name": "instanceTypes", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", - "stability": "experimental", - "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 253 - }, - "name": "allocationStrategy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" - } - }, - { - "abstract": true, - "docs": { - "default": "- ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances", - "remarks": "Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.", - "stability": "experimental", - "summary": "Configure which AMIs this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 244 - }, - "name": "images", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- a role will be created", - "stability": "experimental", - "summary": "The execution Role that instances launched by this Compute Environment will use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 304 - }, - "name": "instanceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "no launch template", - "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", - "stability": "experimental", - "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 317 - }, - "name": "launchTemplate", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" - } - }, - { - "abstract": true, - "docs": { - "default": "0", - "stability": "experimental", - "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 325 - }, - "name": "minvCpus", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no placement group", - "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", - "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", - "stability": "experimental", - "summary": "The EC2 placement group to associate with your compute resources." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 338 - }, - "name": "placementGroup", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" - } - }, - { - "abstract": true, - "docs": { - "default": "- 100%", - "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.", - "stability": "experimental", - "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 265 - }, - "name": "spotBidPercentage", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- a new Role will be created", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html", - "stability": "experimental", - "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 274 - }, - "name": "spotFleetRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", - "stability": "experimental", - "summary": "Whether or not to use batch's optimal instance type." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 297 - }, - "name": "useOptimalInstanceClasses", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:IManagedEc2EcsComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.ISchedulingPolicy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "remarks": "Scheduling Policies tell the Batch\nJob Scheduler how to schedule incoming jobs.", - "stability": "experimental", - "summary": "Represents a Scheduling Policy." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy", - "interfaces": [ - "aws-cdk-lib.IResource" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 9 - }, - "name": "ISchedulingPolicy", - "properties": [ - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The arn of this scheduling policy." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 22 - }, - "name": "schedulingPolicyArn", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "custom": { - "attribute": "true" - }, - "stability": "experimental", - "summary": "The name of this scheduling policy." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 15 - }, - "name": "schedulingPolicyName", - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/scheduling-policy:ISchedulingPolicy" - }, - "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "remarks": "Batch will not provision instances on your behalf\nin this ComputeEvironment.", - "stability": "experimental", - "summary": "Represents an UnmanagedComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 11 - }, - "name": "IUnmanagedComputeEnvironment", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", - "stability": "experimental", - "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 19 - }, - "name": "unmanagedvCPUs", - "optional": true, - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/unmanaged-compute-environment:IUnmanagedComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.ImagePullPolicy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Determines when the image is pulled from the registry to launch a container." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ImagePullPolicy", - "kind": "enum", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 256 - }, - "members": [ - { - "docs": { - "remarks": "If the kubelet has a container image with that exact digest cached locally,\nthe kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest,\nand uses that image to launch the container.", - "see": "https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier", - "stability": "experimental", - "summary": "Every time the kubelet launches a container, the kubelet queries the container image registry to resolve the name to an image digest." - }, - "name": "ALWAYS" - }, - { - "docs": { - "stability": "experimental", - "summary": "The image is pulled only if it is not already present locally." - }, - "name": "IF_NOT_PRESENT" - }, - { - "docs": { - "remarks": "If the image is somehow already present locally,\nthe kubelet attempts to start the container; otherwise, startup fails.\nSee pre-pulled images for more details.", - "see": "https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images", - "stability": "experimental", - "summary": "The kubelet does not try fetching the image." - }, - "name": "NEVER" - } - ], - "name": "ImagePullPolicy", - "symbolId": "lib/eks-container-definition:ImagePullPolicy" - }, - "@aws-cdk/aws-batch-alpha.JobDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props common to all JobDefinitions." - }, - "fqn": "@aws-cdk/aws-batch-alpha.JobDefinitionProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 76 - }, - "name": "JobDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- generated by CloudFormation", - "stability": "experimental", - "summary": "The name of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 82 - }, - "name": "jobDefinitionName", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters", - "stability": "experimental", - "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 93 - }, - "name": "parameters", - "optional": true, - "type": { - "collection": { - "elementtype": { - "primitive": "any" - }, - "kind": "map" - } - } - }, - { - "abstract": true, - "docs": { - "default": "1", - "remarks": "The job is retried on failure the same number of attempts as the value.", - "stability": "experimental", - "summary": "The number of times to retry a job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 101 - }, - "name": "retryAttempts", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no `RetryStrategy`", - "stability": "experimental", - "summary": "Defines the retry behavior for this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 108 - }, - "name": "retryStrategies", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", - "stability": "experimental", - "summary": "The priority of this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 117 - }, - "name": "schedulingPriority", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no timeout", - "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", - "stability": "experimental", - "summary": "The timeout time for jobs that are submitted with this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 126 - }, - "name": "timeout", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/job-definition-base:JobDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.JobQueue": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "remarks": "Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked.", - "stability": "experimental", - "summary": "JobQueues can receive Jobs, which are removed from the queue when sent to the linked ComputeEnvironment(s) to be executed." - }, - "fqn": "@aws-cdk/aws-batch-alpha.JobQueue", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 171 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.JobQueueProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IJobQueue" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 143 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "refer to an existing JobQueue by its arn." - }, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 147 - }, - "name": "fromJobQueueArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "jobQueueArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IJobQueue" - } - }, - "static": true - }, - { - "docs": { - "remarks": "The Queue will prefer lower-order `ComputeEnvironment`s.", - "stability": "experimental", - "summary": "Add a `ComputeEnvironment` to this Queue." - }, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 206 - }, - "name": "addComputeEnvironment", - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "parameters": [ - { - "name": "computeEnvironment", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - } - }, - { - "name": "order", - "type": { - "primitive": "number" - } - } - ] - } - ], - "name": "JobQueue", - "properties": [ - { - "docs": { - "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", - "stability": "experimental", - "summary": "The set of compute environments mapped to a job queue and their order relative to each other." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 163 - }, - "name": "computeEnvironments", - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 168 - }, - "name": "jobQueueArn", - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", - "stability": "experimental", - "summary": "The name of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 169 - }, - "name": "jobQueueName", - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.", - "stability": "experimental", - "summary": "The priority of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 164 - }, - "name": "priority", - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", - "stability": "experimental", - "summary": "If the job queue is enabled, it is able to accept jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 165 - }, - "name": "enabled", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "Instructs the Scheduler how to schedule different jobs.", - "stability": "experimental", - "summary": "The SchedulingPolicy for this JobQueue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 166 - }, - "name": "schedulingPolicy", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobQueue", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" - } - } - ], - "symbolId": "lib/job-queue:JobQueue" - }, - "@aws-cdk/aws-batch-alpha.JobQueueProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure a JobQueue." - }, - "fqn": "@aws-cdk/aws-batch-alpha.JobQueueProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 72 - }, - "name": "JobQueueProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "The job scheduler uses this parameter to determine which compute environment runs a specific job.\nCompute environments must be in the VALID state before you can associate them with a job queue.\nYou can associate up to three compute environments with a job queue.\nAll of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\nEC2 and Fargate compute environments can't be mixed.\n\n*Note*: All compute environments that are associated with a job queue must share the same architecture.\nAWS Batch doesn't support mixing compute environment architecture types in a single job queue.", - "stability": "experimental", - "summary": "The set of compute environments mapped to a job queue and their order relative to each other." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 86 - }, - "name": "computeEnvironments", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.", - "stability": "experimental", - "summary": "If the job queue is enabled, it is able to accept jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 112 - }, - "name": "enabled", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "- no name", - "remarks": "It can be up to 128 letters long.\nIt can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)", - "stability": "experimental", - "summary": "The name of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 104 - }, - "name": "jobQueueName", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "1", - "remarks": "Job queues with a higher priority are evaluated first when associated with the same compute environment.\nPriority is determined in descending order.\nFor example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1.", - "stability": "experimental", - "summary": "The priority of the job queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 96 - }, - "name": "priority", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no scheduling policy", - "remarks": "Instructs the Scheduler how to schedule different jobs.", - "stability": "experimental", - "summary": "The SchedulingPolicy for this JobQueue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 119 - }, - "name": "schedulingPolicy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ISchedulingPolicy" - } - } - ], - "symbolId": "lib/job-queue:JobQueueProps" - }, - "@aws-cdk/aws-batch-alpha.LinuxParameters": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "constructs.Construct", - "docs": { - "stability": "experimental", - "summary": "Linux-specific options that are applied to the container." - }, - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParameters", - "initializer": { - "docs": { - "stability": "experimental", - "summary": "Constructs a new instance of the LinuxParameters class." - }, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 87 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParametersProps" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 53 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Adds one or more host devices to a container." - }, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 111 - }, - "name": "addDevices", - "parameters": [ - { - "name": "device", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Device" - }, - "variadic": true - } - ], - "variadic": true - }, - { - "docs": { - "remarks": "Only works with EC2 launch type.", - "stability": "experimental", - "summary": "Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container." - }, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 120 - }, - "name": "addTmpfs", - "parameters": [ - { - "name": "tmpfs", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs" - }, - "variadic": true - } - ], - "variadic": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Renders the Linux parameters to the Batch version of this resource, which does not have 'capabilities' and requires tmpfs.containerPath to be defined." - }, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 128 - }, - "name": "renderLinuxParameters", - "returns": { - "type": { - "fqn": "aws-cdk-lib.aws_batch.CfnJobDefinition.LinuxParametersProperty" - } - } - } - ], - "name": "LinuxParameters", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "Device mounts." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 77 - }, - "name": "devices", - "protected": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Device" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "TmpFs mounts." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 82 - }, - "name": "tmpfs", - "protected": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Whether the init process is enabled." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 57 - }, - "name": "initProcessEnabled", - "optional": true, - "protected": true, - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The max swap memory." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 67 - }, - "name": "maxSwap", - "optional": true, - "protected": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "remarks": "Not valid for Fargate launch type", - "stability": "experimental", - "summary": "The shared memory size (in MiB)." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 62 - }, - "name": "sharedMemorySize", - "optional": true, - "protected": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The swappiness behavior." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 72 - }, - "name": "swappiness", - "optional": true, - "protected": true, - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/linux-parameters:LinuxParameters" - }, - "@aws-cdk/aws-batch-alpha.LinuxParametersProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "The properties for defining Linux-specific options that are applied to the container." - }, - "fqn": "@aws-cdk/aws-batch-alpha.LinuxParametersProps", - "kind": "interface", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 8 - }, - "name": "LinuxParametersProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Specifies whether to run an init process inside the container that forwards signals and reaps processes." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 14 - }, - "name": "initProcessEnabled", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "No swap.", - "remarks": "This parameter\nwill be translated to the --memory-swap option to docker run.\n\nThis parameter is only supported when you are using the EC2 launch type.\nAccepted values are positive integers.", - "stability": "experimental", - "summary": "The total amount of swap memory a container can use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 32 - }, - "name": "maxSwap", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "No shared memory.", - "stability": "experimental", - "summary": "The value for the size of the /dev/shm volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 21 - }, - "name": "sharedMemorySize", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "60", - "remarks": "This parameter\nmaps to the --memory-swappiness option to docker run. The swappiness relates\nto the kernel's tendency to swap memory. A value of 0 will cause swapping to\nnot happen unless absolutely necessary. A value of 100 will cause pages to\nbe swapped very aggressively.\n\nThis parameter is only supported when you are using the EC2 launch type.\nAccepted values are whole numbers between 0 and 100. If a value is not\nspecified for maxSwap then this parameter is ignored.", - "stability": "experimental", - "summary": "This allows you to tune a container's memory swappiness behavior." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 47 - }, - "name": "swappiness", - "optional": true, - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/linux-parameters:LinuxParametersProps" - }, - "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for a ManagedComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 99 - }, - "name": "ManagedComputeEnvironmentProps", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "VPC in which this Compute Environment will launch Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 169 - }, - "name": "vpc", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IVpc" - } - }, - { - "abstract": true, - "docs": { - "default": "256", - "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", - "stability": "experimental", - "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to. Each vCPU is equivalent to 1024 CPU shares." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 111 - }, - "name": "maxvCpus", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", - "see": "https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html", - "stability": "experimental", - "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 132 - }, - "name": "replaceComputeEnvironment", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "new security groups will be created", - "stability": "experimental", - "summary": "The security groups this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 176 - }, - "name": "securityGroups", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", - "stability": "experimental", - "summary": "Whether or not to use spot instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 142 - }, - "name": "spot", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", - "stability": "experimental", - "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 164 - }, - "name": "terminateOnUpdate", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "30 minutes", - "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html", - "stability": "experimental", - "summary": "Only meaningful if `terminateOnUpdate` is `false`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 153 - }, - "name": "updateTimeout", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "If you specify a specific AMI, this property will be ignored.", - "stability": "experimental", - "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 193 - }, - "name": "updateToLatestImageVersion", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "abstract": true, - "docs": { - "default": "new subnets will be created", - "stability": "experimental", - "summary": "The VPC Subnets this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 183 - }, - "name": "vpcSubnets", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.SubnetSelection" - } - } - ], - "symbolId": "lib/managed-compute-environment:ManagedComputeEnvironmentProps" - }, - "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::ComputeEnvironment" - }, - "stability": "experimental", - "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 635 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 588 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "refer to an existing ComputeEnvironment by its arn." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 592 - }, - "name": "fromManagedEc2EcsComputeEnvironmentArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "managedEc2EcsComputeEnvironmentArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Add an instance class to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 705 - }, - "name": "addInstanceClass", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "parameters": [ - { - "name": "instanceClass", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - } - } - ] - }, - { - "docs": { - "stability": "experimental", - "summary": "Add an instance type to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 701 - }, - "name": "addInstanceType", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "parameters": [ - { - "name": "instanceType", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - } - } - ] - } - ], - "name": "ManagedEc2EcsComputeEnvironment", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this compute environment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 619 - }, - "name": "computeEnvironmentArn", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 620 - }, - "name": "computeEnvironmentName", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The network connections associated with this resource." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 210 - }, - "name": "connections", - "overrides": "aws-cdk-lib.aws_ec2.IConnectable", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.Connections" - } - }, - { - "docs": { - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 92 - }, - "name": "enabled", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the size.", - "stability": "experimental", - "summary": "The instance classes that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 627 - }, - "name": "instanceClasses", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 626 - }, - "name": "instanceTypes", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", - "stability": "experimental", - "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 201 - }, - "name": "maxvCpus", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The security groups this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 206 - }, - "name": "securityGroups", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "TagManager to set, remove and format tags." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 208 - }, - "name": "tags", - "overrides": "aws-cdk-lib.ITaggable", - "type": { - "fqn": "aws-cdk-lib.TagManager" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 623 - }, - "name": "allocationStrategy", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" - } - }, - { - "docs": { - "remarks": "Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.", - "stability": "experimental", - "summary": "Configure which AMIs this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 622 - }, - "name": "images", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The execution Role that instances launched by this Compute Environment will use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 628 - }, - "name": "instanceRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", - "stability": "experimental", - "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 629 - }, - "name": "launchTemplate", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 630 - }, - "name": "minvCpus", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", - "stability": "experimental", - "summary": "The EC2 placement group to associate with your compute resources." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 631 - }, - "name": "placementGroup", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" - } - }, - { - "docs": { - "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", - "stability": "experimental", - "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 202 - }, - "name": "replaceComputeEnvironment", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 91 - }, - "name": "serviceRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", - "stability": "experimental", - "summary": "Whether or not to use spot instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 203 - }, - "name": "spot", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.", - "stability": "experimental", - "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 624 - }, - "name": "spotBidPercentage", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 625 - }, - "name": "spotFleetRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedEc2EcsComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", - "stability": "experimental", - "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 205 - }, - "name": "terminateOnUpdate", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", - "stability": "experimental", - "summary": "Only meaningful if `terminateOnUpdate` is `false`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 204 - }, - "name": "updateTimeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "docs": { - "remarks": "If you specify a specific AMI, this property will be ignored.", - "stability": "experimental", - "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 207 - }, - "name": "updateToLatestImageVersion", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:ManagedEc2EcsComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for a ManagedEc2EcsComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironmentProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 469 - }, - "name": "ManagedEc2EcsComputeEnvironmentProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", - "stability": "experimental", - "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 499 - }, - "name": "allocationStrategy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" - } - }, - { - "abstract": true, - "docs": { - "default": "- ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances", - "remarks": "If you specify this property with only `image` specified, then the\n`imageType` will default to `ECS_AL2`. *If your image needs GPU resources,\nspecify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly\njoin the ComputeEnvironment*.", - "stability": "experimental", - "summary": "Configure which AMIs this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 490 - }, - "name": "images", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EcsMachineImage" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the instance size.", - "stability": "experimental", - "summary": "The instance classes that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 539 - }, - "name": "instanceClasses", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- a role will be created", - "stability": "experimental", - "summary": "The execution Role that instances launched by this Compute Environment will use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 546 - }, - "name": "instanceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 530 - }, - "name": "instanceTypes", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "no launch template", - "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", - "stability": "experimental", - "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 559 - }, - "name": "launchTemplate", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" - } - }, - { - "abstract": true, - "docs": { - "default": "0", - "stability": "experimental", - "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 567 - }, - "name": "minvCpus", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no placement group", - "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", - "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", - "stability": "experimental", - "summary": "The EC2 placement group to associate with your compute resources." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 580 - }, - "name": "placementGroup", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" - } - }, - { - "abstract": true, - "docs": { - "default": "100%", - "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", - "stability": "experimental", - "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 513 - }, - "name": "spotBidPercentage", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- a new role will be created", - "see": "https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html", - "stability": "experimental", - "summary": "The service-linked role that Spot Fleet needs to launch instances on your behalf." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 522 - }, - "name": "spotFleetRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", - "stability": "experimental", - "summary": "Whether or not to use batch's optimal instance type." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 478 - }, - "name": "useOptimalInstanceClasses", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:ManagedEc2EcsComputeEnvironmentProps" - }, - "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::ComputeEnvironment" - }, - "stability": "experimental", - "summary": "A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 982 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 963 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Add an instance class to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1052 - }, - "name": "addInstanceClass", - "parameters": [ - { - "name": "instanceClass", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - } - } - ] - }, - { - "docs": { - "stability": "experimental", - "summary": "Add an instance type to this compute environment." - }, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 1048 - }, - "name": "addInstanceType", - "parameters": [ - { - "name": "instanceType", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - } - } - ] - } - ], - "name": "ManagedEc2EksComputeEnvironment", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this compute environment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 968 - }, - "name": "computeEnvironmentArn", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 967 - }, - "name": "computeEnvironmentName", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The network connections associated with this resource." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 210 - }, - "name": "connections", - "overrides": "aws-cdk-lib.aws_ec2.IConnectable", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.Connections" - } - }, - { - "docs": { - "remarks": "Please ensure that you have followed the steps at\n\nhttps://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n\nbefore attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\nIf you do not follow the steps in the link, the deployment fail with a message that the\ncompute environment did not stabilize.", - "stability": "experimental", - "summary": "The cluster that backs this Compute Environment. Required for Compute Environments running Kubernetes jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 965 - }, - "name": "eksCluster", - "type": { - "fqn": "aws-cdk-lib.aws_eks.ICluster" - } - }, - { - "docs": { - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 92 - }, - "name": "enabled", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 974 - }, - "name": "instanceClasses", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 973 - }, - "name": "instanceTypes", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "*Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n`AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\nThe scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\nor `instanceClasses`.", - "stability": "experimental", - "summary": "The maximum vCpus this `ManagedComputeEnvironment` can scale up to." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 201 - }, - "name": "maxvCpus", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The security groups this Compute Environment will launch instances in." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 206 - }, - "name": "securityGroups", - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.ISecurityGroup" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "TagManager to set, remove and format tags." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 208 - }, - "name": "tags", - "overrides": "aws-cdk-lib.ITaggable", - "type": { - "fqn": "aws-cdk-lib.TagManager" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 971 - }, - "name": "allocationStrategy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Configure which AMIs this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 970 - }, - "name": "images", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The execution Role that instances launched by this Compute Environment will use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 975 - }, - "name": "instanceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "Cannot be 'default', start with 'kube-', or be longer than 64 characters.", - "stability": "experimental", - "summary": "The namespace of the Cluster." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 964 - }, - "name": "kubernetesNamespace", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.", - "stability": "experimental", - "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 976 - }, - "name": "launchTemplate", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 977 - }, - "name": "minvCpus", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", - "stability": "experimental", - "summary": "The EC2 placement group to associate with your compute resources." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 978 - }, - "name": "placementGroup", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" - } - }, - { - "docs": { - "remarks": "To enable more properties to be updated,\nset this property to `false`. When changing the value of this property to false,\ndo not change any other properties at the same time.\nIf other properties are changed at the same time,\nand the change needs to be rolled back but it can't,\nit's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\nYou can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\nHowever, if you can continue to roll it back,\nyou can return the stack to its original settings and then try to update it again.\n\nThe properties which require a replacement of the Compute Environment are:", - "stability": "experimental", - "summary": "Specifies whether this Compute Environment is replaced if an update is made that requires replacing its instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 202 - }, - "name": "replaceComputeEnvironment", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 91 - }, - "name": "serviceRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "Spot instances are less expensive EC2 instances that can be\nreclaimed by EC2 at any time; your job will be given two minutes\nof notice before reclamation.", - "stability": "experimental", - "summary": "Whether or not to use spot instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 203 - }, - "name": "spot", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", - "stability": "experimental", - "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 972 - }, - "name": "spotBidPercentage", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "If this is enabled, any terminated jobs may be retried, depending on the job's\nretry policy.", - "stability": "experimental", - "summary": "Whether or not any running jobs will be immediately terminated when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 205 - }, - "name": "terminateOnUpdate", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "If so,\nwhen an infrastructure update is triggered, any running jobs\nwill be allowed to run until `updateTimeout` has expired.", - "stability": "experimental", - "summary": "Only meaningful if `terminateOnUpdate` is `false`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 204 - }, - "name": "updateTimeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - }, - { - "docs": { - "remarks": "If you specify a specific AMI, this property will be ignored.", - "stability": "experimental", - "summary": "Whether or not the AMI is updated to the latest one supported by Batch when an infrastructure update occurs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 207 - }, - "name": "updateToLatestImageVersion", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IManagedComputeEnvironment", - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:ManagedEc2EksComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props for a ManagedEc2EksComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironmentProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ManagedComputeEnvironmentProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 835 - }, - "name": "ManagedEc2EksComputeEnvironmentProps", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "Please ensure that you have followed the steps at\n\nhttps://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n\nbefore attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\nIf you do not follow the steps in the link, the deployment fail with a message that the\ncompute environment did not stabilize.", - "stability": "experimental", - "summary": "The cluster that backs this Compute Environment. Required for Compute Environments running Kubernetes jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 853 - }, - "name": "eksCluster", - "type": { - "fqn": "aws-cdk-lib.aws_eks.ICluster" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The namespace of the Cluster." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 839 - }, - "name": "kubernetesNamespace", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n`SPOT_CAPACITY_OPTIMIZED` if using Spot instances.", - "stability": "experimental", - "summary": "The allocation strategy to use if not enough instances of the best fitting instance type can be allocated." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 883 - }, - "name": "allocationStrategy", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.AllocationStrategy" - } - }, - { - "abstract": true, - "docs": { - "default": "If `imageKubernetesVersion` is specified,\n- EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\nOtherwise,\n- ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances,", - "stability": "experimental", - "summary": "Configure which AMIs this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 874 - }, - "name": "images", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.EksMachineImage" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.\nBatch will automatically choose the instance size.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 914 - }, - "name": "instanceClasses", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceClass" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- a role will be created", - "stability": "experimental", - "summary": "The execution Role that instances launched by this Compute Environment will use." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 921 - }, - "name": "instanceRole", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "abstract": true, - "docs": { - "default": "- the instances Batch considers will be used (currently C4, M4, and R4)", - "remarks": "Which one is chosen depends on the `AllocationStrategy` used.", - "stability": "experimental", - "summary": "The instance types that this Compute Environment can launch." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 905 - }, - "name": "instanceTypes", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "- no launch template", - "remarks": "*Note*: if `securityGroups` is specified on both your\nlaunch template and this Compute Environment, **the\n`securityGroup`s on the Compute Environment override the\nones on the launch template.**", - "stability": "experimental", - "summary": "The Launch Template that this Compute Environment will use to provision EC2 Instances." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 934 - }, - "name": "launchTemplate", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.ILaunchTemplate" - } - }, - { - "abstract": true, - "docs": { - "default": "0", - "stability": "experimental", - "summary": "The minimum vCPUs that an environment should maintain, even if the compute environment is DISABLED." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 942 - }, - "name": "minvCpus", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "- no placement group", - "remarks": "If you intend to submit multi-node parallel jobs to this Compute Environment,\nyou should consider creating a cluster placement group and associate it with your compute resources.\nThis keeps your multi-node parallel job on a logical grouping of instances\nwithin a single Availability Zone with high network flow potential.", - "see": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html", - "stability": "experimental", - "summary": "The EC2 placement group to associate with your compute resources." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 955 - }, - "name": "placementGroup", - "optional": true, - "type": { - "fqn": "aws-cdk-lib.aws_ec2.IPlacementGroup" - } - }, - { - "abstract": true, - "docs": { - "default": "- 100%", - "remarks": "For example, if your maximum percentage is 20%, the Spot price must be\nless than 20% of the current On-Demand price for that Instance.\nYou always pay the lowest market price and never more than your maximum percentage.\nFor most use cases, Batch recommends leaving this field empty.\n\nImplies `spot == true` if set", - "stability": "experimental", - "summary": "The maximum percentage that a Spot Instance price can be when compared with the On-Demand price for that instance type before instances are launched." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 897 - }, - "name": "spotBidPercentage", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "remarks": "The optimal instance type is equivalent to adding the\nC4, M4, and R4 instance classes. You can specify other instance classes\n(of the same architecture) in addition to the optimal instance classes.", - "stability": "experimental", - "summary": "Whether or not to use batch's optimal instance type." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/managed-compute-environment.ts", - "line": 863 - }, - "name": "useOptimalInstanceClasses", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/managed-compute-environment:ManagedEc2EksComputeEnvironmentProps" - }, - "@aws-cdk/aws-batch-alpha.MultiNodeContainer": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Runs the container on nodes [startNode, endNode]." - }, - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer", - "kind": "interface", - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 47 - }, - "name": "MultiNodeContainer", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The container that this node range will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 65 - }, - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IEcsContainerDefinition" - } - }, - { - "abstract": true, - "docs": { - "remarks": "The container is run on all nodes in the range [startNode, endNode] (inclusive)", - "stability": "experimental", - "summary": "The index of the last node to run this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 60 - }, - "name": "endNode", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "remarks": "The container is run on all nodes in the range [startNode, endNode] (inclusive)", - "stability": "experimental", - "summary": "The index of the first node to run this container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 53 - }, - "name": "startNode", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/multinode-job-definition:MultiNodeContainer" - }, - "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::JobDefinition" - }, - "stability": "experimental", - "summary": "A JobDefinition that uses Ecs orchestration to run multiple containers." - }, - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 134 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IJobDefinition" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 109 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "refer to an existing JobDefinition by its arn." - }, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 113 - }, - "name": "fromJobDefinitionArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "jobDefinitionArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IJobDefinition" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a container to this multinode job." - }, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 174 - }, - "name": "addContainer", - "parameters": [ - { - "name": "container", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" - } - } - ] - }, - { - "docs": { - "stability": "experimental", - "summary": "Add a RetryStrategy to this JobDefinition." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 259 - }, - "name": "addRetryStrategy", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "parameters": [ - { - "name": "strategy", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - } - } - ] - } - ], - "name": "MultiNodeJobDefinition", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The containers that this multinode job will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 126 - }, - "name": "containers", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" - }, - "kind": "array" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The instance type that this job definition will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 127 - }, - "name": "instanceType", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 131 - }, - "name": "jobDefinitionArn", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 132 - }, - "name": "jobDefinitionName", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Defines the retry behavior for this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 243 - }, - "name": "retryStrategies", - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - }, - "kind": "array" - } - } - }, - { - "docs": { - "remarks": "The main node is responsible for orchestration.", - "stability": "experimental", - "summary": "The index of the main node in this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 128 - }, - "name": "mainNode", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The default parameters passed to the container These parameters can be referenced in the `command` that you give to the container." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 241 - }, - "name": "parameters", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "collection": { - "elementtype": { - "primitive": "any" - }, - "kind": "map" - } - } - }, - { - "docs": { - "stability": "experimental", - "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 129 - }, - "name": "propagateTags", - "optional": true, - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "remarks": "The job is retried on failure the same number of attempts as the value.", - "stability": "experimental", - "summary": "The number of times to retry a job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 242 - }, - "name": "retryAttempts", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "Only used in Fairshare Scheduling\nto decide which job to run first when there are multiple jobs\nwith the same share identifier.", - "stability": "experimental", - "summary": "The priority of this Job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 244 - }, - "name": "schedulingPriority", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "primitive": "number" - } - }, - { - "docs": { - "remarks": "After the amount of time you specify passes,\nBatch terminates your jobs if they aren't finished.", - "stability": "experimental", - "summary": "The timeout time for jobs that are submitted with this job definition." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 245 - }, - "name": "timeout", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IJobDefinition", - "type": { - "fqn": "aws-cdk-lib.Duration" - } - } - ], - "symbolId": "lib/multinode-job-definition:MultiNodeJobDefinition" - }, - "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Props to configure a MultiNodeJobDefinition." - }, - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinitionProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.JobDefinitionProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 71 - }, - "name": "MultiNodeJobDefinitionProps", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The instance type that this job definition will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 76 - }, - "name": "instanceType", - "type": { - "fqn": "aws-cdk-lib.aws_ec2.InstanceType" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "see": "https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/", - "stability": "experimental", - "summary": "The containers that this multinode job will run." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 85 - }, - "name": "containers", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.MultiNodeContainer" - }, - "kind": "array" - } - } - }, - { - "abstract": true, - "docs": { - "default": "0", - "remarks": "The main node is responsible for orchestration.", - "stability": "experimental", - "summary": "The index of the main node in this job." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 93 - }, - "name": "mainNode", - "optional": true, - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "default": "false", - "stability": "experimental", - "summary": "Whether to propogate tags from the JobDefinition to the ECS task that Batch spawns." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/multinode-job-definition.ts", - "line": 101 - }, - "name": "propagateTags", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/multinode-job-definition:MultiNodeJobDefinitionProps" - }, - "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "remarks": "The JobQueue will prioritize the lowest-order ComputeEnvironment.", - "stability": "experimental", - "summary": "Assigns an order to a ComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.OrderedComputeEnvironment", - "kind": "interface", - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 126 - }, - "name": "OrderedComputeEnvironment", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The ComputeEnvironment to link to this JobQueue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 130 - }, - "name": "computeEnvironment", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The order associated with `computeEnvironment`." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-queue.ts", - "line": 135 - }, - "name": "order", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/job-queue:OrderedComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.Reason": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Common job exit reasons." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Reason", - "initializer": { - "docs": { - "stability": "experimental" - } - }, - "kind": "class", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 201 - }, - "methods": [ - { - "docs": { - "remarks": "Note that all specified conditions must be met for this reason to match.", - "stability": "experimental", - "summary": "A custom Reason that can match on multiple conditions." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 227 - }, - "name": "custom", - "parameters": [ - { - "name": "customReasonProps", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.CustomReason" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - }, - "static": true - } - ], - "name": "Reason", - "properties": [ - { - "const": true, - "docs": { - "stability": "experimental", - "summary": "Will only match if the Docker container could not be pulled." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 212 - }, - "name": "CANNOT_PULL_CONTAINER", - "static": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - }, - { - "const": true, - "docs": { - "stability": "experimental", - "summary": "Will match any non-zero exit code." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 205 - }, - "name": "NON_ZERO_EXIT_CODE", - "static": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - }, - { - "const": true, - "docs": { - "stability": "experimental", - "summary": "Will only match if the Spot instance executing the job was reclaimed." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 219 - }, - "name": "SPOT_INSTANCE_RECLAIMED", - "static": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - } - ], - "symbolId": "lib/job-definition-base:Reason" - }, - "@aws-cdk/aws-batch-alpha.RetryStrategy": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "Define how Jobs using this JobDefinition respond to different exit conditions." - }, - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 150 - }, - "parameters": [ - { - "name": "action", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Action" - } - }, - { - "name": "on", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 132 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Create a new RetryStrategy." - }, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 136 - }, - "name": "of", - "parameters": [ - { - "name": "action", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Action" - } - }, - { - "name": "on", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.RetryStrategy" - } - }, - "static": true - } - ], - "name": "RetryStrategy", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The action to take when the job exits with the Reason specified." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 143 - }, - "name": "action", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Action" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "If the job exits with this Reason it will trigger the specified Action." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/job-definition-base.ts", - "line": 148 - }, - "name": "on", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Reason" - } - } - ], - "symbolId": "lib/job-definition-base:RetryStrategy" - }, - "@aws-cdk/aws-batch-alpha.Secret": { - "abstract": true, - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "A secret environment variable." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Secret", - "initializer": { - "docs": { - "stability": "experimental" - } - }, - "kind": "class", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 36 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Creates a environment variable value from a secret stored in AWS Secrets Manager." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 58 - }, - "name": "fromSecretsManager", - "parameters": [ - { - "docs": { - "summary": "the secret stored in AWS Secrets Manager." - }, - "name": "secret", - "type": { - "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret" - } - }, - { - "docs": { - "remarks": "Only values in JSON format are supported.\nIf you do not specify a JSON field, then the full content of the secret is\nused.", - "summary": "the name of the field with the value that you want to set as the environment variable value." - }, - "name": "field", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Creates a environment variable value from a secret stored in AWS Secrets Manager." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 77 - }, - "name": "fromSecretsManagerVersion", - "parameters": [ - { - "docs": { - "summary": "the secret stored in AWS Secrets Manager." - }, - "name": "secret", - "type": { - "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret" - } - }, - { - "docs": { - "summary": "the version information to reference the secret." - }, - "name": "versionInfo", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.SecretVersionInfo" - } - }, - { - "docs": { - "remarks": "Only values in JSON format are supported.\nIf you do not specify a JSON field, then the full content of the secret is\nused.", - "summary": "the name of the field with the value that you want to set as the environment variable value." - }, - "name": "field", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - } - }, - "static": true - }, - { - "docs": { - "stability": "experimental", - "summary": "Creates an environment variable value from a parameter stored in AWS Systems Manager Parameter Store." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 41 - }, - "name": "fromSsmParameter", - "parameters": [ - { - "name": "parameter", - "type": { - "fqn": "aws-cdk-lib.aws_ssm.IParameter" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.Secret" - } - }, - "static": true - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Grants reading the secret to a principal." - }, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 98 - }, - "name": "grantRead", - "parameters": [ - { - "name": "grantee", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IGrantable" - } - } - ], - "returns": { - "type": { - "fqn": "aws-cdk-lib.aws_iam.Grant" - } - } - } - ], - "name": "Secret", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The ARN of the secret." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 88 - }, - "name": "arn", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "Whether this secret uses a specific JSON field." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 93 - }, - "name": "hasField", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/ecs-container-definition:Secret" - }, - "@aws-cdk/aws-batch-alpha.SecretPathVolume": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "@aws-cdk/aws-batch-alpha.EksVolume", - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", - "stability": "experimental", - "summary": "Specifies the configuration of a Kubernetes secret volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolume", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 902 - }, - "parameters": [ - { - "name": "options", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions" - } - } - ] - }, - "kind": "class", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 879 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "returns `true` if `x` is a `SecretPathVolume` and `false` otherwise." - }, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 883 - }, - "name": "isSecretPathVolume", - "parameters": [ - { - "name": "x", - "type": { - "primitive": "any" - } - } - ], - "returns": { - "type": { - "primitive": "boolean" - } - }, - "static": true - } - ], - "name": "SecretPathVolume", - "properties": [ - { - "docs": { - "remarks": "Must be a valid DNS subdomain name.", - "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", - "stability": "experimental", - "summary": "The name of the secret." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 893 - }, - "name": "secretName", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "default": "true", - "stability": "experimental", - "summary": "Specifies whether the secret or the secret's keys must be defined." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 900 - }, - "name": "optional", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-container-definition:SecretPathVolume" - }, - "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "see": "https://kubernetes.io/docs/concepts/storage/volumes/#secret", - "stability": "experimental", - "summary": "Options for a Kubernetes SecretPath Volume." - }, - "fqn": "@aws-cdk/aws-batch-alpha.SecretPathVolumeOptions", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.EksVolumeOptions" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 857 - }, - "name": "SecretPathVolumeOptions", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "Must be a valid DNS subdomain name.", - "see": "https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names", - "stability": "experimental", - "summary": "The name of the secret." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 864 - }, - "name": "secretName", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "true", - "stability": "experimental", - "summary": "Specifies whether the secret or the secret's keys must be defined." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/eks-container-definition.ts", - "line": 871 - }, - "name": "optional", - "optional": true, - "type": { - "primitive": "boolean" - } - } - ], - "symbolId": "lib/eks-container-definition:SecretPathVolumeOptions" - }, - "@aws-cdk/aws-batch-alpha.SecretVersionInfo": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "Specify the secret's version id or version stage." - }, - "fqn": "@aws-cdk/aws-batch-alpha.SecretVersionInfo", - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 18 - }, - "name": "SecretVersionInfo", - "properties": [ - { - "abstract": true, - "docs": { - "default": "- use default version id", - "stability": "experimental", - "summary": "version id of the secret." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 24 - }, - "name": "versionId", - "optional": true, - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "default": "- use default version stage", - "stability": "experimental", - "summary": "version stage of the secret." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 30 - }, - "name": "versionStage", - "optional": true, - "type": { - "primitive": "string" - } - } - ], - "symbolId": "lib/ecs-container-definition:SecretVersionInfo" - }, - "@aws-cdk/aws-batch-alpha.Share": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "remarks": "All Job Definitions that\ndeclare a share identifier will be considered members of the Share\ndefined by that share identifier.\n\nThe Scheduler divides the maximum available vCPUs of the ComputeEnvironment\namong Jobs in the Queue based on their shareIdentifier and the weightFactor\nassociated with that shareIdentifier.", - "stability": "experimental", - "summary": "Represents a group of Job Definitions." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Share", - "kind": "interface", - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 60 - }, - "name": "Share", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "All jobs that specify this share identifier\nwhen submitted to the queue will be considered as part of this Share.", - "stability": "experimental", - "summary": "The identifier of this Share." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 65 - }, - "name": "shareIdentifier", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "remarks": "The Scheduler decides which jobs to put in the Compute Environment\nsuch that the following ratio is equal for each job:\n\n`sharevCpu / weightFactor`,\n\nwhere `sharevCpu` is the total amount of vCPU given to that particular share; that is,\nthe sum of the vCPU of each job currently in the Compute Environment for that share.\n\nSee the readme of this module for a detailed example that shows how these are used,\nhow it relates to `computeReservation`, and how `shareDecay` affects these calculations.", - "stability": "experimental", - "summary": "The weight factor given to this Share." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/scheduling-policy.ts", - "line": 79 - }, - "name": "weightFactor", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/scheduling-policy:Share" - }, - "@aws-cdk/aws-batch-alpha.Tmpfs": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "stability": "experimental", - "summary": "The details of a tmpfs mount for a container." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Tmpfs", - "kind": "interface", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 168 - }, - "name": "Tmpfs", - "properties": [ - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The absolute file path where the tmpfs volume is to be mounted." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 172 - }, - "name": "containerPath", - "type": { - "primitive": "string" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The size (in MiB) of the tmpfs volume." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 177 - }, - "name": "size", - "type": { - "fqn": "aws-cdk-lib.Size" - } - }, - { - "abstract": true, - "docs": { - "default": "none", - "remarks": "For more information, see\n[TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).", - "stability": "experimental", - "summary": "The list of tmpfs volume mount options." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 185 - }, - "name": "mountOptions", - "optional": true, - "type": { - "collection": { - "elementtype": { - "fqn": "@aws-cdk/aws-batch-alpha.TmpfsMountOption" - }, - "kind": "array" - } - } - } - ], - "symbolId": "lib/linux-parameters:Tmpfs" - }, - "@aws-cdk/aws-batch-alpha.TmpfsMountOption": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "The supported options for a tmpfs mount for a container." - }, - "fqn": "@aws-cdk/aws-batch-alpha.TmpfsMountOption", - "kind": "enum", - "locationInModule": { - "filename": "lib/linux-parameters.ts", - "line": 211 - }, - "members": [ - { - "docs": { - "stability": "experimental" - }, - "name": "DEFAULTS" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RO" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RW" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "SUID" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NOSUID" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "DEV" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NODEV" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "EXEC" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NOEXEC" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "SYNC" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "ASYNC" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "DIRSYNC" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "REMOUNT" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "MAND" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NOMAND" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "ATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NOATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "DIRATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NODIRATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "BIND" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RBIND" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "UNBINDABLE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RUNBINDABLE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "PRIVATE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RPRIVATE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "SHARED" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RSHARED" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "SLAVE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RSLAVE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "RELATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NORELATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "STRICTATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NOSTRICTATIME" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "MODE" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "UID" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "GID" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NR_INODES" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "NR_BLOCKS" - }, - { - "docs": { - "stability": "experimental" - }, - "name": "MPOL" - } - ], - "name": "TmpfsMountOption", - "symbolId": "lib/linux-parameters:TmpfsMountOption" - }, - "@aws-cdk/aws-batch-alpha.Ulimit": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "remarks": "Used by the Docker daemon.", - "stability": "experimental", - "summary": "Sets limits for a resource with `ulimit` on linux systems." - }, - "fqn": "@aws-cdk/aws-batch-alpha.Ulimit", - "kind": "interface", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 734 - }, - "name": "Ulimit", - "properties": [ - { - "abstract": true, - "docs": { - "remarks": "The container will\nbe terminated if it exceeds this limit.", - "stability": "experimental", - "summary": "The hard limit for this resource." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 739 - }, - "name": "hardLimit", - "type": { - "primitive": "number" - } - }, - { - "abstract": true, - "docs": { - "stability": "experimental", - "summary": "The resource to limit." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 744 - }, - "name": "name", - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.UlimitName" - } - }, - { - "abstract": true, - "docs": { - "remarks": "The container will\nnot be terminated if it exceeds this limit.", - "stability": "experimental", - "summary": "The reservation for this resource." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 750 - }, - "name": "softLimit", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/ecs-container-definition:Ulimit" - }, - "@aws-cdk/aws-batch-alpha.UlimitName": { - "assembly": "@aws-cdk/aws-batch-alpha", - "docs": { - "stability": "experimental", - "summary": "The resources to be limited." - }, - "fqn": "@aws-cdk/aws-batch-alpha.UlimitName", - "kind": "enum", - "locationInModule": { - "filename": "lib/ecs-container-definition.ts", - "line": 756 - }, - "members": [ - { - "docs": { - "stability": "experimental", - "summary": "max core dump file size." - }, - "name": "CORE" - }, - { - "docs": { - "stability": "experimental", - "summary": "max cpu time (seconds) for a process." - }, - "name": "CPU" - }, - { - "docs": { - "stability": "experimental", - "summary": "max data segment size." - }, - "name": "DATA" - }, - { - "docs": { - "stability": "experimental", - "summary": "max file size." - }, - "name": "FSIZE" - }, - { - "docs": { - "stability": "experimental", - "summary": "max number of file locks." - }, - "name": "LOCKS" - }, - { - "docs": { - "stability": "experimental", - "summary": "max locked memory." - }, - "name": "MEMLOCK" - }, - { - "docs": { - "stability": "experimental", - "summary": "max POSIX message queue size." - }, - "name": "MSGQUEUE" - }, - { - "docs": { - "stability": "experimental", - "summary": "max nice value for any process this user is running." - }, - "name": "NICE" - }, - { - "docs": { - "stability": "experimental", - "summary": "maximum number of open file descriptors." - }, - "name": "NOFILE" - }, - { - "docs": { - "stability": "experimental", - "summary": "maximum number of processes." - }, - "name": "NPROC" - }, - { - "docs": { - "stability": "experimental", - "summary": "size of the process' resident set (in pages)." - }, - "name": "RSS" - }, - { - "docs": { - "stability": "experimental", - "summary": "max realtime priority." - }, - "name": "RTPRIO" - }, - { - "docs": { - "stability": "experimental", - "summary": "timeout for realtime tasks." - }, - "name": "RTTIME" - }, - { - "docs": { - "stability": "experimental", - "summary": "max number of pending signals." - }, - "name": "SIGPENDING" - }, - { - "docs": { - "stability": "experimental", - "summary": "max stack size (in bytes)." - }, - "name": "STACK" - } - ], - "name": "UlimitName", - "symbolId": "lib/ecs-container-definition:UlimitName" - }, - "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment": { - "assembly": "@aws-cdk/aws-batch-alpha", - "base": "aws-cdk-lib.Resource", - "docs": { - "custom": { - "resource": "AWS::Batch::ComputeEnvironment" - }, - "stability": "experimental", - "summary": "Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf." - }, - "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment", - "initializer": { - "docs": { - "stability": "experimental" - }, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 68 - }, - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "props", - "optional": true, - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps" - } - } - ] - }, - "interfaces": [ - "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", - "@aws-cdk/aws-batch-alpha.IComputeEnvironment" - ], - "kind": "class", - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 44 - }, - "methods": [ - { - "docs": { - "stability": "experimental", - "summary": "Import an UnmanagedComputeEnvironment by its arn." - }, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 48 - }, - "name": "fromUnmanagedComputeEnvironmentArn", - "parameters": [ - { - "name": "scope", - "type": { - "fqn": "constructs.Construct" - } - }, - { - "name": "id", - "type": { - "primitive": "string" - } - }, - { - "name": "unmanagedComputeEnvironmentArn", - "type": { - "primitive": "string" - } - } - ], - "returns": { - "type": { - "fqn": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment" - } - }, - "static": true - } - ], - "name": "UnmanagedComputeEnvironment", - "properties": [ - { - "docs": { - "stability": "experimental", - "summary": "The ARN of this compute environment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 65 - }, - "name": "computeEnvironmentArn", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The name of the ComputeEnvironment." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 66 - }, - "name": "computeEnvironmentName", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "string" - } - }, - { - "docs": { - "remarks": "Enabled ComputeEnvironments can accept jobs from a Queue and\ncan scale instances up or down.\nDisabled ComputeEnvironments cannot accept jobs from a Queue or\nscale instances up or down.\n\nIf you change a ComputeEnvironment from enabled to disabled while it is executing jobs,\nJobs in the `STARTED` or `RUNNING` states will not\nbe interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`.\n\nTo ensure you aren't billed for unused capacity, set `minvCpus` to `0`.", - "stability": "experimental", - "summary": "Whether or not this ComputeEnvironment can accept jobs from a Queue." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 92 - }, - "name": "enabled", - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "primitive": "boolean" - } - }, - { - "docs": { - "stability": "experimental", - "summary": "The role Batch uses to perform actions on your behalf in your account, such as provision instances to run your jobs." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/compute-environment-base.ts", - "line": 91 - }, - "name": "serviceRole", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IComputeEnvironment", - "type": { - "fqn": "aws-cdk-lib.aws_iam.IRole" - } - }, - { - "docs": { - "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", - "stability": "experimental", - "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 64 - }, - "name": "unmanagedvCPUs", - "optional": true, - "overrides": "@aws-cdk/aws-batch-alpha.IUnmanagedComputeEnvironment", - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/unmanaged-compute-environment:UnmanagedComputeEnvironment" - }, - "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps": { - "assembly": "@aws-cdk/aws-batch-alpha", - "datatype": true, - "docs": { - "remarks": "Batch will not provision instances on your behalf\nin this ComputeEvironment.", - "stability": "experimental", - "summary": "Represents an UnmanagedComputeEnvironment." - }, - "fqn": "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironmentProps", - "interfaces": [ - "@aws-cdk/aws-batch-alpha.ComputeEnvironmentProps" - ], - "kind": "interface", - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 26 - }, - "name": "UnmanagedComputeEnvironmentProps", - "properties": [ - { - "abstract": true, - "docs": { - "default": "0", - "remarks": "**If this parameter is not provided on a fairshare queue, no capacity is reserved**;\nthat is, the `FairshareSchedulingPolicy` is ignored.", - "stability": "experimental", - "summary": "The vCPUs this Compute Environment provides. Used only by the scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s." - }, - "immutable": true, - "locationInModule": { - "filename": "lib/unmanaged-compute-environment.ts", - "line": 36 - }, - "name": "unmanagedvCpus", - "optional": true, - "type": { - "primitive": "number" - } - } - ], - "symbolId": "lib/unmanaged-compute-environment:UnmanagedComputeEnvironmentProps" - } - }, - "version": "0.0.0", - "fingerprint": "oTncRAlRM55jMKT9Vxi1eKfuNXfCgiLRFVfCY18w+gM=" -} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js b/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js deleted file mode 100644 index 204b2b9e6ead6..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/.warnings.jsii.js +++ /dev/null @@ -1,515 +0,0 @@ -function _aws_cdk_aws_batch_alpha_IComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_ComputeEnvironmentProps(p) { -} -function _aws_cdk_aws_batch_alpha_EcsJobDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.container)) - _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p.container); - if (p.retryStrategies != null) - for (const o of p.retryStrategies) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_RetryStrategy(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EcsJobDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_IEksJobDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_EksJobDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.container)) - _aws_cdk_aws_batch_alpha_EksContainerDefinition(p.container); - if (!visitedObjects.has(p.dnsPolicy)) - _aws_cdk_aws_batch_alpha_DnsPolicy(p.dnsPolicy); - if (p.retryStrategies != null) - for (const o of p.retryStrategies) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_RetryStrategy(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_DnsPolicy(p) { -} -function _aws_cdk_aws_batch_alpha_EksJobDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_SecretVersionInfo(p) { -} -function _aws_cdk_aws_batch_alpha_Secret(p) { -} -function _aws_cdk_aws_batch_alpha_EcsVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_EcsVolume(p) { -} -function _aws_cdk_aws_batch_alpha_EfsVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_EfsVolume(p) { -} -function _aws_cdk_aws_batch_alpha_HostVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_HostVolume(p) { -} -function _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_EcsContainerDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.linuxParameters)) - _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); - if (p.secrets != null) - for (const o of Object.values(p.secrets)) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_Secret(o); - if (p.volumes != null) - for (const o of p.volumes) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EcsVolume(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_Ulimit(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.name)) - _aws_cdk_aws_batch_alpha_UlimitName(p.name); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_UlimitName(p) { -} -function _aws_cdk_aws_batch_alpha_IEcsEc2ContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.ulimits != null) - for (const o of p.ulimits) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_Ulimit(o); - if (!visitedObjects.has(p.linuxParameters)) - _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); - if (p.secrets != null) - for (const o of Object.values(p.secrets)) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_Secret(o); - if (p.volumes != null) - for (const o of p.volumes) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EcsVolume(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_IEcsFargateContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.linuxParameters)) - _aws_cdk_aws_batch_alpha_LinuxParameters(p.linuxParameters); - if (p.secrets != null) - for (const o of Object.values(p.secrets)) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_Secret(o); - if (p.volumes != null) - for (const o of p.volumes) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EcsVolume(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_IEksContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_ImagePullPolicy(p) { -} -function _aws_cdk_aws_batch_alpha_EksContainerDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.imagePullPolicy)) - _aws_cdk_aws_batch_alpha_ImagePullPolicy(p.imagePullPolicy); - if (p.volumes != null) - for (const o of p.volumes) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EksVolume(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EksContainerDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_EksVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_EksVolume(p) { -} -function _aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.medium)) - _aws_cdk_aws_batch_alpha_EmptyDirMediumType(p.medium); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EmptyDirMediumType(p) { -} -function _aws_cdk_aws_batch_alpha_EmptyDirVolume(p) { -} -function _aws_cdk_aws_batch_alpha_HostPathVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_HostPathVolume(p) { -} -function _aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(p) { -} -function _aws_cdk_aws_batch_alpha_SecretPathVolume(p) { -} -function _aws_cdk_aws_batch_alpha_IJobDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_JobDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.retryStrategies != null) - for (const o of p.retryStrategies) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_RetryStrategy(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_RetryStrategy(p) { -} -function _aws_cdk_aws_batch_alpha_Action(p) { -} -function _aws_cdk_aws_batch_alpha_CustomReason(p) { -} -function _aws_cdk_aws_batch_alpha_Reason(p) { -} -function _aws_cdk_aws_batch_alpha_IJobQueue(p) { -} -function _aws_cdk_aws_batch_alpha_JobQueueProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.computeEnvironments != null) - for (const o of p.computeEnvironments) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment(o); - if (!visitedObjects.has(p.schedulingPolicy)) - _aws_cdk_aws_batch_alpha_ISchedulingPolicy(p.schedulingPolicy); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.computeEnvironment)) - _aws_cdk_aws_batch_alpha_IComputeEnvironment(p.computeEnvironment); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_JobQueue(p) { -} -function _aws_cdk_aws_batch_alpha_LinuxParametersProps(p) { -} -function _aws_cdk_aws_batch_alpha_LinuxParameters(p) { -} -function _aws_cdk_aws_batch_alpha_Device(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.permissions != null) - for (const o of p.permissions) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_DevicePermission(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_Tmpfs(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.mountOptions != null) - for (const o of p.mountOptions) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_TmpfsMountOption(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_DevicePermission(p) { -} -function _aws_cdk_aws_batch_alpha_TmpfsMountOption(p) { -} -function _aws_cdk_aws_batch_alpha_IManagedComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_ManagedComputeEnvironmentProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.securityGroups != null) - for (const o of p.securityGroups) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_IManagedEc2EcsComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_EcsMachineImage(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.imageType)) - _aws_cdk_aws_batch_alpha_EcsMachineImageType(p.imageType); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EksMachineImage(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.imageType)) - _aws_cdk_aws_batch_alpha_EksMachineImageType(p.imageType); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_EcsMachineImageType(p) { -} -function _aws_cdk_aws_batch_alpha_EksMachineImageType(p) { -} -function _aws_cdk_aws_batch_alpha_AllocationStrategy(p) { -} -function _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.allocationStrategy)) - _aws_cdk_aws_batch_alpha_AllocationStrategy(p.allocationStrategy); - if (p.images != null) - for (const o of p.images) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EcsMachineImage(o); - if (p.instanceClasses != null) - for (const o of p.instanceClasses) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceClass(o); - if (p.instanceTypes != null) - for (const o of p.instanceTypes) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceType(o); - if (p.securityGroups != null) - for (const o of p.securityGroups) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.allocationStrategy)) - _aws_cdk_aws_batch_alpha_AllocationStrategy(p.allocationStrategy); - if (p.images != null) - for (const o of p.images) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_EksMachineImage(o); - if (p.instanceClasses != null) - for (const o of p.instanceClasses) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceClass(o); - if (p.instanceTypes != null) - for (const o of p.instanceTypes) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_InstanceType(o); - if (p.securityGroups != null) - for (const o of p.securityGroups) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_IFargateComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.securityGroups != null) - for (const o of p.securityGroups) - if (!visitedObjects.has(o)) - require("aws-cdk-lib/.warnings.jsii.js").aws_cdk_lib_aws_ec2_ISecurityGroup(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_FargateComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_MultiNodeContainer(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (!visitedObjects.has(p.container)) - _aws_cdk_aws_batch_alpha_IEcsContainerDefinition(p.container); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.containers != null) - for (const o of p.containers) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_MultiNodeContainer(o); - if (p.retryStrategies != null) - for (const o of p.retryStrategies) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_RetryStrategy(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_MultiNodeJobDefinition(p) { -} -function _aws_cdk_aws_batch_alpha_ISchedulingPolicy(p) { -} -function _aws_cdk_aws_batch_alpha_Share(p) { -} -function _aws_cdk_aws_batch_alpha_IFairshareSchedulingPolicy(p) { -} -function _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps(p) { - if (p == null) - return; - visitedObjects.add(p); - try { - if (p.shares != null) - for (const o of p.shares) - if (!visitedObjects.has(o)) - _aws_cdk_aws_batch_alpha_Share(o); - } - finally { - visitedObjects.delete(p); - } -} -function _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicy(p) { -} -function _aws_cdk_aws_batch_alpha_IUnmanagedComputeEnvironment(p) { -} -function _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps(p) { -} -function _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironment(p) { -} -function print(name, deprecationMessage) { - const deprecated = process.env.JSII_DEPRECATED; - const deprecationMode = ["warn", "fail", "quiet"].includes(deprecated) ? deprecated : "warn"; - const message = `${name} is deprecated.\n ${deprecationMessage.trim()}\n This API will be removed in the next major release.`; - switch (deprecationMode) { - case "fail": - throw new DeprecationError(message); - case "warn": - console.warn("[WARNING]", message); - break; - } -} -function getPropertyDescriptor(obj, prop) { - const descriptor = Object.getOwnPropertyDescriptor(obj, prop); - if (descriptor) { - return descriptor; - } - const proto = Object.getPrototypeOf(obj); - const prototypeDescriptor = proto && getPropertyDescriptor(proto, prop); - if (prototypeDescriptor) { - return prototypeDescriptor; - } - return {}; -} -const visitedObjects = new Set(); -class DeprecationError extends Error { - constructor(...args) { - super(...args); - Object.defineProperty(this, "name", { - configurable: false, - enumerable: true, - value: "DeprecationError", - writable: false, - }); - } -} -module.exports = { print, getPropertyDescriptor, DeprecationError, _aws_cdk_aws_batch_alpha_IComputeEnvironment, _aws_cdk_aws_batch_alpha_ComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_EcsJobDefinitionProps, _aws_cdk_aws_batch_alpha_EcsJobDefinition, _aws_cdk_aws_batch_alpha_IEksJobDefinition, _aws_cdk_aws_batch_alpha_EksJobDefinitionProps, _aws_cdk_aws_batch_alpha_DnsPolicy, _aws_cdk_aws_batch_alpha_EksJobDefinition, _aws_cdk_aws_batch_alpha_SecretVersionInfo, _aws_cdk_aws_batch_alpha_Secret, _aws_cdk_aws_batch_alpha_EcsVolumeOptions, _aws_cdk_aws_batch_alpha_EcsVolume, _aws_cdk_aws_batch_alpha_EfsVolumeOptions, _aws_cdk_aws_batch_alpha_EfsVolume, _aws_cdk_aws_batch_alpha_HostVolumeOptions, _aws_cdk_aws_batch_alpha_HostVolume, _aws_cdk_aws_batch_alpha_IEcsContainerDefinition, _aws_cdk_aws_batch_alpha_EcsContainerDefinitionProps, _aws_cdk_aws_batch_alpha_Ulimit, _aws_cdk_aws_batch_alpha_UlimitName, _aws_cdk_aws_batch_alpha_IEcsEc2ContainerDefinition, _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinition, _aws_cdk_aws_batch_alpha_IEcsFargateContainerDefinition, _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EcsFargateContainerDefinition, _aws_cdk_aws_batch_alpha_IEksContainerDefinition, _aws_cdk_aws_batch_alpha_ImagePullPolicy, _aws_cdk_aws_batch_alpha_EksContainerDefinitionProps, _aws_cdk_aws_batch_alpha_EksContainerDefinition, _aws_cdk_aws_batch_alpha_EksVolumeOptions, _aws_cdk_aws_batch_alpha_EksVolume, _aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions, _aws_cdk_aws_batch_alpha_EmptyDirMediumType, _aws_cdk_aws_batch_alpha_EmptyDirVolume, _aws_cdk_aws_batch_alpha_HostPathVolumeOptions, _aws_cdk_aws_batch_alpha_HostPathVolume, _aws_cdk_aws_batch_alpha_SecretPathVolumeOptions, _aws_cdk_aws_batch_alpha_SecretPathVolume, _aws_cdk_aws_batch_alpha_IJobDefinition, _aws_cdk_aws_batch_alpha_JobDefinitionProps, _aws_cdk_aws_batch_alpha_RetryStrategy, _aws_cdk_aws_batch_alpha_Action, _aws_cdk_aws_batch_alpha_CustomReason, _aws_cdk_aws_batch_alpha_Reason, _aws_cdk_aws_batch_alpha_IJobQueue, _aws_cdk_aws_batch_alpha_JobQueueProps, _aws_cdk_aws_batch_alpha_OrderedComputeEnvironment, _aws_cdk_aws_batch_alpha_JobQueue, _aws_cdk_aws_batch_alpha_LinuxParametersProps, _aws_cdk_aws_batch_alpha_LinuxParameters, _aws_cdk_aws_batch_alpha_Device, _aws_cdk_aws_batch_alpha_Tmpfs, _aws_cdk_aws_batch_alpha_DevicePermission, _aws_cdk_aws_batch_alpha_TmpfsMountOption, _aws_cdk_aws_batch_alpha_IManagedComputeEnvironment, _aws_cdk_aws_batch_alpha_ManagedComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_IManagedEc2EcsComputeEnvironment, _aws_cdk_aws_batch_alpha_EcsMachineImage, _aws_cdk_aws_batch_alpha_EksMachineImage, _aws_cdk_aws_batch_alpha_EcsMachineImageType, _aws_cdk_aws_batch_alpha_EksMachineImageType, _aws_cdk_aws_batch_alpha_AllocationStrategy, _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironment, _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironment, _aws_cdk_aws_batch_alpha_IFargateComputeEnvironment, _aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_FargateComputeEnvironment, _aws_cdk_aws_batch_alpha_MultiNodeContainer, _aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps, _aws_cdk_aws_batch_alpha_MultiNodeJobDefinition, _aws_cdk_aws_batch_alpha_ISchedulingPolicy, _aws_cdk_aws_batch_alpha_Share, _aws_cdk_aws_batch_alpha_IFairshareSchedulingPolicy, _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps, _aws_cdk_aws_batch_alpha_FairshareSchedulingPolicy, _aws_cdk_aws_batch_alpha_IUnmanagedComputeEnvironment, _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps, _aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironment }; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts deleted file mode 100644 index 61426345d5a13..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.d.ts +++ /dev/null @@ -1,87 +0,0 @@ -import * as iam from 'aws-cdk-lib/aws-iam'; -import { IResource, Resource } from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -/** - * Represents a ComputeEnvironment - */ -export interface IComputeEnvironment extends IResource { - /** - * The name of the ComputeEnvironment - * - * @attribute - */ - readonly computeEnvironmentName: string; - /** - * The ARN of this compute environment. - * - * @attribute - */ - readonly computeEnvironmentArn: string; - /** - * The role Batch uses to perform actions on your behalf - * in your account, such as provision instances to run your jobs - * - * @default - a serviceRole will be created for managed CEs, none for unmanaged CEs - */ - readonly serviceRole?: iam.IRole; - /** - * Whether or not this ComputeEnvironment can accept jobs from a Queue. - * Enabled ComputeEnvironments can accept jobs from a Queue and - * can scale instances up or down. - * Disabled ComputeEnvironments cannot accept jobs from a Queue or - * scale instances up or down. - * - * If you change a ComputeEnvironment from enabled to disabled while it is executing jobs, - * Jobs in the `STARTED` or `RUNNING` states will not - * be interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`. - * - * To ensure you aren't billed for unused capacity, set `minvCpus` to `0`. - */ - readonly enabled: boolean; -} -/** - * Props common to all ComputeEnvironments - */ -export interface ComputeEnvironmentProps { - /** - * The name of the ComputeEnvironment - * - * @default - generated by CloudFormation - */ - readonly computeEnvironmentName?: string; - /** - * The role Batch uses to perform actions on your behalf - * in your account, such as provision instances to run your jobs - * - * @default - a serviceRole will be created for managed CEs, none for unmanaged CEs - */ - readonly serviceRole?: iam.IRole; - /** - * Whether or not this ComputeEnvironment can accept jobs from a Queue. - * Enabled ComputeEnvironments can accept jobs from a Queue and - * can scale instances up or down. - * Disabled ComputeEnvironments cannot accept jobs from a Queue or - * scale instances up or down. - * - * If you change a ComputeEnvironment from enabled to disabled while it is executing jobs, - * Jobs in the `STARTED` or `RUNNING` states will not - * be interrupted. As jobs complete, the ComputeEnvironment will scale instances down to `minvCpus`. - * - * To ensure you aren't billed for unused capacity, set `minvCpus` to `0`. - * - * @default true - */ - readonly enabled?: boolean; -} -/** - * Abstract base class for ComputeEnvironments - * - * @internal - */ -export declare abstract class ComputeEnvironmentBase extends Resource implements IComputeEnvironment { - abstract readonly computeEnvironmentName: string; - readonly serviceRole?: iam.IRole | undefined; - readonly enabled: boolean; - abstract readonly computeEnvironmentArn: string; - constructor(scope: Construct, id: string, props?: ComputeEnvironmentProps); -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js b/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js deleted file mode 100644 index 4af677e1944ac..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/compute-environment-base.js +++ /dev/null @@ -1,20 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.ComputeEnvironmentBase = void 0; -const core_1 = require("aws-cdk-lib/core"); -/** - * Abstract base class for ComputeEnvironments - * - * @internal - */ -class ComputeEnvironmentBase extends core_1.Resource { - constructor(scope, id, props) { - super(scope, id, { - physicalName: props?.computeEnvironmentName, - }); - this.serviceRole = props?.serviceRole; - this.enabled = props?.enabled ?? true; - } -} -exports.ComputeEnvironmentBase = ComputeEnvironmentBase; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcHV0ZS1lbnZpcm9ubWVudC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29tcHV0ZS1lbnZpcm9ubWVudC1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLDJDQUF1RDtBQWtGdkQ7Ozs7R0FJRztBQUNILE1BQXNCLHNCQUF1QixTQUFRLGVBQVE7SUFNM0QsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN2RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFlBQVksRUFBRSxLQUFLLEVBQUUsc0JBQXNCO1NBQzVDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxFQUFFLFdBQVcsQ0FBQztRQUN0QyxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssRUFBRSxPQUFPLElBQUksSUFBSSxDQUFDO0tBQ3ZDO0NBQ0Y7QUFkRCx3REFjQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IElSZXNvdXJjZSwgUmVzb3VyY2UgfSBmcm9tICdhd3MtY2RrLWxpYi9jb3JlJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBDb21wdXRlRW52aXJvbm1lbnRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJQ29tcHV0ZUVudmlyb25tZW50IGV4dGVuZHMgSVJlc291cmNlIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBDb21wdXRlRW52aXJvbm1lbnRcbiAgICpcbiAgICogQGF0dHJpYnV0ZVxuICAgKi9cbiAgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIHRoaXMgY29tcHV0ZSBlbnZpcm9ubWVudC5cbiAgICpcbiAgICogQGF0dHJpYnV0ZVxuICAgKi9cbiAgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIEJhdGNoIHVzZXMgdG8gcGVyZm9ybSBhY3Rpb25zIG9uIHlvdXIgYmVoYWxmXG4gICAqIGluIHlvdXIgYWNjb3VudCwgc3VjaCBhcyBwcm92aXNpb24gaW5zdGFuY2VzIHRvIHJ1biB5b3VyIGpvYnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBhIHNlcnZpY2VSb2xlIHdpbGwgYmUgY3JlYXRlZCBmb3IgbWFuYWdlZCBDRXMsIG5vbmUgZm9yIHVubWFuYWdlZCBDRXNcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VSb2xlPzogaWFtLklSb2xlO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0aGlzIENvbXB1dGVFbnZpcm9ubWVudCBjYW4gYWNjZXB0IGpvYnMgZnJvbSBhIFF1ZXVlLlxuICAgKiBFbmFibGVkIENvbXB1dGVFbnZpcm9ubWVudHMgY2FuIGFjY2VwdCBqb2JzIGZyb20gYSBRdWV1ZSBhbmRcbiAgICogY2FuIHNjYWxlIGluc3RhbmNlcyB1cCBvciBkb3duLlxuICAgKiBEaXNhYmxlZCBDb21wdXRlRW52aXJvbm1lbnRzIGNhbm5vdCBhY2NlcHQgam9icyBmcm9tIGEgUXVldWUgb3JcbiAgICogc2NhbGUgaW5zdGFuY2VzIHVwIG9yIGRvd24uXG4gICAqXG4gICAqIElmIHlvdSBjaGFuZ2UgYSBDb21wdXRlRW52aXJvbm1lbnQgZnJvbSBlbmFibGVkIHRvIGRpc2FibGVkIHdoaWxlIGl0IGlzIGV4ZWN1dGluZyBqb2JzLFxuICAgKiBKb2JzIGluIHRoZSBgU1RBUlRFRGAgb3IgYFJVTk5JTkdgIHN0YXRlcyB3aWxsIG5vdFxuICAgKiBiZSBpbnRlcnJ1cHRlZC4gQXMgam9icyBjb21wbGV0ZSwgdGhlIENvbXB1dGVFbnZpcm9ubWVudCB3aWxsIHNjYWxlIGluc3RhbmNlcyBkb3duIHRvIGBtaW52Q3B1c2AuXG4gICAqXG4gICAqIFRvIGVuc3VyZSB5b3UgYXJlbid0IGJpbGxlZCBmb3IgdW51c2VkIGNhcGFjaXR5LCBzZXQgYG1pbnZDcHVzYCB0byBgMGAuXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkOiBib29sZWFuO1xufVxuXG4vKipcbiAqIFByb3BzIGNvbW1vbiB0byBhbGwgQ29tcHV0ZUVudmlyb25tZW50c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBDb21wdXRlRW52aXJvbm1lbnRcbiAgICpcbiAgICogQGRlZmF1bHQgLSBnZW5lcmF0ZWQgYnkgQ2xvdWRGb3JtYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGNvbXB1dGVFbnZpcm9ubWVudE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIEJhdGNoIHVzZXMgdG8gcGVyZm9ybSBhY3Rpb25zIG9uIHlvdXIgYmVoYWxmXG4gICAqIGluIHlvdXIgYWNjb3VudCwgc3VjaCBhcyBwcm92aXNpb24gaW5zdGFuY2VzIHRvIHJ1biB5b3VyIGpvYnNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBhIHNlcnZpY2VSb2xlIHdpbGwgYmUgY3JlYXRlZCBmb3IgbWFuYWdlZCBDRXMsIG5vbmUgZm9yIHVubWFuYWdlZCBDRXNcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VSb2xlPzogaWFtLklSb2xlO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0aGlzIENvbXB1dGVFbnZpcm9ubWVudCBjYW4gYWNjZXB0IGpvYnMgZnJvbSBhIFF1ZXVlLlxuICAgKiBFbmFibGVkIENvbXB1dGVFbnZpcm9ubWVudHMgY2FuIGFjY2VwdCBqb2JzIGZyb20gYSBRdWV1ZSBhbmRcbiAgICogY2FuIHNjYWxlIGluc3RhbmNlcyB1cCBvciBkb3duLlxuICAgKiBEaXNhYmxlZCBDb21wdXRlRW52aXJvbm1lbnRzIGNhbm5vdCBhY2NlcHQgam9icyBmcm9tIGEgUXVldWUgb3JcbiAgICogc2NhbGUgaW5zdGFuY2VzIHVwIG9yIGRvd24uXG4gICAqXG4gICAqIElmIHlvdSBjaGFuZ2UgYSBDb21wdXRlRW52aXJvbm1lbnQgZnJvbSBlbmFibGVkIHRvIGRpc2FibGVkIHdoaWxlIGl0IGlzIGV4ZWN1dGluZyBqb2JzLFxuICAgKiBKb2JzIGluIHRoZSBgU1RBUlRFRGAgb3IgYFJVTk5JTkdgIHN0YXRlcyB3aWxsIG5vdFxuICAgKiBiZSBpbnRlcnJ1cHRlZC4gQXMgam9icyBjb21wbGV0ZSwgdGhlIENvbXB1dGVFbnZpcm9ubWVudCB3aWxsIHNjYWxlIGluc3RhbmNlcyBkb3duIHRvIGBtaW52Q3B1c2AuXG4gICAqXG4gICAqIFRvIGVuc3VyZSB5b3UgYXJlbid0IGJpbGxlZCBmb3IgdW51c2VkIGNhcGFjaXR5LCBzZXQgYG1pbnZDcHVzYCB0byBgMGAuXG4gICAqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIHJlYWRvbmx5IGVuYWJsZWQ/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEFic3RyYWN0IGJhc2UgY2xhc3MgZm9yIENvbXB1dGVFbnZpcm9ubWVudHNcbiAqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgZXh0ZW5kcyBSZXNvdXJjZSBpbXBsZW1lbnRzIElDb21wdXRlRW52aXJvbm1lbnQge1xuICBwdWJsaWMgYWJzdHJhY3QgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgc2VydmljZVJvbGU/OiBpYW0uSVJvbGUgfCB1bmRlZmluZWQ7XG4gIHB1YmxpYyByZWFkb25seSBlbmFibGVkOiBib29sZWFuO1xuICBwdWJsaWMgYWJzdHJhY3QgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBDb21wdXRlRW52aXJvbm1lbnRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgcGh5c2ljYWxOYW1lOiBwcm9wcz8uY29tcHV0ZUVudmlyb25tZW50TmFtZSxcbiAgICB9KTtcblxuICAgIHRoaXMuc2VydmljZVJvbGUgPSBwcm9wcz8uc2VydmljZVJvbGU7XG4gICAgdGhpcy5lbmFibGVkID0gcHJvcHM/LmVuYWJsZWQgPz8gdHJ1ZTtcbiAgfVxufVxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts deleted file mode 100644 index 4d545c302aeec..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.d.ts +++ /dev/null @@ -1,726 +0,0 @@ -import * as ecs from 'aws-cdk-lib/aws-ecs'; -import { IFileSystem } from 'aws-cdk-lib/aws-efs'; -import * as iam from 'aws-cdk-lib/aws-iam'; -import * as ssm from 'aws-cdk-lib/aws-ssm'; -import * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager'; -import { Size } from 'aws-cdk-lib/core'; -import { Construct, IConstruct } from 'constructs'; -import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; -import { LinuxParameters } from './linux-parameters'; -/** - * Specify the secret's version id or version stage - */ -export interface SecretVersionInfo { - /** - * version id of the secret - * - * @default - use default version id - */ - readonly versionId?: string; - /** - * version stage of the secret - * - * @default - use default version stage - */ - readonly versionStage?: string; -} -/** - * A secret environment variable. - */ -export declare abstract class Secret { - /** - * Creates an environment variable value from a parameter stored in AWS - * Systems Manager Parameter Store. - */ - static fromSsmParameter(parameter: ssm.IParameter): Secret; - /** - * Creates a environment variable value from a secret stored in AWS Secrets - * Manager. - * - * @param secret the secret stored in AWS Secrets Manager - * @param field the name of the field with the value that you want to set as - * the environment variable value. Only values in JSON format are supported. - * If you do not specify a JSON field, then the full content of the secret is - * used. - */ - static fromSecretsManager(secret: secretsmanager.ISecret, field?: string): Secret; - /** - * Creates a environment variable value from a secret stored in AWS Secrets - * Manager. - * - * @param secret the secret stored in AWS Secrets Manager - * @param versionInfo the version information to reference the secret - * @param field the name of the field with the value that you want to set as - * the environment variable value. Only values in JSON format are supported. - * If you do not specify a JSON field, then the full content of the secret is - * used. - */ - static fromSecretsManagerVersion(secret: secretsmanager.ISecret, versionInfo: SecretVersionInfo, field?: string): Secret; - /** - * The ARN of the secret - */ - abstract readonly arn: string; - /** - * Whether this secret uses a specific JSON field - */ - abstract readonly hasField?: boolean; - /** - * Grants reading the secret to a principal - */ - abstract grantRead(grantee: iam.IGrantable): iam.Grant; -} -/** - * Options to configure an EcsVolume - */ -export interface EcsVolumeOptions { - /** - * the name of this volume - */ - readonly name: string; - /** - * the path on the container where this volume is mounted - */ - readonly containerPath: string; - /** - * if set, the container will have readonly access to the volume - * - * @default false - */ - readonly readonly?: boolean; -} -/** - * Represents a Volume that can be mounted to a container that uses ECS - */ -export declare abstract class EcsVolume { - /** - * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html - */ - static efs(options: EfsVolumeOptions): EfsVolume; - /** - * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. - * If the `hostPath` is not specified, Docker will choose the host path. In this case, - * the data may not persist after the containers that use it stop running. - */ - static host(options: HostVolumeOptions): HostVolume; - /** - * The name of this volume - */ - readonly name: string; - /** - * The path on the container that this volume will be mounted to - */ - readonly containerPath: string; - /** - * Whether or not the container has readonly access to this volume - * - * @default false - */ - readonly readonly?: boolean; - constructor(options: EcsVolumeOptions); -} -/** - * Options for configuring an EfsVolume - */ -export interface EfsVolumeOptions extends EcsVolumeOptions { - /** - * The EFS File System that supports this volume - */ - readonly fileSystem: IFileSystem; - /** - * The directory within the Amazon EFS file system to mount as the root directory inside the host. - * If this parameter is omitted, the root of the Amazon EFS volume is used instead. - * Specifying `/` has the same effect as omitting this parameter. - * The maximum length is 4,096 characters. - * - * @default - root of the EFS File System - */ - readonly rootDirectory?: string; - /** - * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server - * - * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html - * - * @default false - */ - readonly enableTransitEncryption?: boolean; - /** - * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server. - * The value must be between 0 and 65,535. - * - * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html - * - * @default - chosen by the EFS Mount Helper - */ - readonly transitEncryptionPort?: number; - /** - * The Amazon EFS access point ID to use. - * If an access point is specified, `rootDirectory` must either be omitted or set to `/` - * which enforces the path set on the EFS access point. - * If an access point is used, `enableTransitEncryption` must be `true`. - * - * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html - * - * @default - no accessPointId - */ - readonly accessPointId?: string; - /** - * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system. - * If specified, `enableTransitEncryption` must be `true`. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints - * - * @default false - */ - readonly useJobRole?: boolean; -} -/** - * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed - */ -export declare class EfsVolume extends EcsVolume { - /** - * Returns true if x is an EfsVolume, false otherwise - */ - static isEfsVolume(x: any): x is EfsVolume; - /** - * The EFS File System that supports this volume - */ - readonly fileSystem: IFileSystem; - /** - * The directory within the Amazon EFS file system to mount as the root directory inside the host. - * If this parameter is omitted, the root of the Amazon EFS volume is used instead. - * Specifying `/` has the same effect as omitting this parameter. - * The maximum length is 4,096 characters. - * - * @default - root of the EFS File System - */ - readonly rootDirectory?: string; - /** - * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server - * - * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html - * - * @default false - */ - readonly enableTransitEncryption?: boolean; - /** - * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server. - * The value must be between 0 and 65,535. - * - * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html - * - * @default - chosen by the EFS Mount Helper - */ - readonly transitEncryptionPort?: number; - /** - * The Amazon EFS access point ID to use. - * If an access point is specified, `rootDirectory` must either be omitted or set to `/` - * which enforces the path set on the EFS access point. - * If an access point is used, `enableTransitEncryption` must be `true`. - * - * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html - * - * @default - no accessPointId - */ - readonly accessPointId?: string; - /** - * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system. - * If specified, `enableTransitEncryption` must be `true`. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints - * - * @default false - */ - readonly useJobRole?: boolean; - constructor(options: EfsVolumeOptions); -} -/** - * Options for configuring an ECS HostVolume - */ -export interface HostVolumeOptions extends EcsVolumeOptions { - /** - * The path on the host machine this container will have access to - * - * @default - Docker will choose the host path. - * The data may not persist after the containers that use it stop running. - */ - readonly hostPath?: string; -} -/** - * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. - * If the `hostPath` is not specified, Docker will choose the host path. In this case, - * the data may not persist after the containers that use it stop running. - */ -export declare class HostVolume extends EcsVolume { - /** - * returns `true` if `x` is a `HostVolume`, `false` otherwise - */ - static isHostVolume(x: any): x is HostVolume; - /** - * The path on the host machine this container will have access to - */ - readonly hostPath?: string; - constructor(options: HostVolumeOptions); -} -/** - * A container that can be run with ECS orchestration - */ -export interface IEcsContainerDefinition extends IConstruct { - /** - * The image that this container will run - */ - readonly image: ecs.ContainerImage; - /** - * The number of vCPUs reserved for the container. - * Each vCPU is equivalent to 1,024 CPU shares. - * For containers running on EC2 resources, you must specify at least one vCPU. - */ - readonly cpu: number; - /** - * The memory hard limit present to the container. - * If your container attempts to exceed the memory specified, the container is terminated. - * You must specify at least 4 MiB of memory for a job. - */ - readonly memory: Size; - /** - * The command that's passed to the container - * - * @see https://docs.docker.com/engine/reference/builder/#cmd - */ - readonly command?: string[]; - /** - * The environment variables to pass to a container. - * Cannot start with `AWS_BATCH`. - * We don't recommend using plaintext environment variables for sensitive information, such as credential data. - * - * @default - no environment variables - */ - readonly environment?: { - [key: string]: string; - }; - /** - * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html - */ - readonly executionRole: iam.IRole; - /** - * The role that the container can assume. - * - * @default - no jobRole - * - * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html - */ - readonly jobRole?: iam.IRole; - /** - * Linux-specific modifications that are applied to the container, such as details for device mappings. - * - * @default none - */ - readonly linuxParameters?: LinuxParameters; - /** - * The configuration of the log driver - */ - readonly logDriverConfig?: ecs.LogDriverConfig; - /** - * Gives the container readonly access to its root filesystem. - * - * @default false - */ - readonly readonlyRootFilesystem?: boolean; - /** - * A map from environment variable names to the secrets for the container. Allows your job definitions - * to reference the secret by the environment variable name defined in this property. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html - * - * @default - no secrets - */ - readonly secrets?: { - [envVarName: string]: Secret; - }; - /** - * The user name to use inside the container - * - * @default - no user - */ - readonly user?: string; - /** - * The volumes to mount to this container. Automatically added to the job definition. - * - * @default - no volumes - */ - readonly volumes: EcsVolume[]; - /** - * Renders this container to CloudFormation - * - * @internal - */ - _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; - /** - * Add a Volume to this container - */ - addVolume(volume: EcsVolume): void; -} -/** - * Props to configure an EcsContainerDefinition - */ -export interface EcsContainerDefinitionProps { - /** - * The image that this container will run - */ - readonly image: ecs.ContainerImage; - /** - * The number of vCPUs reserved for the container. - * Each vCPU is equivalent to 1,024 CPU shares. - * For containers running on EC2 resources, you must specify at least one vCPU. - */ - readonly cpu: number; - /** - * The memory hard limit present to the container. - * If your container attempts to exceed the memory specified, the container is terminated. - * You must specify at least 4 MiB of memory for a job. - */ - readonly memory: Size; - /** - * The command that's passed to the container - * - * @see https://docs.docker.com/engine/reference/builder/#cmd - * - * @default - no command - */ - readonly command?: string[]; - /** - * The environment variables to pass to a container. - * Cannot start with `AWS_BATCH`. - * We don't recommend using plaintext environment variables for sensitive information, such as credential data. - * - * @default - no environment variables - */ - readonly environment?: { - [key: string]: string; - }; - /** - * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html - * - * @default - a Role will be created - */ - readonly executionRole?: iam.IRole; - /** - * The role that the container can assume. - * - * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html - * - * @default - no job role - */ - readonly jobRole?: iam.IRole; - /** - * Linux-specific modifications that are applied to the container, such as details for device mappings. - * - * @default none - */ - readonly linuxParameters?: LinuxParameters; - /** - * The loging configuration for this Job - * - * @default - the log configuration of the Docker daemon - */ - readonly logging?: ecs.LogDriver; - /** - * Gives the container readonly access to its root filesystem. - * - * @default false - */ - readonly readonlyRootFilesystem?: boolean; - /** - * A map from environment variable names to the secrets for the container. Allows your job definitions - * to reference the secret by the environment variable name defined in this property. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html - * - * @default - no secrets - */ - readonly secrets?: { - [envVarName: string]: Secret; - }; - /** - * The user name to use inside the container - * - * @default - no user - */ - readonly user?: string; - /** - * The volumes to mount to this container. Automatically added to the job definition. - * - * @default - no volumes - */ - readonly volumes?: EcsVolume[]; -} -/** - * Abstract base class for ECS Containers - */ -declare abstract class EcsContainerDefinitionBase extends Construct implements IEcsContainerDefinition { - readonly image: ecs.ContainerImage; - readonly cpu: number; - readonly memory: Size; - readonly command?: string[]; - readonly environment?: { - [key: string]: string; - }; - readonly executionRole: iam.IRole; - readonly jobRole?: iam.IRole; - readonly linuxParameters?: LinuxParameters; - readonly logDriverConfig?: ecs.LogDriverConfig; - readonly readonlyRootFilesystem?: boolean; - readonly secrets?: { - [envVarName: string]: Secret; - }; - readonly user?: string; - readonly volumes: EcsVolume[]; - private readonly imageConfig; - constructor(scope: Construct, id: string, props: EcsContainerDefinitionProps); - /** - * @internal - */ - _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; - addVolume(volume: EcsVolume): void; - /** - * @internal - */ - protected _renderResourceRequirements(): { - type: string; - value: string; - }[]; -} -/** - * Sets limits for a resource with `ulimit` on linux systems. - * Used by the Docker daemon. - */ -export interface Ulimit { - /** - * The hard limit for this resource. The container will - * be terminated if it exceeds this limit. - */ - readonly hardLimit: number; - /** - * The resource to limit - */ - readonly name: UlimitName; - /** - * The reservation for this resource. The container will - * not be terminated if it exceeds this limit. - */ - readonly softLimit: number; -} -/** - * The resources to be limited - */ -export declare enum UlimitName { - /** - * max core dump file size - */ - CORE = "core", - /** - * max cpu time (seconds) for a process - */ - CPU = "cpu", - /** - * max data segment size - */ - DATA = "data", - /** - * max file size - */ - FSIZE = "fsize", - /** - * max number of file locks - */ - LOCKS = "locks", - /** - * max locked memory - */ - MEMLOCK = "memlock", - /** - * max POSIX message queue size - */ - MSGQUEUE = "msgqueue", - /** - * max nice value for any process this user is running - */ - NICE = "nice", - /** - * maximum number of open file descriptors - */ - NOFILE = "nofile", - /** - * maximum number of processes - */ - NPROC = "nproc", - /** - * size of the process' resident set (in pages) - */ - RSS = "rss", - /** - * max realtime priority - */ - RTPRIO = "rtprio", - /** - * timeout for realtime tasks - */ - RTTIME = "rttime", - /** - * max number of pending signals - */ - SIGPENDING = "sigpending", - /** - * max stack size (in bytes) - */ - STACK = "stack" -} -/** - * A container orchestrated by ECS that uses EC2 resources - */ -export interface IEcsEc2ContainerDefinition extends IEcsContainerDefinition { - /** - * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user). - * - * @default false - */ - readonly privileged?: boolean; - /** - * Limits to set for the user this docker container will run as - */ - readonly ulimits: Ulimit[]; - /** - * The number of physical GPUs to reserve for the container. - * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed - * the number of available GPUs on the compute resource that the job is launched on. - * - * @default - no gpus - */ - readonly gpu?: number; - /** - * Add a ulimit to this container - */ - addUlimit(ulimit: Ulimit): void; -} -/** - * Props to configure an EcsEc2ContainerDefinition - */ -export interface EcsEc2ContainerDefinitionProps extends EcsContainerDefinitionProps { - /** - * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user). - * - * @default false - */ - readonly privileged?: boolean; - /** - * Limits to set for the user this docker container will run as - * - * @default - no ulimits - */ - readonly ulimits?: Ulimit[]; - /** - * The number of physical GPUs to reserve for the container. - * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed - * the number of available GPUs on the compute resource that the job is launched on. - * - * @default - no gpus - */ - readonly gpu?: number; -} -/** - * A container orchestrated by ECS that uses EC2 resources - */ -export declare class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase implements IEcsEc2ContainerDefinition { - readonly privileged?: boolean; - readonly ulimits: Ulimit[]; - readonly gpu?: number; - constructor(scope: Construct, id: string, props: EcsEc2ContainerDefinitionProps); - /** - * @internal - */ - _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; - /** - * Add a ulimit to this container - */ - addUlimit(ulimit: Ulimit): void; - /** - * @internal - */ - protected _renderResourceRequirements(): { - type: string; - value: string; - }[]; -} -/** - * A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS - */ -export interface IEcsFargateContainerDefinition extends IEcsContainerDefinition { - /** - * Indicates whether the job has a public IP address. - * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet - * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet. - * - * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html - * - * @default false - */ - readonly assignPublicIp?: boolean; - /** - * Which version of Fargate to use when running this container - * - * @default LATEST - */ - readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; - /** - * The size for ephemeral storage. - * - * @default - 20 GiB - */ - readonly ephemeralStorageSize?: Size; -} -/** - * Props to configure an EcsFargateContainerDefinition - */ -export interface EcsFargateContainerDefinitionProps extends EcsContainerDefinitionProps { - /** - * Indicates whether the job has a public IP address. - * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet - * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet. - * - * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html - * - * @default false - */ - readonly assignPublicIp?: boolean; - /** - * Which version of Fargate to use when running this container - * - * @default LATEST - */ - readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; - /** - * The size for ephemeral storage. - * - * @default - 20 GiB - */ - readonly ephemeralStorageSize?: Size; -} -/** - * A container orchestrated by ECS that uses Fargate resources - */ -export declare class EcsFargateContainerDefinition extends EcsContainerDefinitionBase implements IEcsFargateContainerDefinition { - readonly fargatePlatformVersion?: ecs.FargatePlatformVersion; - readonly assignPublicIp?: boolean; - readonly ephemeralStorageSize?: Size; - constructor(scope: Construct, id: string, props: EcsFargateContainerDefinitionProps); - /** - * @internal - */ - _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty; -} -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js deleted file mode 100644 index 1153535f13eac..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-container-definition.js +++ /dev/null @@ -1,531 +0,0 @@ -"use strict"; -var _a, _b, _c, _d, _e, _f; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcsFargateContainerDefinition = exports.EcsEc2ContainerDefinition = exports.UlimitName = exports.HostVolume = exports.EfsVolume = exports.EcsVolume = exports.Secret = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const iam = require("aws-cdk-lib/aws-iam"); -const core_1 = require("aws-cdk-lib/core"); -const constructs_1 = require("constructs"); -const aws_logs_1 = require("aws-cdk-lib/aws-logs"); -const EFS_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.EfsVolume'); -const HOST_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.HostVolume'); -/** - * A secret environment variable. - */ -class Secret { - /** - * Creates an environment variable value from a parameter stored in AWS - * Systems Manager Parameter Store. - */ - static fromSsmParameter(parameter) { - return { - arn: parameter.parameterArn, - grantRead: grantee => parameter.grantRead(grantee), - }; - } - /** - * Creates a environment variable value from a secret stored in AWS Secrets - * Manager. - * - * @param secret the secret stored in AWS Secrets Manager - * @param field the name of the field with the value that you want to set as - * the environment variable value. Only values in JSON format are supported. - * If you do not specify a JSON field, then the full content of the secret is - * used. - */ - static fromSecretsManager(secret, field) { - return { - arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn, - hasField: !!field, - grantRead: grantee => secret.grantRead(grantee), - }; - } - /** - * Creates a environment variable value from a secret stored in AWS Secrets - * Manager. - * - * @param secret the secret stored in AWS Secrets Manager - * @param versionInfo the version information to reference the secret - * @param field the name of the field with the value that you want to set as - * the environment variable value. Only values in JSON format are supported. - * If you do not specify a JSON field, then the full content of the secret is - * used. - */ - static fromSecretsManagerVersion(secret, versionInfo, field) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretVersionInfo(versionInfo); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.fromSecretsManagerVersion); - } - throw error; - } - return { - arn: `${secret.secretArn}:${field ?? ''}:${versionInfo.versionStage ?? ''}:${versionInfo.versionId ?? ''}`, - hasField: !!field, - grantRead: grantee => secret.grantRead(grantee), - }; - } -} -exports.Secret = Secret; -_a = JSII_RTTI_SYMBOL_1; -Secret[_a] = { fqn: "@aws-cdk/aws-batch-alpha.Secret", version: "0.0.0" }; -/** - * Represents a Volume that can be mounted to a container that uses ECS - */ -class EcsVolume { - /** - * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html - */ - static efs(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EfsVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.efs); - } - throw error; - } - return new EfsVolume(options); - } - /** - * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. - * If the `hostPath` is not specified, Docker will choose the host path. In this case, - * the data may not persist after the containers that use it stop running. - */ - static host(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.host); - } - throw error; - } - return new HostVolume(options); - } - constructor(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EcsVolume); - } - throw error; - } - this.name = options.name; - this.containerPath = options.containerPath; - this.readonly = options.readonly; - } -} -exports.EcsVolume = EcsVolume; -_b = JSII_RTTI_SYMBOL_1; -EcsVolume[_b] = { fqn: "@aws-cdk/aws-batch-alpha.EcsVolume", version: "0.0.0" }; -/** - * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed - */ -class EfsVolume extends EcsVolume { - /** - * Returns true if x is an EfsVolume, false otherwise - */ - static isEfsVolume(x) { - return x !== null && typeof (x) === 'object' && EFS_VOLUME_SYMBOL in x; - } - constructor(options) { - super(options); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EfsVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EfsVolume); - } - throw error; - } - this.fileSystem = options.fileSystem; - this.rootDirectory = options.rootDirectory; - this.enableTransitEncryption = options.enableTransitEncryption; - this.transitEncryptionPort = options.transitEncryptionPort; - this.accessPointId = options.accessPointId; - this.useJobRole = options.useJobRole; - } -} -exports.EfsVolume = EfsVolume; -_c = JSII_RTTI_SYMBOL_1; -EfsVolume[_c] = { fqn: "@aws-cdk/aws-batch-alpha.EfsVolume", version: "0.0.0" }; -Object.defineProperty(EfsVolume.prototype, EFS_VOLUME_SYMBOL, { - value: true, - enumerable: false, - writable: false, -}); -/** - * Creates a Host volume. This volume will persist on the host at the specified `hostPath`. - * If the `hostPath` is not specified, Docker will choose the host path. In this case, - * the data may not persist after the containers that use it stop running. - */ -class HostVolume extends EcsVolume { - /** - * returns `true` if `x` is a `HostVolume`, `false` otherwise - */ - static isHostVolume(x) { - return x !== null && typeof (x) === 'object' && HOST_VOLUME_SYMBOL in x; - } - constructor(options) { - super(options); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, HostVolume); - } - throw error; - } - this.hostPath = options.hostPath; - } -} -exports.HostVolume = HostVolume; -_d = JSII_RTTI_SYMBOL_1; -HostVolume[_d] = { fqn: "@aws-cdk/aws-batch-alpha.HostVolume", version: "0.0.0" }; -Object.defineProperty(HostVolume.prototype, HOST_VOLUME_SYMBOL, { - value: true, - enumerable: false, - writable: false, -}); -/** - * Abstract base class for ECS Containers - */ -class EcsContainerDefinitionBase extends constructs_1.Construct { - constructor(scope, id, props) { - super(scope, id); - this.image = props.image; - this.cpu = props.cpu; - this.command = props.command; - this.environment = props.environment; - this.executionRole = props.executionRole ?? createExecutionRole(this, 'ExecutionRole', props.logging ? true : false); - this.jobRole = props.jobRole; - this.linuxParameters = props.linuxParameters; - this.memory = props.memory; - if (props.logging) { - this.logDriverConfig = props.logging.bind(this, { - ...this, - // TS! - taskDefinition: { - obtainExecutionRole: () => this.executionRole, - }, - }); - } - this.readonlyRootFilesystem = props.readonlyRootFilesystem ?? false; - this.secrets = props.secrets; - this.user = props.user; - this.volumes = props.volumes ?? []; - this.imageConfig = props.image.bind(this, { - ...this, - taskDefinition: { - obtainExecutionRole: () => this.executionRole, - }, - }); - } - /** - * @internal - */ - _renderContainerDefinition() { - return { - image: this.imageConfig.imageName, - command: this.command, - environment: Object.keys(this.environment ?? {}).map((envKey) => ({ - name: envKey, - value: (this.environment ?? {})[envKey], - })), - jobRoleArn: this.jobRole?.roleArn, - executionRoleArn: this.executionRole?.roleArn, - linuxParameters: this.linuxParameters && this.linuxParameters.renderLinuxParameters(), - logConfiguration: this.logDriverConfig, - readonlyRootFilesystem: this.readonlyRootFilesystem, - resourceRequirements: this._renderResourceRequirements(), - secrets: this.secrets ? Object.entries(this.secrets).map(([name, secret]) => { - secret.grantRead(this.executionRole); - return { - name, - valueFrom: secret.arn, - }; - }) : undefined, - mountPoints: core_1.Lazy.any({ - produce: () => { - if (this.volumes.length === 0) { - return undefined; - } - return this.volumes.map((volume) => { - return { - containerPath: volume.containerPath, - readOnly: volume.readonly, - sourceVolume: volume.name, - }; - }); - }, - }), - volumes: core_1.Lazy.any({ - produce: () => { - if (this.volumes.length === 0) { - return undefined; - } - return this.volumes.map((volume) => { - if (EfsVolume.isEfsVolume(volume)) { - return { - name: volume.name, - efsVolumeConfiguration: { - fileSystemId: volume.fileSystem.fileSystemId, - rootDirectory: volume.rootDirectory, - transitEncryption: volume.enableTransitEncryption ? 'ENABLED' : (volume.enableTransitEncryption === false ? 'DISABLED' : undefined), - transitEncryptionPort: volume.transitEncryptionPort, - authorizationConfig: volume.accessPointId || volume.useJobRole ? { - accessPointId: volume.accessPointId, - iam: volume.useJobRole ? 'ENABLED' : (volume.useJobRole === false ? 'DISABLED' : undefined), - } : undefined, - }, - }; - } - else if (HostVolume.isHostVolume(volume)) { - return { - name: volume.name, - host: { - sourcePath: volume.hostPath, - }, - }; - } - throw new Error('unsupported Volume encountered'); - }); - }, - }), - user: this.user, - }; - } - addVolume(volume) { - this.volumes.push(volume); - } - /** - * @internal - */ - _renderResourceRequirements() { - const resourceRequirements = []; - resourceRequirements.push({ - type: 'MEMORY', - value: this.memory.toMebibytes().toString(), - }); - resourceRequirements.push({ - type: 'VCPU', - value: this.cpu.toString(), - }); - return resourceRequirements; - } -} -/** - * The resources to be limited - */ -var UlimitName; -(function (UlimitName) { - /** - * max core dump file size - */ - UlimitName["CORE"] = "core"; - /** - * max cpu time (seconds) for a process - */ - UlimitName["CPU"] = "cpu"; - /** - * max data segment size - */ - UlimitName["DATA"] = "data"; - /** - * max file size - */ - UlimitName["FSIZE"] = "fsize"; - /** - * max number of file locks - */ - UlimitName["LOCKS"] = "locks"; - /** - * max locked memory - */ - UlimitName["MEMLOCK"] = "memlock"; - /** - * max POSIX message queue size - */ - UlimitName["MSGQUEUE"] = "msgqueue"; - /** - * max nice value for any process this user is running - */ - UlimitName["NICE"] = "nice"; - /** - * maximum number of open file descriptors - */ - UlimitName["NOFILE"] = "nofile"; - /** - * maximum number of processes - */ - UlimitName["NPROC"] = "nproc"; - /** - * size of the process' resident set (in pages) - */ - UlimitName["RSS"] = "rss"; - /** - * max realtime priority - */ - UlimitName["RTPRIO"] = "rtprio"; - /** - * timeout for realtime tasks - */ - UlimitName["RTTIME"] = "rttime"; - /** - * max number of pending signals - */ - UlimitName["SIGPENDING"] = "sigpending"; - /** - * max stack size (in bytes) - */ - UlimitName["STACK"] = "stack"; -})(UlimitName || (exports.UlimitName = UlimitName = {})); -/** - * A container orchestrated by ECS that uses EC2 resources - */ -class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase { - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsEc2ContainerDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EcsEc2ContainerDefinition); - } - throw error; - } - this.privileged = props.privileged; - this.ulimits = props.ulimits ?? []; - this.gpu = props.gpu; - } - /** - * @internal - */ - _renderContainerDefinition() { - return { - ...super._renderContainerDefinition(), - ulimits: core_1.Lazy.any({ - produce: () => { - if (this.ulimits.length === 0) { - return undefined; - } - return this.ulimits.map((ulimit) => ({ - hardLimit: ulimit.hardLimit, - name: ulimit.name, - softLimit: ulimit.softLimit, - })); - }, - }), - privileged: this.privileged, - resourceRequirements: this._renderResourceRequirements(), - }; - } - ; - /** - * Add a ulimit to this container - */ - addUlimit(ulimit) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Ulimit(ulimit); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addUlimit); - } - throw error; - } - this.ulimits.push(ulimit); - } - /** - * @internal - */ - _renderResourceRequirements() { - const resourceRequirements = super._renderResourceRequirements(); - if (this.gpu) { - resourceRequirements.push({ - type: 'GPU', - value: this.gpu.toString(), - }); - } - return resourceRequirements; - } -} -exports.EcsEc2ContainerDefinition = EcsEc2ContainerDefinition; -_e = JSII_RTTI_SYMBOL_1; -EcsEc2ContainerDefinition[_e] = { fqn: "@aws-cdk/aws-batch-alpha.EcsEc2ContainerDefinition", version: "0.0.0" }; -/** - * A container orchestrated by ECS that uses Fargate resources - */ -class EcsFargateContainerDefinition extends EcsContainerDefinitionBase { - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsFargateContainerDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EcsFargateContainerDefinition); - } - throw error; - } - this.assignPublicIp = props.assignPublicIp; - this.fargatePlatformVersion = props.fargatePlatformVersion; - this.ephemeralStorageSize = props.ephemeralStorageSize; - // validates ephemeralStorageSize is within limits - if (props.ephemeralStorageSize) { - if (props.ephemeralStorageSize.toGibibytes() > 200) { - throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} > 200 GB`); - } - else if (props.ephemeralStorageSize.toGibibytes() < 21) { - throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} < 21 GB`); - } - } - } - /** - * @internal - */ - _renderContainerDefinition() { - return { - ...super._renderContainerDefinition(), - ephemeralStorage: this.ephemeralStorageSize ? { - sizeInGiB: this.ephemeralStorageSize?.toGibibytes(), - } : undefined, - fargatePlatformConfiguration: { - platformVersion: this.fargatePlatformVersion?.toString(), - }, - networkConfiguration: { - assignPublicIp: this.assignPublicIp ? 'ENABLED' : 'DISABLED', - }, - }; - } - ; -} -exports.EcsFargateContainerDefinition = EcsFargateContainerDefinition; -_f = JSII_RTTI_SYMBOL_1; -EcsFargateContainerDefinition[_f] = { fqn: "@aws-cdk/aws-batch-alpha.EcsFargateContainerDefinition", version: "0.0.0" }; -function createExecutionRole(scope, id, logging) { - const execRole = new iam.Role(scope, id, { - assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'), - // needed for cross-account access with TagParameterContainerImage - roleName: core_1.PhysicalName.GENERATE_IF_NEEDED, - }); - if (!logging) { - // all jobs will fail without this if they produce any output at all when no logging is specified - aws_logs_1.LogGroup.fromLogGroupName(scope, 'batchDefaultLogGroup', '/aws/batch/job').grantWrite(execRole); - } - return execRole; -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-container-definition.js","sourceRoot":"","sources":["ecs-container-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { IFileSystem } from 'aws-cdk-lib/aws-efs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport { Lazy, PhysicalName, Size } from 'aws-cdk-lib/core';\nimport { Construct, IConstruct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { LinuxParameters } from './linux-parameters';\nimport { LogGroup } from 'aws-cdk-lib/aws-logs';\n\nconst EFS_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.EfsVolume');\nconst HOST_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/container-definition.HostVolume');\n\n/**\n * Specify the secret's version id or version stage\n */\nexport interface SecretVersionInfo {\n  /**\n   * version id of the secret\n   *\n   * @default - use default version id\n   */\n  readonly versionId?: string;\n  /**\n   * version stage of the secret\n   *\n   * @default - use default version stage\n   */\n  readonly versionStage?: string;\n}\n\n/**\n * A secret environment variable.\n */\nexport abstract class Secret {\n  /**\n   * Creates an environment variable value from a parameter stored in AWS\n   * Systems Manager Parameter Store.\n   */\n  public static fromSsmParameter(parameter: ssm.IParameter): Secret {\n    return {\n      arn: parameter.parameterArn,\n      grantRead: grantee => parameter.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManager(secret: secretsmanager.ISecret, field?: string): Secret {\n    return {\n      arn: field ? `${secret.secretArn}:${field}::` : secret.secretArn,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * Creates a environment variable value from a secret stored in AWS Secrets\n   * Manager.\n   *\n   * @param secret the secret stored in AWS Secrets Manager\n   * @param versionInfo the version information to reference the secret\n   * @param field the name of the field with the value that you want to set as\n   * the environment variable value. Only values in JSON format are supported.\n   * If you do not specify a JSON field, then the full content of the secret is\n   * used.\n   */\n  public static fromSecretsManagerVersion(secret: secretsmanager.ISecret, versionInfo: SecretVersionInfo, field?: string): Secret {\n    return {\n      arn: `${secret.secretArn}:${field ?? ''}:${versionInfo.versionStage ?? ''}:${versionInfo.versionId ?? ''}`,\n      hasField: !!field,\n      grantRead: grantee => secret.grantRead(grantee),\n    };\n  }\n\n  /**\n   * The ARN of the secret\n   */\n  public abstract readonly arn: string;\n\n  /**\n   * Whether this secret uses a specific JSON field\n   */\n  public abstract readonly hasField?: boolean;\n\n  /**\n   * Grants reading the secret to a principal\n   */\n  public abstract grantRead(grantee: iam.IGrantable): iam.Grant;\n}\n\n/**\n * Options to configure an EcsVolume\n */\nexport interface EcsVolumeOptions {\n  /**\n   * the name of this volume\n   */\n  readonly name: string;\n\n  /**\n   * the path on the container where this volume is mounted\n   */\n  readonly containerPath: string;\n\n  /**\n   * if set, the container will have readonly access to the volume\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n}\n\n/**\n * Represents a Volume that can be mounted to a container that uses ECS\n */\nexport abstract class EcsVolume {\n  /**\n   * Creates a Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html\n   */\n  static efs(options: EfsVolumeOptions) {\n    return new EfsVolume(options);\n  }\n\n  /**\n   * Creates a Host volume. This volume will persist on the host at the specified `hostPath`.\n   * If the `hostPath` is not specified, Docker will choose the host path. In this case,\n   * the data may not persist after the containers that use it stop running.\n   */\n  static host(options: HostVolumeOptions) {\n    return new HostVolume(options);\n  }\n\n  /**\n   * The name of this volume\n   */\n  public readonly name: string;\n\n  /**\n   * The path on the container that this volume will be mounted to\n   */\n  public readonly containerPath: string;\n\n  /**\n   * Whether or not the container has readonly access to this volume\n   *\n   * @default false\n   */\n  public readonly readonly?: boolean;\n\n  constructor(options: EcsVolumeOptions) {\n    this.name = options.name;\n    this.containerPath = options.containerPath;\n    this.readonly = options.readonly;\n  }\n}\n\n/**\n * Options for configuring an EfsVolume\n */\nexport interface EfsVolumeOptions extends EcsVolumeOptions {\n  /**\n   * The EFS File System that supports this volume\n   */\n  readonly fileSystem: IFileSystem;\n\n  /**\n   * The directory within the Amazon EFS file system to mount as the root directory inside the host.\n   * If this parameter is omitted, the root of the Amazon EFS volume is used instead.\n   * Specifying `/` has the same effect as omitting this parameter.\n   * The maximum length is 4,096 characters.\n   *\n   * @default - root of the EFS File System\n   */\n  readonly rootDirectory?: string;\n\n  /**\n   * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html\n   *\n   * @default false\n   */\n  readonly enableTransitEncryption?: boolean;\n\n  /**\n   * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server.\n   * The value must be between 0 and 65,535.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html\n   *\n   * @default - chosen by the EFS Mount Helper\n   */\n  readonly transitEncryptionPort?: number;\n\n  /**\n   * The Amazon EFS access point ID to use.\n   * If an access point is specified, `rootDirectory` must either be omitted or set to `/`\n   * which enforces the path set on the EFS access point.\n   * If an access point is used, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html\n   *\n   * @default - no accessPointId\n   */\n  readonly accessPointId?: string;\n\n  /**\n   * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system.\n   * If specified, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints\n   *\n   * @default false\n   */\n  readonly useJobRole?: boolean;\n}\n\n/**\n * A Volume that uses an AWS Elastic File System (EFS); this volume can grow and shrink as needed\n */\nexport class EfsVolume extends EcsVolume {\n  /**\n   * Returns true if x is an EfsVolume, false otherwise\n   */\n  public static isEfsVolume(x: any) : x is EfsVolume {\n    return x !== null && typeof(x) === 'object' && EFS_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The EFS File System that supports this volume\n   */\n  public readonly fileSystem: IFileSystem;\n\n  /**\n   * The directory within the Amazon EFS file system to mount as the root directory inside the host.\n   * If this parameter is omitted, the root of the Amazon EFS volume is used instead.\n   * Specifying `/` has the same effect as omitting this parameter.\n   * The maximum length is 4,096 characters.\n   *\n   * @default - root of the EFS File System\n   */\n  public readonly rootDirectory?: string;\n\n  /**\n   * Enables encryption for Amazon EFS data in transit between the Amazon ECS host and the Amazon EFS server\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/encryption-in-transit.html\n   *\n   * @default false\n   */\n  public readonly enableTransitEncryption?: boolean;\n\n  /**\n   * The port to use when sending encrypted data between the Amazon ECS host and the Amazon EFS server.\n   * The value must be between 0 and 65,535.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-mount-helper.html\n   *\n   * @default - chosen by the EFS Mount Helper\n   */\n  public readonly transitEncryptionPort?: number;\n\n  /**\n   * The Amazon EFS access point ID to use.\n   * If an access point is specified, `rootDirectory` must either be omitted or set to `/`\n   * which enforces the path set on the EFS access point.\n   * If an access point is used, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/efs/latest/ug/efs-access-points.html\n   *\n   * @default - no accessPointId\n   */\n  public readonly accessPointId?: string;\n\n  /**\n   * Whether or not to use the AWS Batch job IAM role defined in a job definition when mounting the Amazon EFS file system.\n   * If specified, `enableTransitEncryption` must be `true`.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/efs-volumes.html#efs-volume-accesspoints\n   *\n   * @default false\n   */\n  public readonly useJobRole?: boolean;\n\n  constructor(options: EfsVolumeOptions) {\n    super(options);\n\n    this.fileSystem = options.fileSystem;\n    this.rootDirectory = options.rootDirectory;\n    this.enableTransitEncryption = options.enableTransitEncryption;\n    this.transitEncryptionPort = options.transitEncryptionPort;\n    this.accessPointId = options.accessPointId;\n    this.useJobRole = options.useJobRole;\n  }\n}\n\nObject.defineProperty(EfsVolume.prototype, EFS_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for configuring an ECS HostVolume\n */\nexport interface HostVolumeOptions extends EcsVolumeOptions {\n  /**\n   * The path on the host machine this container will have access to\n   *\n   * @default - Docker will choose the host path.\n   * The data may not persist after the containers that use it stop running.\n   */\n  readonly hostPath?: string;\n}\n\n/**\n * Creates a Host volume. This volume will persist on the host at the specified `hostPath`.\n * If the `hostPath` is not specified, Docker will choose the host path. In this case,\n * the data may not persist after the containers that use it stop running.\n */\nexport class HostVolume extends EcsVolume {\n  /**\n   * returns `true` if `x` is a `HostVolume`, `false` otherwise\n   */\n  public static isHostVolume(x: any): x is HostVolume {\n    return x !== null && typeof (x) === 'object' && HOST_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The path on the host machine this container will have access to\n   */\n  public readonly hostPath?: string;\n\n  constructor(options: HostVolumeOptions) {\n    super(options);\n    this.hostPath = options.hostPath;\n  }\n}\n\nObject.defineProperty(HostVolume.prototype, HOST_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * A container that can be run with ECS orchestration\n */\nexport interface IEcsContainerDefinition extends IConstruct {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The number of vCPUs reserved for the container.\n   * Each vCPU is equivalent to 1,024 CPU shares.\n   * For containers running on EC2 resources, you must specify at least one vCPU.\n   */\n  readonly cpu: number;\n\n  /**\n   * The memory hard limit present to the container.\n   * If your container attempts to exceed the memory specified, the container is terminated.\n   * You must specify at least 4 MiB of memory for a job.\n   */\n  readonly memory: Size;\n\n  /**\n   * The command that's passed to the container\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to a container.\n   * Cannot start with `AWS_BATCH`.\n   * We don't recommend using plaintext environment variables for sensitive information, such as credential data.\n   *\n   * @default - no environment variables\n   */\n  readonly environment?: { [key:string]: string };\n\n  /**\n   * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html\n   */\n  readonly executionRole: iam.IRole;\n\n  /**\n   * The role that the container can assume.\n   *\n   * @default - no jobRole\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html\n   */\n  readonly jobRole?: iam.IRole;\n\n  /**\n   * Linux-specific modifications that are applied to the container, such as details for device mappings.\n   *\n   * @default none\n   */\n  readonly linuxParameters?: LinuxParameters;\n\n  /**\n   * The configuration of the log driver\n   */\n  readonly logDriverConfig?: ecs.LogDriverConfig;\n\n  /**\n   * Gives the container readonly access to its root filesystem.\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * A map from environment variable names to the secrets for the container. Allows your job definitions\n   * to reference the secret by the environment variable name defined in this property.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html\n   *\n   * @default - no secrets\n   */\n  readonly secrets?: { [envVarName: string]: Secret };\n\n  /**\n   * The user name to use inside the container\n   *\n   * @default - no user\n   */\n  readonly user?: string;\n\n  /**\n   * The volumes to mount to this container. Automatically added to the job definition.\n   *\n   * @default - no volumes\n   */\n  readonly volumes: EcsVolume[];\n\n  /**\n   * Renders this container to CloudFormation\n   *\n   * @internal\n   */\n  _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty;\n\n  /**\n   * Add a Volume to this container\n   */\n  addVolume(volume: EcsVolume): void;\n}\n\n/**\n * Props to configure an EcsContainerDefinition\n */\nexport interface EcsContainerDefinitionProps {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The number of vCPUs reserved for the container.\n   * Each vCPU is equivalent to 1,024 CPU shares.\n   * For containers running on EC2 resources, you must specify at least one vCPU.\n   */\n  readonly cpu: number;\n\n  /**\n   * The memory hard limit present to the container.\n   * If your container attempts to exceed the memory specified, the container is terminated.\n   * You must specify at least 4 MiB of memory for a job.\n   */\n  readonly memory: Size;\n\n  /**\n   * The command that's passed to the container\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   *\n   * @default - no command\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to a container.\n   * Cannot start with `AWS_BATCH`.\n   * We don't recommend using plaintext environment variables for sensitive information, such as credential data.\n   *\n   * @default - no environment variables\n   */\n  readonly environment?: { [key:string]: string };\n\n  /**\n   * The role used by Amazon ECS container and AWS Fargate agents to make AWS API calls on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/execution-IAM-role.html\n   *\n   * @default - a Role will be created\n   */\n  readonly executionRole?: iam.IRole;\n\n  /**\n   * The role that the container can assume.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html\n   *\n   * @default - no job role\n   */\n  readonly jobRole?: iam.IRole;\n\n  /**\n   * Linux-specific modifications that are applied to the container, such as details for device mappings.\n   *\n   * @default none\n   */\n  readonly linuxParameters?: LinuxParameters;\n\n  /**\n   * The loging configuration for this Job\n   *\n   * @default - the log configuration of the Docker daemon\n   */\n  readonly logging?: ecs.LogDriver;\n\n  /**\n   * Gives the container readonly access to its root filesystem.\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * A map from environment variable names to the secrets for the container. Allows your job definitions\n   * to reference the secret by the environment variable name defined in this property.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/specifying-sensitive-data.html\n   *\n   * @default - no secrets\n   */\n  readonly secrets?: { [envVarName: string]: Secret };\n\n  /**\n   * The user name to use inside the container\n   *\n   * @default - no user\n   */\n  readonly user?: string;\n\n  /**\n   * The volumes to mount to this container. Automatically added to the job definition.\n   *\n   * @default - no volumes\n   */\n  readonly volumes?: EcsVolume[];\n}\n\n/**\n * Abstract base class for ECS Containers\n */\nabstract class EcsContainerDefinitionBase extends Construct implements IEcsContainerDefinition {\n  public readonly image: ecs.ContainerImage;\n  public readonly cpu: number;\n  public readonly memory: Size;\n  public readonly command?: string[];\n  public readonly environment?: { [key:string]: string };\n  public readonly executionRole: iam.IRole;\n  public readonly jobRole?: iam.IRole;\n  public readonly linuxParameters?: LinuxParameters;\n  public readonly logDriverConfig?: ecs.LogDriverConfig;\n  public readonly readonlyRootFilesystem?: boolean;\n  public readonly secrets?: { [envVarName: string]: Secret };\n  public readonly user?: string;\n  public readonly volumes: EcsVolume[];\n\n  private readonly imageConfig: ecs.ContainerImageConfig;\n\n  constructor(scope: Construct, id: string, props: EcsContainerDefinitionProps) {\n    super(scope, id);\n\n    this.image = props.image;\n    this.cpu = props.cpu;\n    this.command = props.command;\n    this.environment = props.environment;\n    this.executionRole = props.executionRole ?? createExecutionRole(this, 'ExecutionRole', props.logging ? true : false);\n    this.jobRole = props.jobRole;\n    this.linuxParameters = props.linuxParameters;\n    this.memory = props.memory;\n\n    if (props.logging) {\n      this.logDriverConfig = props.logging.bind(this, {\n        ...this as any,\n        // TS!\n        taskDefinition: {\n          obtainExecutionRole: () => this.executionRole,\n        },\n      });\n    }\n\n    this.readonlyRootFilesystem = props.readonlyRootFilesystem ?? false;\n    this.secrets = props.secrets;\n    this.user = props.user;\n    this.volumes = props.volumes ?? [];\n\n    this.imageConfig = props.image.bind(this, {\n      ...this as any,\n      taskDefinition: {\n        obtainExecutionRole: () => this.executionRole,\n      },\n    });\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      image: this.imageConfig.imageName,\n      command: this.command,\n      environment: Object.keys(this.environment ?? {}).map((envKey) => ({\n        name: envKey,\n        value: (this.environment ?? {})[envKey],\n      })),\n      jobRoleArn: this.jobRole?.roleArn,\n      executionRoleArn: this.executionRole?.roleArn,\n      linuxParameters: this.linuxParameters && this.linuxParameters.renderLinuxParameters(),\n      logConfiguration: this.logDriverConfig,\n      readonlyRootFilesystem: this.readonlyRootFilesystem,\n      resourceRequirements: this._renderResourceRequirements(),\n      secrets: this.secrets ? Object.entries(this.secrets).map(([name, secret]) => {\n        secret.grantRead(this.executionRole);\n\n        return {\n          name,\n          valueFrom: secret.arn,\n        };\n      }) : undefined,\n      mountPoints: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n          return this.volumes.map((volume) => {\n            return {\n              containerPath: volume.containerPath,\n              readOnly: volume.readonly,\n              sourceVolume: volume.name,\n            };\n          });\n        },\n      }),\n      volumes: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n\n          return this.volumes.map((volume) => {\n            if (EfsVolume.isEfsVolume(volume)) {\n              return {\n                name: volume.name,\n                efsVolumeConfiguration: {\n                  fileSystemId: volume.fileSystem.fileSystemId,\n                  rootDirectory: volume.rootDirectory,\n                  transitEncryption: volume.enableTransitEncryption ? 'ENABLED' : (volume.enableTransitEncryption === false ? 'DISABLED' : undefined),\n                  transitEncryptionPort: volume.transitEncryptionPort,\n                  authorizationConfig: volume.accessPointId || volume.useJobRole ? {\n                    accessPointId: volume.accessPointId,\n                    iam: volume.useJobRole ? 'ENABLED' : (volume.useJobRole === false ? 'DISABLED' : undefined),\n                  } : undefined,\n                },\n              };\n            } else if (HostVolume.isHostVolume(volume)) {\n              return {\n                name: volume.name,\n                host: {\n                  sourcePath: volume.hostPath,\n                },\n              };\n            }\n\n            throw new Error('unsupported Volume encountered');\n          });\n        },\n      }),\n      user: this.user,\n    };\n  }\n\n  public addVolume(volume: EcsVolume): void {\n    this.volumes.push(volume);\n  }\n\n  /**\n   * @internal\n   */\n  protected _renderResourceRequirements() {\n    const resourceRequirements = [];\n\n    resourceRequirements.push({\n      type: 'MEMORY',\n      value: this.memory.toMebibytes().toString(),\n    });\n\n    resourceRequirements.push({\n      type: 'VCPU',\n      value: this.cpu.toString(),\n    });\n\n    return resourceRequirements;\n  }\n}\n\n/**\n * Sets limits for a resource with `ulimit` on linux systems.\n * Used by the Docker daemon.\n */\nexport interface Ulimit {\n  /**\n   * The hard limit for this resource. The container will\n   * be terminated if it exceeds this limit.\n   */\n  readonly hardLimit: number;\n\n  /**\n   * The resource to limit\n   */\n  readonly name: UlimitName;\n\n  /**\n   * The reservation for this resource. The container will\n   * not be terminated if it exceeds this limit.\n   */\n  readonly softLimit: number;\n}\n\n/**\n * The resources to be limited\n */\nexport enum UlimitName {\n  /**\n   * max core dump file size\n   */\n  CORE = 'core',\n\n  /**\n   * max cpu time (seconds) for a process\n   */\n  CPU = 'cpu',\n\n  /**\n   * max data segment size\n   */\n  DATA = 'data',\n\n  /**\n   * max file size\n   */\n  FSIZE = 'fsize',\n\n  /**\n   * max number of file locks\n   */\n  LOCKS = 'locks',\n\n  /**\n   * max locked memory\n   */\n  MEMLOCK = 'memlock',\n\n  /**\n   * max POSIX message queue size\n   */\n  MSGQUEUE = 'msgqueue',\n\n  /**\n   * max nice value for any process this user is running\n   */\n  NICE = 'nice',\n\n  /**\n   * maximum number of open file descriptors\n   */\n  NOFILE = 'nofile',\n\n  /**\n   * maximum number of processes\n   */\n  NPROC = 'nproc',\n\n  /**\n   * size of the process' resident set (in pages)\n   */\n  RSS = 'rss',\n\n  /**\n   * max realtime priority\n   */\n  RTPRIO = 'rtprio',\n\n  /**\n   * timeout for realtime tasks\n   */\n  RTTIME = 'rttime',\n\n  /**\n   * max number of pending signals\n   */\n  SIGPENDING = 'sigpending',\n\n  /**\n   * max stack size (in bytes)\n   */\n  STACK = 'stack',\n}\n\n/**\n * A container orchestrated by ECS that uses EC2 resources\n */\nexport interface IEcsEc2ContainerDefinition extends IEcsContainerDefinition {\n  /**\n   * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user).\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Limits to set for the user this docker container will run as\n   */\n  readonly ulimits: Ulimit[];\n\n  /**\n   * The number of physical GPUs to reserve for the container.\n   * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\n   * the number of available GPUs on the compute resource that the job is launched on.\n   *\n   * @default - no gpus\n   */\n  readonly gpu?: number;\n\n  /**\n   * Add a ulimit to this container\n   */\n  addUlimit(ulimit: Ulimit): void;\n}\n\n/**\n * Props to configure an EcsEc2ContainerDefinition\n */\nexport interface EcsEc2ContainerDefinitionProps extends EcsContainerDefinitionProps {\n  /**\n   * When this parameter is true, the container is given elevated permissions on the host container instance (similar to the root user).\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Limits to set for the user this docker container will run as\n   *\n   * @default - no ulimits\n   */\n  readonly ulimits?: Ulimit[];\n\n  /**\n   * The number of physical GPUs to reserve for the container.\n   * Make sure that the number of GPUs reserved for all containers in a job doesn't exceed\n   * the number of available GPUs on the compute resource that the job is launched on.\n   *\n   * @default - no gpus\n   */\n  readonly gpu?: number;\n}\n\n/**\n * A container orchestrated by ECS that uses EC2 resources\n */\nexport class EcsEc2ContainerDefinition extends EcsContainerDefinitionBase implements IEcsEc2ContainerDefinition {\n  public readonly privileged?: boolean;\n  public readonly ulimits: Ulimit[];\n  public readonly gpu?: number;\n\n  constructor(scope: Construct, id: string, props: EcsEc2ContainerDefinitionProps) {\n    super(scope, id, props);\n    this.privileged = props.privileged;\n    this.ulimits = props.ulimits ?? [];\n    this.gpu = props.gpu;\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      ...super._renderContainerDefinition(),\n      ulimits: Lazy.any({\n        produce: () => {\n          if (this.ulimits.length === 0) {\n            return undefined;\n          }\n\n          return this.ulimits.map((ulimit) => ({\n            hardLimit: ulimit.hardLimit,\n            name: ulimit.name,\n            softLimit: ulimit.softLimit,\n          }));\n        },\n      }),\n      privileged: this.privileged,\n      resourceRequirements: this._renderResourceRequirements(),\n    };\n  };\n\n  /**\n   * Add a ulimit to this container\n   */\n  addUlimit(ulimit: Ulimit): void {\n    this.ulimits.push(ulimit);\n  }\n\n  /**\n   * @internal\n   */\n  protected _renderResourceRequirements() {\n    const resourceRequirements = super._renderResourceRequirements();\n    if (this.gpu) {\n      resourceRequirements.push({\n        type: 'GPU',\n        value: this.gpu.toString(),\n      });\n    }\n\n    return resourceRequirements;\n  }\n}\n\n/**\n * A container orchestrated by ECS that uses Fargate resources and is orchestrated by ECS\n */\nexport interface IEcsFargateContainerDefinition extends IEcsContainerDefinition {\n  /**\n   * Indicates whether the job has a public IP address.\n   * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n   * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html\n   *\n   * @default false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Which version of Fargate to use when running this container\n   *\n   * @default LATEST\n   */\n  readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n\n  /**\n   * The size for ephemeral storage.\n   *\n   * @default - 20 GiB\n   */\n  readonly ephemeralStorageSize?: Size;\n}\n\n/**\n * Props to configure an EcsFargateContainerDefinition\n */\nexport interface EcsFargateContainerDefinitionProps extends EcsContainerDefinitionProps {\n  /**\n   * Indicates whether the job has a public IP address.\n   * For a job that's running on Fargate resources in a private subnet to send outbound traffic to the internet\n   * (for example, to pull container images), the private subnet requires a NAT gateway be attached to route requests to the internet.\n   *\n   * @see https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-networking.html\n   *\n   * @default false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Which version of Fargate to use when running this container\n   *\n   * @default LATEST\n   */\n  readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n\n  /**\n   * The size for ephemeral storage.\n   *\n   * @default - 20 GiB\n   */\n  readonly ephemeralStorageSize?: Size;\n}\n\n/**\n * A container orchestrated by ECS that uses Fargate resources\n */\nexport class EcsFargateContainerDefinition extends EcsContainerDefinitionBase implements IEcsFargateContainerDefinition {\n  public readonly fargatePlatformVersion?: ecs.FargatePlatformVersion;\n  public readonly assignPublicIp?: boolean;\n  public readonly ephemeralStorageSize?: Size;\n\n  constructor(scope: Construct, id: string, props: EcsFargateContainerDefinitionProps) {\n    super(scope, id, props);\n    this.assignPublicIp = props.assignPublicIp;\n    this.fargatePlatformVersion = props.fargatePlatformVersion;\n    this.ephemeralStorageSize = props.ephemeralStorageSize;\n\n    // validates ephemeralStorageSize is within limits\n    if (props.ephemeralStorageSize) {\n      if (props.ephemeralStorageSize.toGibibytes() > 200) {\n        throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} > 200 GB`);\n      } else if (props.ephemeralStorageSize.toGibibytes() < 21) {\n        throw new Error(`ECS Fargate container '${id}' specifies 'ephemeralStorageSize' at ${props.ephemeralStorageSize.toGibibytes()} < 21 GB`);\n      }\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.ContainerPropertiesProperty {\n    return {\n      ...super._renderContainerDefinition(),\n      ephemeralStorage: this.ephemeralStorageSize? {\n        sizeInGiB: this.ephemeralStorageSize?.toGibibytes(),\n      } : undefined,\n      fargatePlatformConfiguration: {\n        platformVersion: this.fargatePlatformVersion?.toString(),\n      },\n      networkConfiguration: {\n        assignPublicIp: this.assignPublicIp ? 'ENABLED' : 'DISABLED',\n      },\n    };\n  };\n}\n\nfunction createExecutionRole(scope: Construct, id: string, logging: boolean): iam.IRole {\n  const execRole = new iam.Role(scope, id, {\n    assumedBy: new iam.ServicePrincipal('ecs-tasks.amazonaws.com'),\n    // needed for cross-account access with TagParameterContainerImage\n    roleName: PhysicalName.GENERATE_IF_NEEDED,\n  });\n\n  if (!logging) {\n    // all jobs will fail without this if they produce any output at all when no logging is specified\n    LogGroup.fromLogGroupName(scope, 'batchDefaultLogGroup', '/aws/batch/job').grantWrite(execRole);\n  }\n\n  return execRole;\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts deleted file mode 100644 index f387b11752d75..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.d.ts +++ /dev/null @@ -1,67 +0,0 @@ -import { Construct } from 'constructs'; -import { IEcsContainerDefinition } from './ecs-container-definition'; -import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; -import * as iam from 'aws-cdk-lib/aws-iam'; -import { IJobQueue } from './job-queue'; -/** - * A JobDefinition that uses ECS orchestration - */ -interface IEcsJobDefinition extends IJobDefinition { - /** - * The container that this job will run - */ - readonly container: IEcsContainerDefinition; - /** - * Whether to propogate tags from the JobDefinition - * to the ECS task that Batch spawns - * - * @default false - */ - readonly propagateTags?: boolean; -} -/** - * @internal - */ -export declare enum Compatibility { - EC2 = "EC2", - FARGATE = "FARGATE" -} -/** - * Props for EcsJobDefinition - */ -export interface EcsJobDefinitionProps extends JobDefinitionProps { - /** - * The container that this job will run - */ - readonly container: IEcsContainerDefinition; - /** - * Whether to propogate tags from the JobDefinition - * to the ECS task that Batch spawns - * - * @default false - */ - readonly propagateTags?: boolean; -} -/** - * A JobDefinition that uses ECS orchestration - * - * @resource AWS::Batch::JobDefinition - */ -export declare class EcsJobDefinition extends JobDefinitionBase implements IEcsJobDefinition { - /** - * Import a JobDefinition by its arn. - */ - static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition; - private static getJobDefinitionName; - readonly container: IEcsContainerDefinition; - readonly propagateTags?: boolean; - readonly jobDefinitionArn: string; - readonly jobDefinitionName: string; - constructor(scope: Construct, id: string, props: EcsJobDefinitionProps); - /** - * Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue` - */ - grantSubmitJob(identity: iam.IGrantable, queue: IJobQueue): void; - private renderPlatformCapabilities; -} -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js deleted file mode 100644 index e10f4f02ae1a9..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/ecs-job-definition.js +++ /dev/null @@ -1,102 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EcsJobDefinition = exports.Compatibility = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -const ecs_container_definition_1 = require("./ecs-container-definition"); -const job_definition_base_1 = require("./job-definition-base"); -const iam = require("aws-cdk-lib/aws-iam"); -/** - * @internal - */ -var Compatibility; -(function (Compatibility) { - Compatibility["EC2"] = "EC2"; - Compatibility["FARGATE"] = "FARGATE"; -})(Compatibility || (exports.Compatibility = Compatibility = {})); -/** - * A JobDefinition that uses ECS orchestration - * - * @resource AWS::Batch::JobDefinition - */ -class EcsJobDefinition extends job_definition_base_1.JobDefinitionBase { - /** - * Import a JobDefinition by its arn. - */ - static fromJobDefinitionArn(scope, id, jobDefinitionArn) { - class Import extends job_definition_base_1.JobDefinitionBase { - constructor() { - super(...arguments); - this.jobDefinitionArn = jobDefinitionArn; - this.jobDefinitionName = EcsJobDefinition.getJobDefinitionName(this, jobDefinitionArn); - this.enabled = true; - this.container = {}; - } - } - return new Import(scope, id); - } - static getJobDefinitionName(scope, jobDefinitionArn) { - const resourceName = core_1.Stack.of(scope).splitArn(jobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - return resourceName.split(':')[0]; - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EcsJobDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EcsJobDefinition); - } - throw error; - } - this.container = props.container; - this.propagateTags = props?.propagateTags; - const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { - ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), - type: 'container', - jobDefinitionName: props.jobDefinitionName, - containerProperties: this.container?._renderContainerDefinition(), - platformCapabilities: this.renderPlatformCapabilities(), - propagateTags: this.propagateTags, - }); - this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { - service: 'batch', - resource: 'job-definition', - resourceName: this.physicalName, - }); - this.jobDefinitionName = EcsJobDefinition.getJobDefinitionName(scope, this.jobDefinitionArn); - } - /** - * Grants the `batch:submitJob` permission to the identity on both this job definition and the `queue` - */ - grantSubmitJob(identity, queue) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_IJobQueue(queue); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.grantSubmitJob); - } - throw error; - } - iam.Grant.addToPrincipal({ - actions: ['batch:SubmitJob'], - grantee: identity, - resourceArns: [this.jobDefinitionArn, queue.jobQueueArn], - }); - } - renderPlatformCapabilities() { - if (this.container instanceof ecs_container_definition_1.EcsEc2ContainerDefinition) { - return [Compatibility.EC2]; - } - return [Compatibility.FARGATE]; - } -} -exports.EcsJobDefinition = EcsJobDefinition; -_a = JSII_RTTI_SYMBOL_1; -EcsJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EcsJobDefinition", version: "0.0.0" }; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZWNzLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDJDQUFvRDtBQUVwRCxxREFBeUQ7QUFDekQseUVBQWdHO0FBQ2hHLCtEQUEySDtBQUMzSCwyQ0FBMkM7QUFxQjNDOztHQUVHO0FBQ0gsSUFBWSxhQUdYO0FBSEQsV0FBWSxhQUFhO0lBQ3ZCLDRCQUFXLENBQUE7SUFDWCxvQ0FBbUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsYUFBYSw2QkFBYixhQUFhLFFBR3hCO0FBb0JEOzs7O0dBSUc7QUFDSCxNQUFhLGdCQUFpQixTQUFRLHVDQUFpQjtJQUNyRDs7T0FFRztJQUNJLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxnQkFBd0I7UUFDdkYsTUFBTSxNQUFPLFNBQVEsdUNBQWlCO1lBQXRDOztnQkFDa0IscUJBQWdCLEdBQUcsZ0JBQWdCLENBQUM7Z0JBQ3BDLHNCQUFpQixHQUFHLGdCQUFnQixDQUFDLG9CQUFvQixDQUFDLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO2dCQUNsRixZQUFPLEdBQUcsSUFBSSxDQUFDO2dCQUMvQixjQUFTLEdBQUcsRUFBUyxDQUFDO1lBQ3hCLENBQUM7U0FBQTtRQUVELE9BQU8sSUFBSSxNQUFNLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0tBQzlCO0lBRU8sTUFBTSxDQUFDLG9CQUFvQixDQUFDLEtBQWdCLEVBQUUsZ0JBQXdCO1FBQzVFLE1BQU0sWUFBWSxHQUFHLFlBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsUUFBUSxDQUFDLGdCQUFnQixFQUFFLGdCQUFTLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxZQUFhLENBQUM7UUFDN0csT0FBTyxZQUFZLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ25DO0lBUUQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUE0QjtRQUNwRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQzs7Ozs7OytDQTNCZixnQkFBZ0I7Ozs7UUE2QnpCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQztRQUNqQyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssRUFBRSxhQUFhLENBQUM7UUFFMUMsTUFBTSxRQUFRLEdBQUcsSUFBSSw0QkFBZ0IsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ3RELEdBQUcsSUFBQSxpREFBMkIsRUFBQyxJQUFJLENBQUM7WUFDcEMsSUFBSSxFQUFFLFdBQVc7WUFDakIsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGlCQUFpQjtZQUMxQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLDBCQUEwQixFQUFFO1lBQ2pFLG9CQUFvQixFQUFFLElBQUksQ0FBQywwQkFBMEIsRUFBRTtZQUN2RCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7U0FDbEMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ2pFLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLFFBQVEsRUFBRSxnQkFBZ0I7WUFDMUIsWUFBWSxFQUFFLElBQUksQ0FBQyxZQUFZO1NBQ2hDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxpQkFBaUIsR0FBRyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7S0FDOUY7SUFFRDs7TUFFRTtJQUNLLGNBQWMsQ0FBQyxRQUF3QixFQUFFLEtBQWdCOzs7Ozs7Ozs7O1FBQzlELEdBQUcsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDO1lBQ3ZCLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO1lBQzVCLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsV0FBVyxDQUFDO1NBQ3pELENBQUMsQ0FBQztLQUNKO0lBRU8sMEJBQTBCO1FBQ2hDLElBQUksSUFBSSxDQUFDLFNBQVMsWUFBWSxvREFBeUIsRUFBRTtZQUN2RCxPQUFPLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzVCO1FBRUQsT0FBTyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUNoQzs7QUFsRUgsNENBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXJuRm9ybWF0LCBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliL2NvcmUnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBDZm5Kb2JEZWZpbml0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWJhdGNoJztcbmltcG9ydCB7IEVjc0VjMkNvbnRhaW5lckRlZmluaXRpb24sIElFY3NDb250YWluZXJEZWZpbml0aW9uIH0gZnJvbSAnLi9lY3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuaW1wb3J0IHsgYmFzZUpvYkRlZmluaXRpb25Qcm9wZXJ0aWVzLCBJSm9iRGVmaW5pdGlvbiwgSm9iRGVmaW5pdGlvbkJhc2UsIEpvYkRlZmluaXRpb25Qcm9wcyB9IGZyb20gJy4vam9iLWRlZmluaXRpb24tYmFzZSc7XG5pbXBvcnQgKiBhcyBpYW0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWlhbSc7XG5pbXBvcnQgeyBJSm9iUXVldWUgfSBmcm9tICcuL2pvYi1xdWV1ZSc7XG5cbi8qKlxuICogQSBKb2JEZWZpbml0aW9uIHRoYXQgdXNlcyBFQ1Mgb3JjaGVzdHJhdGlvblxuICovXG5pbnRlcmZhY2UgSUVjc0pvYkRlZmluaXRpb24gZXh0ZW5kcyBJSm9iRGVmaW5pdGlvbiB7XG4gIC8qKlxuICAgKiBUaGUgY29udGFpbmVyIHRoYXQgdGhpcyBqb2Igd2lsbCBydW5cbiAgICovXG4gIHJlYWRvbmx5IGNvbnRhaW5lcjogSUVjc0NvbnRhaW5lckRlZmluaXRpb25cblxuICAvKipcbiAgICogV2hldGhlciB0byBwcm9wb2dhdGUgdGFncyBmcm9tIHRoZSBKb2JEZWZpbml0aW9uXG4gICAqIHRvIHRoZSBFQ1MgdGFzayB0aGF0IEJhdGNoIHNwYXduc1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcGFnYXRlVGFncz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBlbnVtIENvbXBhdGliaWxpdHkge1xuICBFQzIgPSAnRUMyJyxcbiAgRkFSR0FURSA9ICdGQVJHQVRFJyxcbn1cblxuLyoqXG4gKiBQcm9wcyBmb3IgRWNzSm9iRGVmaW5pdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVjc0pvYkRlZmluaXRpb25Qcm9wcyBleHRlbmRzIEpvYkRlZmluaXRpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgY29udGFpbmVyIHRoYXQgdGhpcyBqb2Igd2lsbCBydW5cbiAgICovXG4gIHJlYWRvbmx5IGNvbnRhaW5lcjogSUVjc0NvbnRhaW5lckRlZmluaXRpb25cblxuICAvKipcbiAgICogV2hldGhlciB0byBwcm9wb2dhdGUgdGFncyBmcm9tIHRoZSBKb2JEZWZpbml0aW9uXG4gICAqIHRvIHRoZSBFQ1MgdGFzayB0aGF0IEJhdGNoIHNwYXduc1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcGFnYXRlVGFncz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBKb2JEZWZpbml0aW9uIHRoYXQgdXNlcyBFQ1Mgb3JjaGVzdHJhdGlvblxuICpcbiAqIEByZXNvdXJjZSBBV1M6OkJhdGNoOjpKb2JEZWZpbml0aW9uXG4gKi9cbmV4cG9ydCBjbGFzcyBFY3NKb2JEZWZpbml0aW9uIGV4dGVuZHMgSm9iRGVmaW5pdGlvbkJhc2UgaW1wbGVtZW50cyBJRWNzSm9iRGVmaW5pdGlvbiB7XG4gIC8qKlxuICAgKiBJbXBvcnQgYSBKb2JEZWZpbml0aW9uIGJ5IGl0cyBhcm4uXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21Kb2JEZWZpbml0aW9uQXJuKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIGpvYkRlZmluaXRpb25Bcm46IHN0cmluZyk6IElKb2JEZWZpbml0aW9uIHtcbiAgICBjbGFzcyBJbXBvcnQgZXh0ZW5kcyBKb2JEZWZpbml0aW9uQmFzZSBpbXBsZW1lbnRzIElFY3NKb2JEZWZpbml0aW9uIHtcbiAgICAgIHB1YmxpYyByZWFkb25seSBqb2JEZWZpbml0aW9uQXJuID0gam9iRGVmaW5pdGlvbkFybjtcbiAgICAgIHB1YmxpYyByZWFkb25seSBqb2JEZWZpbml0aW9uTmFtZSA9IEVjc0pvYkRlZmluaXRpb24uZ2V0Sm9iRGVmaW5pdGlvbk5hbWUodGhpcywgam9iRGVmaW5pdGlvbkFybik7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgZW5hYmxlZCA9IHRydWU7XG4gICAgICBjb250YWluZXIgPSB7fSBhcyBhbnk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ldyBJbXBvcnQoc2NvcGUsIGlkKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGdldEpvYkRlZmluaXRpb25OYW1lKHNjb3BlOiBDb25zdHJ1Y3QsIGpvYkRlZmluaXRpb25Bcm46IHN0cmluZykge1xuICAgIGNvbnN0IHJlc291cmNlTmFtZSA9IFN0YWNrLm9mKHNjb3BlKS5zcGxpdEFybihqb2JEZWZpbml0aW9uQXJuLCBBcm5Gb3JtYXQuU0xBU0hfUkVTT1VSQ0VfTkFNRSkucmVzb3VyY2VOYW1lITtcbiAgICByZXR1cm4gcmVzb3VyY2VOYW1lLnNwbGl0KCc6JylbMF07XG4gIH1cblxuICByZWFkb25seSBjb250YWluZXI6IElFY3NDb250YWluZXJEZWZpbml0aW9uXG4gIHB1YmxpYyByZWFkb25seSBwcm9wYWdhdGVUYWdzPzogYm9vbGVhbjtcblxuICBwdWJsaWMgcmVhZG9ubHkgam9iRGVmaW5pdGlvbkFybjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgam9iRGVmaW5pdGlvbk5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRWNzSm9iRGVmaW5pdGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCBwcm9wcyk7XG5cbiAgICB0aGlzLmNvbnRhaW5lciA9IHByb3BzLmNvbnRhaW5lcjtcbiAgICB0aGlzLnByb3BhZ2F0ZVRhZ3MgPSBwcm9wcz8ucHJvcGFnYXRlVGFncztcblxuICAgIGNvbnN0IHJlc291cmNlID0gbmV3IENmbkpvYkRlZmluaXRpb24odGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgLi4uYmFzZUpvYkRlZmluaXRpb25Qcm9wZXJ0aWVzKHRoaXMpLFxuICAgICAgdHlwZTogJ2NvbnRhaW5lcicsXG4gICAgICBqb2JEZWZpbml0aW9uTmFtZTogcHJvcHMuam9iRGVmaW5pdGlvbk5hbWUsXG4gICAgICBjb250YWluZXJQcm9wZXJ0aWVzOiB0aGlzLmNvbnRhaW5lcj8uX3JlbmRlckNvbnRhaW5lckRlZmluaXRpb24oKSxcbiAgICAgIHBsYXRmb3JtQ2FwYWJpbGl0aWVzOiB0aGlzLnJlbmRlclBsYXRmb3JtQ2FwYWJpbGl0aWVzKCksXG4gICAgICBwcm9wYWdhdGVUYWdzOiB0aGlzLnByb3BhZ2F0ZVRhZ3MsXG4gICAgfSk7XG5cbiAgICB0aGlzLmpvYkRlZmluaXRpb25Bcm4gPSB0aGlzLmdldFJlc291cmNlQXJuQXR0cmlidXRlKHJlc291cmNlLnJlZiwge1xuICAgICAgc2VydmljZTogJ2JhdGNoJyxcbiAgICAgIHJlc291cmNlOiAnam9iLWRlZmluaXRpb24nLFxuICAgICAgcmVzb3VyY2VOYW1lOiB0aGlzLnBoeXNpY2FsTmFtZSxcbiAgICB9KTtcbiAgICB0aGlzLmpvYkRlZmluaXRpb25OYW1lID0gRWNzSm9iRGVmaW5pdGlvbi5nZXRKb2JEZWZpbml0aW9uTmFtZShzY29wZSwgdGhpcy5qb2JEZWZpbml0aW9uQXJuKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHcmFudHMgdGhlIGBiYXRjaDpzdWJtaXRKb2JgIHBlcm1pc3Npb24gdG8gdGhlIGlkZW50aXR5IG9uIGJvdGggdGhpcyBqb2IgZGVmaW5pdGlvbiBhbmQgdGhlIGBxdWV1ZWBcbiAgKi9cbiAgcHVibGljIGdyYW50U3VibWl0Sm9iKGlkZW50aXR5OiBpYW0uSUdyYW50YWJsZSwgcXVldWU6IElKb2JRdWV1ZSkge1xuICAgIGlhbS5HcmFudC5hZGRUb1ByaW5jaXBhbCh7XG4gICAgICBhY3Rpb25zOiBbJ2JhdGNoOlN1Ym1pdEpvYiddLFxuICAgICAgZ3JhbnRlZTogaWRlbnRpdHksXG4gICAgICByZXNvdXJjZUFybnM6IFt0aGlzLmpvYkRlZmluaXRpb25Bcm4sIHF1ZXVlLmpvYlF1ZXVlQXJuXSxcbiAgICB9KTtcbiAgfVxuXG4gIHByaXZhdGUgcmVuZGVyUGxhdGZvcm1DYXBhYmlsaXRpZXMoKSB7XG4gICAgaWYgKHRoaXMuY29udGFpbmVyIGluc3RhbmNlb2YgRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbikge1xuICAgICAgcmV0dXJuIFtDb21wYXRpYmlsaXR5LkVDMl07XG4gICAgfVxuXG4gICAgcmV0dXJuIFtDb21wYXRpYmlsaXR5LkZBUkdBVEVdO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts deleted file mode 100644 index 4e12fa25a1851..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.d.ts +++ /dev/null @@ -1,728 +0,0 @@ -import * as ecs from 'aws-cdk-lib/aws-ecs'; -import { Size } from 'aws-cdk-lib/core'; -import { Construct, IConstruct } from 'constructs'; -import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; -/** - * A container that can be run with EKS orchestration on EC2 resources - */ -export interface IEksContainerDefinition extends IConstruct { - /** - * The image that this container will run - */ - readonly image: ecs.ContainerImage; - /** - * An array of arguments to the entrypoint. - * If this isn't specified, the CMD of the container image is used. - * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes. - * Environment variable references are expanded using the container's environment. - * If the referenced environment variable doesn't exist, the reference in the command isn't changed. - * For example, if the reference is to "$(NAME1)" and the NAME1 environment variable doesn't exist, - * the command string will remain "$(NAME1)." $$ is replaced with $, and the resulting string isn't expanded. - * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists. - * - * @see https://docs.docker.com/engine/reference/builder/#cmd - * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ - */ - readonly args?: string[]; - /** - * The entrypoint for the container. This isn't run within a shell. - * If this isn't specified, the `ENTRYPOINT` of the container image is used. - * Environment variable references are expanded using the container's environment. - * If the referenced environment variable doesn't exist, the reference in the command isn't changed. - * For example, if the reference is to `"$(NAME1)"` and the `NAME1` environment variable doesn't exist, - * the command string will remain `"$(NAME1)."` `$$` is replaced with `$` and the resulting string isn't expanded. - * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists. - - * The entrypoint can't be updated. - * - * @see https://docs.docker.com/engine/reference/builder/#entrypoint - * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ - * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint - */ - readonly command?: string[]; - /** - * The environment variables to pass to this container. - * - * *Note*: Environment variables cannot start with "AWS_BATCH". - * This naming convention is reserved for variables that AWS Batch sets. - */ - readonly env?: { - [key: string]: string; - }; - /** - * The image pull policy for this container - * - * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images - * - * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise - */ - readonly imagePullPolicy?: ImagePullPolicy; - /** - * The name of this container - * - * @default: `'Default'` - */ - readonly name?: string; - /** - * The amount (in MiB) of memory to present to the container. - * If your container attempts to exceed the allocated memory, it will be terminated. - * - * Must be larger that 4 MiB - * - * At least one of `memoryLimit` and `memoryReservation` is required - * - * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible - * for the specific instance type that you are using. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html - * - * @default - No memory limit - */ - readonly memoryLimit?: Size; - /** - * The soft limit (in MiB) of memory to reserve for the container. - * Your container will be given at least this much memory, but may consume more. - * - * Must be larger that 4 MiB - * - * When system memory is under heavy contention, Docker attempts to keep the - * container memory to this soft limit. However, your container can consume more - * memory when it needs to, up to either the hard limit specified with the memory - * parameter (if applicable), or all of the available memory on the container - * instance, whichever comes first. - * - * At least one of `memoryLimit` and `memoryReservation` is required. - * If both are specified, then `memoryLimit` must be equal to `memoryReservation` - * - * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible - * for the specific instance type that you are using. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html - * - * @default - No memory reserved - */ - readonly memoryReservation?: Size; - /** - * The hard limit of CPUs to present to this container. - * Must be an even multiple of 0.25 - * - * If your container attempts to exceed this limit, it will be terminated. - * - * At least one of `cpuReservation` and `cpuLimit` is required. - * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No CPU limit - */ - readonly cpuLimit?: number; - /** - * The soft limit of CPUs to reserve for the container - * Must be an even multiple of 0.25 - * - * The container will given at least this many CPUs, but may consume more. - * - * At least one of `cpuReservation` and `cpuLimit` is required. - * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No CPUs reserved - */ - readonly cpuReservation?: number; - /** - * The hard limit of GPUs to present to this container. - * - * If your container attempts to exceed this limit, it will be terminated. - * - * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No GPU limit - */ - readonly gpuLimit?: number; - /** - * The soft limit of CPUs to reserve for the container - * Must be an even multiple of 0.25 - * - * The container will given at least this many CPUs, but may consume more. - * - * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No GPUs reserved - */ - readonly gpuReservation?: number; - /** - * If specified, gives this container elevated permissions on the host container instance. - * The level of permissions are similar to the root user permissions. - * - * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems - * - * @default false - */ - readonly privileged?: boolean; - /** - * If specified, gives this container readonly access to its root file system. - * - * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems - * - * @default false - */ - readonly readonlyRootFilesystem?: boolean; - /** - * If specified, the container is run as the specified group ID (`gid`). - * If this parameter isn't specified, the default is the group that's specified in the image metadata. - * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default none - */ - readonly runAsGroup?: number; - /** - * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced. - * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default - the container is *not* required to run as a non-root user - */ - readonly runAsRoot?: boolean; - /** - * If specified, this container is run as the specified user ID (`uid`). - * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default - the user that is specified in the image metadata. - */ - readonly runAsUser?: number; - /** - * The Volumes to mount to this container. - * Automatically added to the Pod. - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/ - */ - readonly volumes: EksVolume[]; - /** - * Mount a Volume to this container. Automatically added to the Pod. - */ - addVolume(volume: EksVolume): void; -} -/** - * Determines when the image is pulled from the registry to launch a container - */ -export declare enum ImagePullPolicy { - /** - * Every time the kubelet launches a container, - * the kubelet queries the container image registry to resolve the name to an image digest. - * If the kubelet has a container image with that exact digest cached locally, - * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest, - * and uses that image to launch the container. - * - * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier - */ - ALWAYS = "Always", - /** - * The image is pulled only if it is not already present locally - */ - IF_NOT_PRESENT = "IfNotPresent", - /** - * The kubelet does not try fetching the image. - * If the image is somehow already present locally, - * the kubelet attempts to start the container; otherwise, startup fails. - * See pre-pulled images for more details. - * - * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images - */ - NEVER = "Never" -} -/** - * Props to configure an EksContainerDefinition - */ -export interface EksContainerDefinitionProps { - /** - * The image that this container will run - */ - readonly image: ecs.ContainerImage; - /** - * An array of arguments to the entrypoint. - * If this isn't specified, the CMD of the container image is used. - * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes. - * Environment variable references are expanded using the container's environment. - * If the referenced environment variable doesn't exist, the reference in the command isn't changed. - * For example, if the reference is to "$(NAME1)" and the NAME1 environment variable doesn't exist, - * the command string will remain "$(NAME1)." $$ is replaced with $, and the resulting string isn't expanded. - * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists. - * - * @see https://docs.docker.com/engine/reference/builder/#cmd - * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ - * - * @default - no args - */ - readonly args?: string[]; - /** - * The entrypoint for the container. This isn't run within a shell. - * If this isn't specified, the `ENTRYPOINT` of the container image is used. - * Environment variable references are expanded using the container's environment. - * If the referenced environment variable doesn't exist, the reference in the command isn't changed. - * For example, if the reference is to `"$(NAME1)"` and the `NAME1` environment variable doesn't exist, - * the command string will remain `"$(NAME1)."` `$$` is replaced with `$` and the resulting string isn't expanded. - * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists. - - * The entrypoint can't be updated. - * - * @see https://docs.docker.com/engine/reference/builder/#entrypoint - * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/ - * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint - * - * @default - no command - */ - readonly command?: string[]; - /** - * The environment variables to pass to this container. - * - * *Note*: Environment variables cannot start with "AWS_BATCH". - * This naming convention is reserved for variables that AWS Batch sets. - * - * @default - no environment variables - */ - readonly env?: { - [key: string]: string; - }; - /** - * The image pull policy for this container - * - * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images - * - * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise - */ - readonly imagePullPolicy?: ImagePullPolicy; - /** - * The name of this container - * - * @default: `'Default'` - */ - readonly name?: string; - /** - * The amount (in MiB) of memory to present to the container. - * If your container attempts to exceed the allocated memory, it will be terminated. - * - * Must be larger that 4 MiB - * - * At least one of `memoryLimit` and `memoryReservation` is required - * - * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible - * for the specific instance type that you are using. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html - * - * @default - No memory limit - */ - readonly memoryLimit?: Size; - /** - * The soft limit (in MiB) of memory to reserve for the container. - * Your container will be given at least this much memory, but may consume more. - * - * Must be larger that 4 MiB - * - * When system memory is under heavy contention, Docker attempts to keep the - * container memory to this soft limit. However, your container can consume more - * memory when it needs to, up to either the hard limit specified with the memory - * parameter (if applicable), or all of the available memory on the container - * instance, whichever comes first. - * - * At least one of `memoryLimit` and `memoryReservation` is required. - * If both are specified, then `memoryLimit` must be equal to `memoryReservation` - * - * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible - * for the specific instance type that you are using. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html - * - * @default - No memory reserved - */ - readonly memoryReservation?: Size; - /** - * The hard limit of CPUs to present to this container. - * Must be an even multiple of 0.25 - * - * If your container attempts to exceed this limit, it will be terminated. - * - * At least one of `cpuReservation` and `cpuLimit` is required. - * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No CPU limit - */ - readonly cpuLimit?: number; - /** - * The soft limit of CPUs to reserve for the container - * Must be an even multiple of 0.25 - * - * The container will given at least this many CPUs, but may consume more. - * - * At least one of `cpuReservation` and `cpuLimit` is required. - * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No CPUs reserved - */ - readonly cpuReservation?: number; - /** - * The hard limit of GPUs to present to this container. - * - * If your container attempts to exceed this limit, it will be terminated. - * - * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No GPU limit - */ - readonly gpuLimit?: number; - /** - * The soft limit of CPUs to reserve for the container - * Must be an even multiple of 0.25 - * - * The container will given at least this many CPUs, but may consume more. - * - * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`. - * - * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ - * - * @default - No GPUs reserved - */ - readonly gpuReservation?: number; - /** - * If specified, gives this container elevated permissions on the host container instance. - * The level of permissions are similar to the root user permissions. - * - * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems - * - * @default false - */ - readonly privileged?: boolean; - /** - * If specified, gives this container readonly access to its root file system. - * - * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems - * - * @default false - */ - readonly readonlyRootFilesystem?: boolean; - /** - * If specified, the container is run as the specified group ID (`gid`). - * If this parameter isn't specified, the default is the group that's specified in the image metadata. - * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default none - */ - readonly runAsGroup?: number; - /** - * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced. - * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default - the container is *not* required to run as a non-root user - */ - readonly runAsRoot?: boolean; - /** - * If specified, this container is run as the specified user ID (`uid`). - * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation. - * - * *Note*: this is only compatible with Kubernetes < v1.25 - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups - * - * @default - the user that is specified in the image metadata. - */ - readonly runAsUser?: number; - /** - * The Volumes to mount to this container. - * Automatically added to the Pod. - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/ - * - * @default - no volumes - */ - readonly volumes?: EksVolume[]; -} -/** - * A container that can be run with EKS orchestration on EC2 resources - */ -export declare class EksContainerDefinition extends Construct implements IEksContainerDefinition { - readonly image: ecs.ContainerImage; - readonly args?: string[]; - readonly command?: string[]; - readonly env?: { - [key: string]: string; - }; - readonly imagePullPolicy?: ImagePullPolicy; - readonly name?: string; - readonly memoryLimit?: Size; - readonly memoryReservation?: Size; - readonly cpuLimit?: number; - readonly cpuReservation?: number; - readonly gpuLimit?: number; - readonly gpuReservation?: number; - readonly privileged?: boolean; - readonly readonlyRootFilesystem?: boolean; - readonly runAsGroup?: number; - readonly runAsRoot?: boolean; - readonly runAsUser?: number; - readonly volumes: EksVolume[]; - private readonly imageConfig; - constructor(scope: Construct, id: string, props: EksContainerDefinitionProps); - addVolume(volume: EksVolume): void; - /** - * - * @internal - */ - _renderContainerDefinition(): CfnJobDefinition.EksContainerProperty; -} -/** - * Options to configure an EksVolume - */ -export interface EksVolumeOptions { - /** - * The name of this volume. - * The name must be a valid DNS subdomain name. - * - * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names - */ - readonly name: string; - /** - * The path on the container where the volume is mounted. - * - * @default - the volume is not mounted - */ - readonly mountPath?: string; - /** - * If specified, the container has readonly access to the volume. - * Otherwise, the container has read/write access. - * - * @default false - */ - readonly readonly?: boolean; -} -/** - * A Volume that can be mounted to a container supported by EKS - */ -export declare abstract class EksVolume { - /** - * Creates a Kubernetes EmptyDir volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir - */ - static emptyDir(options: EmptyDirVolumeOptions): EmptyDirVolume; - /** - * Creates a Kubernetes HostPath volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ - static hostPath(options: HostPathVolumeOptions): HostPathVolume; - /** - * Creates a Kubernetes Secret volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret - */ - static secret(options: SecretPathVolumeOptions): SecretPathVolume; - /** - * The name of this volume. - * The name must be a valid DNS subdomain name. - * - * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names - */ - readonly name: string; - /** - * The path on the container where the container is mounted. - * - * @default - the container is not mounted - */ - readonly containerPath?: string; - /** - * If specified, the container has readonly access to the volume. - * Otherwise, the container has read/write access. - * - * @default false - */ - readonly readonly?: boolean; - constructor(options: EksVolumeOptions); -} -/** - * Options for a Kubernetes EmptyDir volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir - */ -export interface EmptyDirVolumeOptions extends EksVolumeOptions { - /** - * The storage type to use for this Volume. - * - * @default `EmptyDirMediumType.DISK` - */ - readonly medium?: EmptyDirMediumType; - /** - * The maximum size for this Volume - * - * @default - no size limit - */ - readonly sizeLimit?: Size; -} -/** - * What medium the volume will live in - */ -export declare enum EmptyDirMediumType { - /** - * Use the disk storage of the node. - * Items written here will survive node reboots. - */ - DISK = "", - /** - * Use the `tmpfs` volume that is backed by RAM of the node. - * Items written here will *not* survive node reboots. - */ - MEMORY = "Memory" -} -/** - * A Kubernetes EmptyDir volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir - */ -export declare class EmptyDirVolume extends EksVolume { - /** - * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise - */ - static isEmptyDirVolume(x: any): x is EmptyDirVolume; - /** - * The storage type to use for this Volume. - * - * @default `EmptyDirMediumType.DISK` - */ - readonly medium?: EmptyDirMediumType; - /** - * The maximum size for this Volume - * - * @default - no size limit - */ - readonly sizeLimit?: Size; - constructor(options: EmptyDirVolumeOptions); -} -/** - * Options for a kubernetes HostPath volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ -export interface HostPathVolumeOptions extends EksVolumeOptions { - /** - * The path of the file or directory on the host to mount into containers on the pod. - * - * *Note*: HothPath Volumes present many security risks, and should be avoided when possible. - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ - readonly hostPath: string; -} -/** - * A Kubernetes HostPath volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ -export declare class HostPathVolume extends EksVolume { - /** - * returns `true` if `x` is a HostPathVolume, `false` otherwise - */ - static isHostPathVolume(x: any): x is HostPathVolume; - /** - * The path of the file or directory on the host to mount into containers on the pod. - * - * *Note*: HothPath Volumes present many security risks, and should be avoided when possible. - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ - readonly path: string; - constructor(options: HostPathVolumeOptions); -} -/** - * Options for a Kubernetes SecretPath Volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret - */ -export interface SecretPathVolumeOptions extends EksVolumeOptions { - /** - * The name of the secret. - * Must be a valid DNS subdomain name. - * - * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names - */ - readonly secretName: string; - /** - * Specifies whether the secret or the secret's keys must be defined - * - * @default true - */ - readonly optional?: boolean; -} -/** - * Specifies the configuration of a Kubernetes secret volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret - */ -export declare class SecretPathVolume extends EksVolume { - /** - * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise - */ - static isSecretPathVolume(x: any): x is SecretPathVolume; - /** - * The name of the secret. - * Must be a valid DNS subdomain name. - * - * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names - */ - readonly secretName: string; - /** - * Specifies whether the secret or the secret's keys must be defined - * - * @default true - */ - readonly optional?: boolean; - constructor(options: SecretPathVolumeOptions); -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js deleted file mode 100644 index bd9b7beec7a4d..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/eks-container-definition.js +++ /dev/null @@ -1,338 +0,0 @@ -"use strict"; -var _a, _b, _c, _d, _e; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.SecretPathVolume = exports.HostPathVolume = exports.EmptyDirVolume = exports.EmptyDirMediumType = exports.EksVolume = exports.EksContainerDefinition = exports.ImagePullPolicy = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const constructs_1 = require("constructs"); -const EMPTY_DIR_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.EmptyDirVolume'); -const HOST_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.HostPathVolume'); -const SECRET_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.SecretVolume'); -/** - * Determines when the image is pulled from the registry to launch a container - */ -var ImagePullPolicy; -(function (ImagePullPolicy) { - /** - * Every time the kubelet launches a container, - * the kubelet queries the container image registry to resolve the name to an image digest. - * If the kubelet has a container image with that exact digest cached locally, - * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest, - * and uses that image to launch the container. - * - * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier - */ - ImagePullPolicy["ALWAYS"] = "Always"; - /** - * The image is pulled only if it is not already present locally - */ - ImagePullPolicy["IF_NOT_PRESENT"] = "IfNotPresent"; - /** - * The kubelet does not try fetching the image. - * If the image is somehow already present locally, - * the kubelet attempts to start the container; otherwise, startup fails. - * See pre-pulled images for more details. - * - * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images - */ - ImagePullPolicy["NEVER"] = "Never"; -})(ImagePullPolicy || (exports.ImagePullPolicy = ImagePullPolicy = {})); -/** - * A container that can be run with EKS orchestration on EC2 resources - */ -class EksContainerDefinition extends constructs_1.Construct { - constructor(scope, id, props) { - super(scope, id); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksContainerDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EksContainerDefinition); - } - throw error; - } - this.image = props.image; - this.args = props.args; - this.command = props.command; - this.env = props.env; - this.imagePullPolicy = props.imagePullPolicy; - this.name = props.name; - this.memoryLimit = props.memoryLimit; - this.memoryReservation = props.memoryReservation; - this.cpuLimit = props.cpuLimit; - this.cpuReservation = props.cpuReservation; - this.gpuLimit = props.gpuLimit; - this.gpuReservation = props.gpuReservation; - this.privileged = props.privileged; - this.readonlyRootFilesystem = props.readonlyRootFilesystem; - this.runAsGroup = props.runAsGroup; - this.runAsRoot = props.runAsRoot; - this.runAsUser = props.runAsUser; - this.volumes = props.volumes ?? []; - this.imageConfig = props.image.bind(this, this); - } - addVolume(volume) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksVolume(volume); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addVolume); - } - throw error; - } - this.volumes.push(volume); - } - /** - * - * @internal - */ - _renderContainerDefinition() { - return { - image: this.imageConfig.imageName, - command: this.command, - args: this.args, - env: Object.keys(this.env ?? {}).map((key) => { - return { - name: key, - value: this.env[key], - }; - }), - name: this.name, - imagePullPolicy: this.imagePullPolicy, - resources: { - limits: { - 'cpu': this.cpuLimit, - 'memory': this.memoryLimit ? this.memoryLimit.toMebibytes() + 'Mi' : undefined, - 'nvidia.com/gpu': this.gpuLimit, - }, - requests: { - 'cpu': this.cpuReservation, - 'memory': this.memoryReservation ? this.memoryReservation.toMebibytes() + 'Mi' : undefined, - 'nvidia.com/gpu': this.gpuReservation, - }, - }, - securityContext: { - privileged: this.privileged, - readOnlyRootFilesystem: this.readonlyRootFilesystem, - runAsGroup: this.runAsGroup, - runAsNonRoot: !this.runAsRoot, - runAsUser: this.runAsUser, - }, - volumeMounts: core_1.Lazy.any({ - produce: () => { - if (this.volumes.length === 0) { - return undefined; - } - return this.volumes.map((volume) => { - return { - name: volume.name, - mountPath: volume.containerPath, - readOnly: volume.readonly, - }; - }); - }, - }), - }; - } - ; -} -exports.EksContainerDefinition = EksContainerDefinition; -_a = JSII_RTTI_SYMBOL_1; -EksContainerDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EksContainerDefinition", version: "0.0.0" }; -/** - * A Volume that can be mounted to a container supported by EKS - */ -class EksVolume { - /** - * Creates a Kubernetes EmptyDir volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir - */ - static emptyDir(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.emptyDir); - } - throw error; - } - return new EmptyDirVolume(options); - } - /** - * Creates a Kubernetes HostPath volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ - static hostPath(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostPathVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.hostPath); - } - throw error; - } - return new HostPathVolume(options); - } - /** - * Creates a Kubernetes Secret volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret - */ - static secret(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.secret); - } - throw error; - } - return new SecretPathVolume(options); - } - constructor(options) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EksVolume); - } - throw error; - } - this.name = options.name; - this.containerPath = options.mountPath; - this.readonly = options.readonly; - } -} -exports.EksVolume = EksVolume; -_b = JSII_RTTI_SYMBOL_1; -EksVolume[_b] = { fqn: "@aws-cdk/aws-batch-alpha.EksVolume", version: "0.0.0" }; -/** - * What medium the volume will live in - */ -var EmptyDirMediumType; -(function (EmptyDirMediumType) { - /** - * Use the disk storage of the node. - * Items written here will survive node reboots. - */ - EmptyDirMediumType["DISK"] = ""; - /** - * Use the `tmpfs` volume that is backed by RAM of the node. - * Items written here will *not* survive node reboots. - */ - EmptyDirMediumType["MEMORY"] = "Memory"; -})(EmptyDirMediumType || (exports.EmptyDirMediumType = EmptyDirMediumType = {})); -/** - * A Kubernetes EmptyDir volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir - */ -class EmptyDirVolume extends EksVolume { - /** - * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise - */ - static isEmptyDirVolume(x) { - return x !== null && typeof (x) === 'object' && EMPTY_DIR_VOLUME_SYMBOL in x; - } - constructor(options) { - super(options); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EmptyDirVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EmptyDirVolume); - } - throw error; - } - this.medium = options.medium; - this.sizeLimit = options.sizeLimit; - } -} -exports.EmptyDirVolume = EmptyDirVolume; -_c = JSII_RTTI_SYMBOL_1; -EmptyDirVolume[_c] = { fqn: "@aws-cdk/aws-batch-alpha.EmptyDirVolume", version: "0.0.0" }; -Object.defineProperty(EmptyDirVolume.prototype, EMPTY_DIR_VOLUME_SYMBOL, { - value: true, - enumerable: false, - writable: false, -}); -/** - * A Kubernetes HostPath volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath - */ -class HostPathVolume extends EksVolume { - /** - * returns `true` if `x` is a HostPathVolume, `false` otherwise - */ - static isHostPathVolume(x) { - return x !== null && typeof (x) === 'object' && HOST_PATH_VOLUME_SYMBOL in x; - } - constructor(options) { - super(options); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_HostPathVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, HostPathVolume); - } - throw error; - } - this.path = options.hostPath; - } -} -exports.HostPathVolume = HostPathVolume; -_d = JSII_RTTI_SYMBOL_1; -HostPathVolume[_d] = { fqn: "@aws-cdk/aws-batch-alpha.HostPathVolume", version: "0.0.0" }; -Object.defineProperty(HostPathVolume.prototype, HOST_PATH_VOLUME_SYMBOL, { - value: true, - enumerable: false, - writable: false, -}); -/** - * Specifies the configuration of a Kubernetes secret volume - * - * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret - */ -class SecretPathVolume extends EksVolume { - /** - * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise - */ - static isSecretPathVolume(x) { - return x !== null && typeof (x) === 'object' && SECRET_PATH_VOLUME_SYMBOL in x; - } - constructor(options) { - super(options); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_SecretPathVolumeOptions(options); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, SecretPathVolume); - } - throw error; - } - this.secretName = options.secretName; - this.optional = options.optional ?? true; - } -} -exports.SecretPathVolume = SecretPathVolume; -_e = JSII_RTTI_SYMBOL_1; -SecretPathVolume[_e] = { fqn: "@aws-cdk/aws-batch-alpha.SecretPathVolume", version: "0.0.0" }; -Object.defineProperty(SecretPathVolume.prototype, SECRET_PATH_VOLUME_SYMBOL, { - value: true, - enumerable: false, - writable: false, -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-container-definition.js","sourceRoot":"","sources":["eks-container-definition.ts"],"names":[],"mappings":";;;;;;AACA,2CAA8C;AAC9C,2CAAmD;AAGnD,MAAM,uBAAuB,GAAG,MAAM,CAAC,GAAG,CAAC,mEAAmE,CAAC,CAAC;AAChH,MAAM,uBAAuB,GAAG,MAAM,CAAC,GAAG,CAAC,mEAAmE,CAAC,CAAC;AAChH,MAAM,yBAAyB,GAAG,MAAM,CAAC,GAAG,CAAC,iEAAiE,CAAC,CAAC;AAqPhH;;GAEG;AACH,IAAY,eA0BX;AA1BD,WAAY,eAAe;IACzB;;;;;;;;OAQG;IACH,oCAAiB,CAAA;IAEjB;;OAEG;IACH,kDAA+B,CAAA;IAE/B;;;;;;;OAOG;IACH,kCAAe,CAAA;AACjB,CAAC,EA1BW,eAAe,+BAAf,eAAe,QA0B1B;AAwPD;;GAEG;AACH,MAAa,sBAAuB,SAAQ,sBAAS;IAsBnD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAkC;QAC1E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;+CAvBR,sBAAsB;;;;QAyB/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QACrB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,eAAe,CAAC;QAC7C,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;QACnC,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,sBAAsB,CAAC;QAC3D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAW,CAAC,CAAC;KACxD;IAED,SAAS,CAAC,MAAiB;;;;;;;;;;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;KAC3B;IAED;;;OAGG;IACI,0BAA0B;QAC/B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS;YACjC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC3C,OAAO;oBACL,IAAI,EAAE,GAAG;oBACT,KAAK,EAAE,IAAI,CAAC,GAAI,CAAC,GAAG,CAAC;iBACtB,CAAC;YACJ,CAAC,CAAC;YACF,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,SAAS,EAAE;gBACT,MAAM,EAAE;oBACN,KAAK,EAAE,IAAI,CAAC,QAAQ;oBACpB,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,SAAS;oBAC9E,gBAAgB,EAAE,IAAI,CAAC,QAAQ;iBAChC;gBACD,QAAQ,EAAE;oBACR,KAAK,EAAE,IAAI,CAAC,cAAc;oBAC1B,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,SAAS;oBAC1F,gBAAgB,EAAE,IAAI,CAAC,cAAc;iBACtC;aACF;YACD,eAAe,EAAE;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,sBAAsB,EAAE,IAAI,CAAC,sBAAsB;gBACnD,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,YAAY,EAAE,CAAC,IAAI,CAAC,SAAS;gBAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;aAC1B;YACD,YAAY,EAAE,WAAI,CAAC,GAAG,CAAC;gBACrB,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;wBAC7B,OAAO,SAAS,CAAC;qBAClB;oBACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;wBACjC,OAAO;4BACL,IAAI,EAAE,MAAM,CAAC,IAAI;4BACjB,SAAS,EAAE,MAAM,CAAC,aAAa;4BAC/B,QAAQ,EAAE,MAAM,CAAC,QAAQ;yBAC1B,CAAC;oBACJ,CAAC,CAAC,CAAC;gBACL,CAAC;aACF,CAAC;SACH,CAAC;KACH;IAAA,CAAC;;AArGJ,wDAsGC;;;AA8BD;;GAEG;AACH,MAAsB,SAAS;IAC7B;;;;OAIG;IACH,MAAM,CAAC,QAAQ,CAAC,OAA8B;;;;;;;;;;QAC5C,OAAO,IAAI,cAAc,CAAC,OAAO,CAAC,CAAC;KACpC;IACD;;;;OAIG;IACH,MAAM,CAAC,QAAQ,CAAC,OAA8B;;;;;;;;;;QAC5C,OAAO,IAAI,cAAc,CAAC,OAAO,CAAC,CAAC;KACpC;IACD;;;;OAIG;IACH,MAAM,CAAC,MAAM,CAAC,OAAgC;;;;;;;;;;QAC5C,OAAO,IAAI,gBAAgB,CAAC,OAAO,CAAC,CAAC;KACtC;IAyBD,YAAY,OAAyB;;;;;;+CAjDjB,SAAS;;;;QAkD3B,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,SAAS,CAAC;QACvC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;KAClC;;AArDH,8BAsDC;;;AAuBD;;GAEG;AACH,IAAY,kBAYX;AAZD,WAAY,kBAAkB;IAC5B;;;OAGG;IACH,+BAAS,CAAA;IAET;;;OAGG;IACH,uCAAiB,CAAA;AACnB,CAAC,EAZW,kBAAkB,kCAAlB,kBAAkB,QAY7B;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,SAAS;IAC3C;;OAEG;IACI,MAAM,CAAC,gBAAgB,CAAC,CAAM;QACnC,OAAO,CAAC,KAAK,IAAI,IAAI,OAAM,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,uBAAuB,IAAI,CAAC,CAAC;KAC7E;IAgBD,YAAY,OAA8B;QACxC,KAAK,CAAC,OAAO,CAAC,CAAC;;;;;;+CAvBN,cAAc;;;;QAwBvB,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;KACpC;;AA1BH,wCA2BC;;;AAED,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,SAAS,EAAE,uBAAuB,EAAE;IACvE,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,KAAK;IACjB,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC;AAkBH;;;;GAIG;AACH,MAAa,cAAe,SAAQ,SAAS;IAC3C;;OAEG;IACI,MAAM,CAAC,gBAAgB,CAAC,CAAM;QACnC,OAAO,CAAC,KAAK,IAAI,IAAI,OAAM,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,uBAAuB,IAAI,CAAC,CAAC;KAC7E;IAWD,YAAY,OAA8B;QACxC,KAAK,CAAC,OAAO,CAAC,CAAC;;;;;;+CAlBN,cAAc;;;;QAmBvB,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,QAAQ,CAAC;KAC9B;;AApBH,wCAqBC;;;AAED,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,SAAS,EAAE,uBAAuB,EAAE;IACvE,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,KAAK;IACjB,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC;AAwBH;;;;GAIG;AACH,MAAa,gBAAiB,SAAQ,SAAS;IAC7C;;OAEG;IACI,MAAM,CAAC,kBAAkB,CAAC,CAAM;QACrC,OAAO,CAAC,KAAK,IAAI,IAAI,OAAM,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,yBAAyB,IAAI,CAAC,CAAC;KAC/E;IAiBD,YAAY,OAAgC;QAC1C,KAAK,CAAC,OAAO,CAAC,CAAC;;;;;;+CAxBN,gBAAgB;;;;QAyBzB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC;KAC1C;;AA3BH,4CA4BC;;;AAED,MAAM,CAAC,cAAc,CAAC,gBAAgB,CAAC,SAAS,EAAE,yBAAyB,EAAE;IAC3E,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,KAAK;IACjB,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC","sourcesContent":["import * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Lazy, Size } from 'aws-cdk-lib/core';\nimport { Construct, IConstruct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\n\nconst EMPTY_DIR_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.EmptyDirVolume');\nconst HOST_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.HostPathVolume');\nconst SECRET_PATH_VOLUME_SYMBOL = Symbol.for('aws-cdk-lib/aws-batch/lib/eks-container-definition.SecretVolume');\n\n/**\n * A container that can be run with EKS orchestration on EC2 resources\n */\nexport interface IEksContainerDefinition extends IConstruct {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * An array of arguments to the entrypoint.\n   * If this isn't specified, the CMD of the container image is used.\n   * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\n   * the command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\n   * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   */\n  readonly args?: string[];\n\n  /**\n   * The entrypoint for the container. This isn't run within a shell.\n   * If this isn't specified, the `ENTRYPOINT` of the container image is used.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\n   * the command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\n   * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\n   * The entrypoint can't be updated.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#entrypoint\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to this container.\n   *\n   * *Note*: Environment variables cannot start with \"AWS_BATCH\".\n   * This naming convention is reserved for variables that AWS Batch sets.\n   */\n  readonly env?: { [key:string]: string };\n\n  /**\n   * The image pull policy for this container\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images\n   *\n   * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise\n   */\n  readonly imagePullPolicy?: ImagePullPolicy;\n\n  /**\n   * The name of this container\n   *\n   * @default: `'Default'`\n   */\n  readonly name?: string;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   * If your container attempts to exceed the allocated memory, it will be terminated.\n   *\n   * Must be larger that 4 MiB\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory limit\n   */\n  readonly memoryLimit?: Size;\n\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   * Your container will be given at least this much memory, but may consume more.\n   *\n   * Must be larger that 4 MiB\n   *\n   * When system memory is under heavy contention, Docker attempts to keep the\n   * container memory to this soft limit. However, your container can consume more\n   * memory when it needs to, up to either the hard limit specified with the memory\n   * parameter (if applicable), or all of the available memory on the container\n   * instance, whichever comes first.\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required.\n   * If both are specified, then `memoryLimit` must be equal to `memoryReservation`\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory reserved\n   */\n  readonly memoryReservation?: Size;\n\n  /**\n   * The hard limit of CPUs to present to this container.\n   * Must be an even multiple of 0.25\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPU limit\n   */\n  readonly cpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPUs reserved\n   */\n  readonly cpuReservation?: number;\n\n  /**\n   * The hard limit of GPUs to present to this container.\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPU limit\n   */\n  readonly gpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPUs reserved\n   */\n  readonly gpuReservation?: number;\n\n  /**\n   * If specified, gives this container elevated permissions on the host container instance.\n   * The level of permissions are similar to the root user permissions.\n   *\n   * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * If specified, gives this container readonly access to its root file system.\n   *\n   * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * If specified, the container is run as the specified group ID (`gid`).\n   * If this parameter isn't specified, the default is the group that's specified in the image metadata.\n   * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default none\n   */\n  readonly runAsGroup?: number;\n\n  /**\n   * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced.\n   * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the container is *not* required to run as a non-root user\n   */\n  readonly runAsRoot?: boolean;\n\n  /**\n   * If specified, this container is run as the specified user ID (`uid`).\n   * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the user that is specified in the image metadata.\n   */\n  readonly runAsUser?: number;\n\n  /**\n   * The Volumes to mount to this container.\n   * Automatically added to the Pod.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/\n   */\n  readonly volumes: EksVolume[];\n\n  /**\n   * Mount a Volume to this container. Automatically added to the Pod.\n   */\n  addVolume(volume: EksVolume): void;\n}\n\n/**\n * Determines when the image is pulled from the registry to launch a container\n */\nexport enum ImagePullPolicy {\n  /**\n   * Every time the kubelet launches a container,\n   * the kubelet queries the container image registry to resolve the name to an image digest.\n   * If the kubelet has a container image with that exact digest cached locally,\n   * the kubelet uses its cached image; otherwise, the kubelet pulls the image with the resolved digest,\n   * and uses that image to launch the container.\n   *\n   * @see https://docs.docker.com/engine/reference/commandline/pull/#pull-an-image-by-digest-immutable-identifier\n   */\n  ALWAYS = 'Always',\n\n  /**\n   * The image is pulled only if it is not already present locally\n   */\n  IF_NOT_PRESENT = 'IfNotPresent',\n\n  /**\n   * The kubelet does not try fetching the image.\n   * If the image is somehow already present locally,\n   * the kubelet attempts to start the container; otherwise, startup fails.\n   * See pre-pulled images for more details.\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#pre-pulled-images\n   */\n  NEVER = 'Never',\n}\n\n/**\n * Props to configure an EksContainerDefinition\n */\nexport interface EksContainerDefinitionProps {\n  /**\n   * The image that this container will run\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * An array of arguments to the entrypoint.\n   * If this isn't specified, the CMD of the container image is used.\n   * This corresponds to the args member in the Entrypoint portion of the Pod in Kubernetes.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to \"$(NAME1)\" and the NAME1 environment variable doesn't exist,\n   * the command string will remain \"$(NAME1).\" $$ is replaced with $, and the resulting string isn't expanded.\n   * or example, $$(VAR_NAME) is passed as $(VAR_NAME) whether or not the VAR_NAME environment variable exists.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#cmd\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   *\n   * @default - no args\n   */\n  readonly args?: string[];\n\n  /**\n   * The entrypoint for the container. This isn't run within a shell.\n   * If this isn't specified, the `ENTRYPOINT` of the container image is used.\n   * Environment variable references are expanded using the container's environment.\n   * If the referenced environment variable doesn't exist, the reference in the command isn't changed.\n   * For example, if the reference is to `\"$(NAME1)\"` and the `NAME1` environment variable doesn't exist,\n   * the command string will remain `\"$(NAME1).\"` `$$` is replaced with `$` and the resulting string isn't expanded.\n   * For example, `$$(VAR_NAME)` will be passed as `$(VAR_NAME)` whether or not the `VAR_NAME` environment variable exists.\n\n   * The entrypoint can't be updated.\n   *\n   * @see https://docs.docker.com/engine/reference/builder/#entrypoint\n   * @see https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/\n   * @see https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#entrypoint\n   *\n   * @default - no command\n   */\n  readonly command?: string[];\n\n  /**\n   * The environment variables to pass to this container.\n   *\n   * *Note*: Environment variables cannot start with \"AWS_BATCH\".\n   * This naming convention is reserved for variables that AWS Batch sets.\n   *\n   * @default - no environment variables\n   */\n  readonly env?: { [key:string]: string };\n\n  /**\n   * The image pull policy for this container\n   *\n   * @see https://kubernetes.io/docs/concepts/containers/images/#updating-images\n   *\n   * @default - `ALWAYS` if the `:latest` tag is specified, `IF_NOT_PRESENT` otherwise\n   */\n  readonly imagePullPolicy?: ImagePullPolicy;\n\n  /**\n   * The name of this container\n   *\n   * @default: `'Default'`\n   */\n  readonly name?: string;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   * If your container attempts to exceed the allocated memory, it will be terminated.\n   *\n   * Must be larger that 4 MiB\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory limit\n   */\n  readonly memoryLimit?: Size;\n\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   * Your container will be given at least this much memory, but may consume more.\n   *\n   * Must be larger that 4 MiB\n   *\n   * When system memory is under heavy contention, Docker attempts to keep the\n   * container memory to this soft limit. However, your container can consume more\n   * memory when it needs to, up to either the hard limit specified with the memory\n   * parameter (if applicable), or all of the available memory on the container\n   * instance, whichever comes first.\n   *\n   * At least one of `memoryLimit` and `memoryReservation` is required.\n   * If both are specified, then `memoryLimit` must be equal to `memoryReservation`\n   *\n   * *Note*: To maximize your resource utilization, provide your jobs with as much memory as possible\n   * for the specific instance type that you are using.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/memory-management.html\n   *\n   * @default - No memory reserved\n   */\n  readonly memoryReservation?: Size;\n\n  /**\n   * The hard limit of CPUs to present to this container.\n   * Must be an even multiple of 0.25\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPU limit\n   */\n  readonly cpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * At least one of `cpuReservation` and `cpuLimit` is required.\n   * If both are specified, then `cpuLimit` must be at least as large as `cpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No CPUs reserved\n   */\n  readonly cpuReservation?: number;\n\n  /**\n   * The hard limit of GPUs to present to this container.\n   *\n   * If your container attempts to exceed this limit, it will be terminated.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPU limit\n   */\n  readonly gpuLimit?: number;\n\n  /**\n   * The soft limit of CPUs to reserve for the container\n   * Must be an even multiple of 0.25\n   *\n   * The container will given at least this many CPUs, but may consume more.\n   *\n   * If both `gpuReservation` and `gpuLimit` are specified, then `gpuLimit` must be equal to `gpuReservation`.\n   *\n   * @see https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/\n   *\n   * @default - No GPUs reserved\n   */\n  readonly gpuReservation?: number;\n\n  /**\n   * If specified, gives this container elevated permissions on the host container instance.\n   * The level of permissions are similar to the root user permissions.\n   *\n   * This parameter maps to `privileged` policy in the Privileged pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * If specified, gives this container readonly access to its root file system.\n   *\n   * This parameter maps to `ReadOnlyRootFilesystem` policy in the Volumes and file systems pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#volumes-and-file-systems\n   *\n   * @default false\n   */\n  readonly readonlyRootFilesystem?: boolean;\n\n  /**\n   * If specified, the container is run as the specified group ID (`gid`).\n   * If this parameter isn't specified, the default is the group that's specified in the image metadata.\n   * This parameter maps to `RunAsGroup` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default none\n   */\n  readonly runAsGroup?: number;\n\n  /**\n   * If specified, the container is run as a user with a `uid` other than 0. Otherwise, no such rule is enforced.\n   * This parameter maps to `RunAsUser` and `MustRunAsNonRoot` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the container is *not* required to run as a non-root user\n   */\n  readonly runAsRoot?: boolean;\n\n  /**\n   * If specified, this container is run as the specified user ID (`uid`).\n   * This parameter maps to `RunAsUser` and `MustRunAs` policy in the Users and groups pod security policies in the Kubernetes documentation.\n   *\n   * *Note*: this is only compatible with Kubernetes < v1.25\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#users-and-groups\n   *\n   * @default - the user that is specified in the image metadata.\n   */\n  readonly runAsUser?: number;\n\n  /**\n   * The Volumes to mount to this container.\n   * Automatically added to the Pod.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/\n   *\n   * @default - no volumes\n   */\n  readonly volumes?: EksVolume[];\n}\n\n/**\n * A container that can be run with EKS orchestration on EC2 resources\n */\nexport class EksContainerDefinition extends Construct implements IEksContainerDefinition {\n  public readonly image: ecs.ContainerImage;\n  public readonly args?: string[];\n  public readonly command?: string[];\n  public readonly env?: { [key:string]: string };\n  public readonly imagePullPolicy?: ImagePullPolicy;\n  public readonly name?: string;\n  public readonly memoryLimit?: Size;\n  public readonly memoryReservation?: Size;\n  public readonly cpuLimit?: number;\n  public readonly cpuReservation?: number;\n  public readonly gpuLimit?: number;\n  public readonly gpuReservation?: number;\n  public readonly privileged?: boolean;\n  public readonly readonlyRootFilesystem?: boolean;\n  public readonly runAsGroup?: number;\n  public readonly runAsRoot?: boolean;\n  public readonly runAsUser?: number;\n  public readonly volumes: EksVolume[];\n\n  private readonly imageConfig: ecs.ContainerImageConfig;\n\n  constructor(scope: Construct, id: string, props: EksContainerDefinitionProps) {\n    super(scope, id);\n\n    this.image = props.image;\n    this.args = props.args;\n    this.command = props.command;\n    this.env = props.env;\n    this.imagePullPolicy = props.imagePullPolicy;\n    this.name = props.name;\n    this.memoryLimit = props.memoryLimit;\n    this.memoryReservation = props.memoryReservation;\n    this.cpuLimit = props.cpuLimit;\n    this.cpuReservation = props.cpuReservation;\n    this.gpuLimit = props.gpuLimit;\n    this.gpuReservation = props.gpuReservation;\n    this.privileged = props.privileged;\n    this.readonlyRootFilesystem = props.readonlyRootFilesystem;\n    this.runAsGroup = props.runAsGroup;\n    this.runAsRoot = props.runAsRoot;\n    this.runAsUser = props.runAsUser;\n    this.volumes = props.volumes ?? [];\n    this.imageConfig = props.image.bind(this, this as any);\n  }\n\n  addVolume(volume: EksVolume) {\n    this.volumes.push(volume);\n  }\n\n  /**\n   *\n   * @internal\n   */\n  public _renderContainerDefinition(): CfnJobDefinition.EksContainerProperty {\n    return {\n      image: this.imageConfig.imageName,\n      command: this.command,\n      args: this.args,\n      env: Object.keys(this.env ?? {}).map((key) => {\n        return {\n          name: key,\n          value: this.env![key],\n        };\n      }),\n      name: this.name,\n      imagePullPolicy: this.imagePullPolicy,\n      resources: {\n        limits: {\n          'cpu': this.cpuLimit,\n          'memory': this.memoryLimit ? this.memoryLimit.toMebibytes() + 'Mi' : undefined,\n          'nvidia.com/gpu': this.gpuLimit,\n        },\n        requests: {\n          'cpu': this.cpuReservation,\n          'memory': this.memoryReservation ? this.memoryReservation.toMebibytes() + 'Mi' : undefined,\n          'nvidia.com/gpu': this.gpuReservation,\n        },\n      },\n      securityContext: {\n        privileged: this.privileged,\n        readOnlyRootFilesystem: this.readonlyRootFilesystem,\n        runAsGroup: this.runAsGroup,\n        runAsNonRoot: !this.runAsRoot,\n        runAsUser: this.runAsUser,\n      },\n      volumeMounts: Lazy.any({\n        produce: () => {\n          if (this.volumes.length === 0) {\n            return undefined;\n          }\n          return this.volumes.map((volume) => {\n            return {\n              name: volume.name,\n              mountPath: volume.containerPath,\n              readOnly: volume.readonly,\n            };\n          });\n        },\n      }),\n    };\n  };\n}\n\n/**\n * Options to configure an EksVolume\n */\nexport interface EksVolumeOptions {\n  /**\n   * The name of this volume.\n   * The name must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly name: string;\n\n  /**\n   * The path on the container where the volume is mounted.\n   *\n   * @default - the volume is not mounted\n   */\n  readonly mountPath?: string;\n\n  /**\n   * If specified, the container has readonly access to the volume.\n   * Otherwise, the container has read/write access.\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n}\n\n/**\n * A Volume that can be mounted to a container supported by EKS\n */\nexport abstract class EksVolume {\n  /**\n   * Creates a Kubernetes EmptyDir volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n   */\n  static emptyDir(options: EmptyDirVolumeOptions) {\n    return new EmptyDirVolume(options);\n  }\n  /**\n   * Creates a Kubernetes HostPath volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  static hostPath(options: HostPathVolumeOptions) {\n    return new HostPathVolume(options);\n  }\n  /**\n   * Creates a Kubernetes Secret volume\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n   */\n  static secret(options: SecretPathVolumeOptions) {\n    return new SecretPathVolume(options);\n  }\n\n  /**\n   * The name of this volume.\n   * The name must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly name: string;\n\n  /**\n   * The path on the container where the container is mounted.\n   *\n   * @default - the container is not mounted\n   */\n  readonly containerPath?: string;\n\n  /**\n   * If specified, the container has readonly access to the volume.\n   * Otherwise, the container has read/write access.\n   *\n   * @default false\n   */\n  readonly readonly?: boolean;\n\n  constructor(options: EksVolumeOptions) {\n    this.name = options.name;\n    this.containerPath = options.mountPath;\n    this.readonly = options.readonly;\n  }\n}\n\n/**\n * Options for a Kubernetes EmptyDir volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n */\nexport interface EmptyDirVolumeOptions extends EksVolumeOptions {\n  /**\n   * The storage type to use for this Volume.\n   *\n   * @default `EmptyDirMediumType.DISK`\n   */\n  readonly medium?: EmptyDirMediumType;\n\n  /**\n   * The maximum size for this Volume\n   *\n   * @default - no size limit\n   */\n  readonly sizeLimit?: Size\n}\n\n/**\n * What medium the volume will live in\n */\nexport enum EmptyDirMediumType {\n  /**\n   * Use the disk storage of the node.\n   * Items written here will survive node reboots.\n   */\n  DISK = '',\n\n  /**\n   * Use the `tmpfs` volume that is backed by RAM of the node.\n   * Items written here will *not* survive node reboots.\n   */\n  MEMORY = 'Memory',\n}\n\n/**\n * A Kubernetes EmptyDir volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n */\nexport class EmptyDirVolume extends EksVolume {\n  /**\n   * Returns `true` if `x` is an EmptyDirVolume, `false` otherwise\n   */\n  public static isEmptyDirVolume(x: any) : x is EmptyDirVolume {\n    return x !== null && typeof(x) === 'object' && EMPTY_DIR_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The storage type to use for this Volume.\n   *\n   * @default `EmptyDirMediumType.DISK`\n   */\n  readonly medium?: EmptyDirMediumType;\n\n  /**\n   * The maximum size for this Volume\n   *\n   * @default - no size limit\n   */\n  readonly sizeLimit?: Size;\n\n  constructor(options: EmptyDirVolumeOptions) {\n    super(options);\n    this.medium = options.medium;\n    this.sizeLimit = options.sizeLimit;\n  }\n}\n\nObject.defineProperty(EmptyDirVolume.prototype, EMPTY_DIR_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for a kubernetes HostPath volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n */\nexport interface HostPathVolumeOptions extends EksVolumeOptions {\n  /**\n   * The path of the file or directory on the host to mount into containers on the pod.\n   *\n   * *Note*: HothPath Volumes present many security risks, and should be avoided when possible.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  readonly hostPath: string;\n}\n\n/**\n * A Kubernetes HostPath volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n */\nexport class HostPathVolume extends EksVolume {\n  /**\n   * returns `true` if `x` is a HostPathVolume, `false` otherwise\n   */\n  public static isHostPathVolume(x: any) : x is HostPathVolume {\n    return x !== null && typeof(x) === 'object' && HOST_PATH_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The path of the file or directory on the host to mount into containers on the pod.\n   *\n   * *Note*: HothPath Volumes present many security risks, and should be avoided when possible.\n   *\n   * @see https://kubernetes.io/docs/concepts/storage/volumes/#hostpath\n   */\n  public readonly path: string;\n\n  constructor(options: HostPathVolumeOptions) {\n    super(options);\n    this.path = options.hostPath;\n  }\n}\n\nObject.defineProperty(HostPathVolume.prototype, HOST_PATH_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n\n/**\n * Options for a Kubernetes SecretPath Volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n */\nexport interface SecretPathVolumeOptions extends EksVolumeOptions {\n  /**\n   * The name of the secret.\n   * Must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly secretName: string;\n\n  /**\n   * Specifies whether the secret or the secret's keys must be defined\n   *\n   * @default true\n   */\n  readonly optional?: boolean;\n}\n\n/**\n * Specifies the configuration of a Kubernetes secret volume\n *\n * @see https://kubernetes.io/docs/concepts/storage/volumes/#secret\n */\nexport class SecretPathVolume extends EksVolume {\n  /**\n   * returns `true` if `x` is a `SecretPathVolume` and `false` otherwise\n   */\n  public static isSecretPathVolume(x: any) : x is SecretPathVolume {\n    return x !== null && typeof(x) === 'object' && SECRET_PATH_VOLUME_SYMBOL in x;\n  }\n\n  /**\n   * The name of the secret.\n   * Must be a valid DNS subdomain name.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#dns-subdomain-names\n   */\n  readonly secretName: string;\n\n  /**\n   * Specifies whether the secret or the secret's keys must be defined\n   *\n   * @default true\n   */\n  readonly optional?: boolean;\n\n  constructor(options: SecretPathVolumeOptions) {\n    super(options);\n    this.secretName = options.secretName;\n    this.optional = options.optional ?? true;\n  }\n}\n\nObject.defineProperty(SecretPathVolume.prototype, SECRET_PATH_VOLUME_SYMBOL, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts deleted file mode 100644 index 02e0bf442017d..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.d.ts +++ /dev/null @@ -1,123 +0,0 @@ -import { Construct } from 'constructs'; -import { EksContainerDefinition } from './eks-container-definition'; -import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; -/** - * A JobDefinition that uses Eks orchestration - */ -export interface IEksJobDefinition extends IJobDefinition { - /** - * The container this Job Definition will run - */ - readonly container: EksContainerDefinition; - /** - * The DNS Policy of the pod used by this Job Definition - * - * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy - * - * @default `DnsPolicy.CLUSTER_FIRST` - */ - readonly dnsPolicy?: DnsPolicy; - /** - * If specified, the Pod used by this Job Definition will use the host's network IP address. - * Otherwise, the Kubernetes pod networking model is enabled. - * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections. - * - * @default true - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces - * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking - */ - readonly useHostNetwork?: boolean; - /** - * The name of the service account that's used to run the container. - * service accounts are Kubernetes method of identification and authentication, - * roughly analogous to IAM users. - * - * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html - * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ - * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html - * - * @default - the default service account of the container - */ - readonly serviceAccount?: string; -} -/** - * Props for EksJobDefinition - */ -export interface EksJobDefinitionProps extends JobDefinitionProps { - /** - * The container this Job Definition will run - */ - readonly container: EksContainerDefinition; - /** - * The DNS Policy of the pod used by this Job Definition - * - * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy - * - * @default `DnsPolicy.CLUSTER_FIRST` - */ - readonly dnsPolicy?: DnsPolicy; - /** - * If specified, the Pod used by this Job Definition will use the host's network IP address. - * Otherwise, the Kubernetes pod networking model is enabled. - * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections. - * - * @default true - * - * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces - * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking - */ - readonly useHostNetwork?: boolean; - /** - * The name of the service account that's used to run the container. - * service accounts are Kubernetes method of identification and authentication, - * roughly analogous to IAM users. - * - * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html - * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ - * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html - * - * @default - the default service account of the container - */ - readonly serviceAccount?: string; -} -/** - * The DNS Policy for the pod used by the Job Definition - * - * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy - */ -export declare enum DnsPolicy { - /** - * The Pod inherits the name resolution configuration from the node that the Pods run on - */ - DEFAULT = "Default", - /** - * Any DNS query that does not match the configured cluster domain suffix, such as `"www.kubernetes.io"`, - * is forwarded to an upstream nameserver by the DNS server. - * Cluster administrators may have extra stub-domain and upstream DNS servers configured. - */ - CLUSTER_FIRST = "ClusterFirst", - /** - * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`. - * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy. - */ - CLUSTER_FIRST_WITH_HOST_NET = "ClusterFirstWithHostNet" -} -/** - * A JobDefinition that uses Eks orchestration - * - * @resource AWS::Batch::JobDefinition - */ -export declare class EksJobDefinition extends JobDefinitionBase implements IEksJobDefinition { - /** - * Import an EksJobDefinition by its arn - */ - static fromEksJobDefinitionArn(scope: Construct, id: string, eksJobDefinitionArn: string): IEksJobDefinition; - readonly container: EksContainerDefinition; - readonly dnsPolicy?: DnsPolicy; - readonly useHostNetwork?: boolean; - readonly serviceAccount?: string; - readonly jobDefinitionArn: string; - readonly jobDefinitionName: string; - constructor(scope: Construct, id: string, props: EksJobDefinitionProps); -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js deleted file mode 100644 index cb23b62ee18c9..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/eks-job-definition.js +++ /dev/null @@ -1,134 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.EksJobDefinition = exports.DnsPolicy = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -const eks_container_definition_1 = require("./eks-container-definition"); -const job_definition_base_1 = require("./job-definition-base"); -/** - * The DNS Policy for the pod used by the Job Definition - * - * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy - */ -var DnsPolicy; -(function (DnsPolicy) { - /** - * The Pod inherits the name resolution configuration from the node that the Pods run on - */ - DnsPolicy["DEFAULT"] = "Default"; - /** - * Any DNS query that does not match the configured cluster domain suffix, such as `"www.kubernetes.io"`, - * is forwarded to an upstream nameserver by the DNS server. - * Cluster administrators may have extra stub-domain and upstream DNS servers configured. - */ - DnsPolicy["CLUSTER_FIRST"] = "ClusterFirst"; - /** - * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`. - * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy. - */ - DnsPolicy["CLUSTER_FIRST_WITH_HOST_NET"] = "ClusterFirstWithHostNet"; -})(DnsPolicy || (exports.DnsPolicy = DnsPolicy = {})); -/** - * A JobDefinition that uses Eks orchestration - * - * @resource AWS::Batch::JobDefinition - */ -class EksJobDefinition extends job_definition_base_1.JobDefinitionBase { - /** - * Import an EksJobDefinition by its arn - */ - static fromEksJobDefinitionArn(scope, id, eksJobDefinitionArn) { - const stack = core_1.Stack.of(scope); - const jobDefinitionName = stack.splitArn(eksJobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - class Import extends job_definition_base_1.JobDefinitionBase { - constructor() { - super(...arguments); - this.jobDefinitionArn = eksJobDefinitionArn; - this.jobDefinitionName = jobDefinitionName; - this.enabled = true; - this.container = {}; - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_EksJobDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, EksJobDefinition); - } - throw error; - } - this.container = props.container; - this.dnsPolicy = props.dnsPolicy; - this.useHostNetwork = props.useHostNetwork; - this.serviceAccount = props.serviceAccount; - const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { - ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), - type: 'container', - jobDefinitionName: props.jobDefinitionName, - eksProperties: { - podProperties: { - containers: [ - this.container._renderContainerDefinition(), - ], - dnsPolicy: this.dnsPolicy, - hostNetwork: this.useHostNetwork, - serviceAccountName: this.serviceAccount, - volumes: core_1.Lazy.any({ - produce: () => { - if (this.container.volumes.length === 0) { - return undefined; - } - return this.container.volumes.map((volume) => { - if (eks_container_definition_1.EmptyDirVolume.isEmptyDirVolume(volume)) { - return { - name: volume.name, - emptyDir: { - medium: volume.medium, - sizeLimit: volume.sizeLimit ? volume.sizeLimit.toMebibytes().toString() + 'Mi' : undefined, - }, - }; - } - if (eks_container_definition_1.HostPathVolume.isHostPathVolume(volume)) { - return { - name: volume.name, - hostPath: { - path: volume.path, - }, - }; - } - if (eks_container_definition_1.SecretPathVolume.isSecretPathVolume(volume)) { - return { - name: volume.name, - secret: { - optional: volume.optional, - secretName: volume.secretName, - }, - }; - } - throw new Error('unknown volume type'); - }); - }, - }), - }, - }, - }); - this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { - service: 'batch', - resource: 'job-definition', - resourceName: this.physicalName, - }); - this.jobDefinitionName = this.getResourceNameAttribute(resource.ref); - } -} -exports.EksJobDefinition = EksJobDefinition; -_a = JSII_RTTI_SYMBOL_1; -EksJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.EksJobDefinition", version: "0.0.0" }; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-job-definition.js","sourceRoot":"","sources":["eks-job-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArnFormat, Lazy, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { EksContainerDefinition, EmptyDirVolume, HostPathVolume, SecretPathVolume } from './eks-container-definition';\nimport { baseJobDefinitionProperties, IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base';\n\n/**\n * A JobDefinition that uses Eks orchestration\n */\nexport interface IEksJobDefinition extends IJobDefinition {\n  /**\n   * The container this Job Definition will run\n   */\n  readonly container: EksContainerDefinition;\n\n  /**\n   * The DNS Policy of the pod used by this Job Definition\n   *\n   * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n   *\n   * @default `DnsPolicy.CLUSTER_FIRST`\n   */\n  readonly dnsPolicy?: DnsPolicy;\n\n  /**\n   * If specified, the Pod used by this Job Definition will use the host's network IP address.\n   * Otherwise, the Kubernetes pod networking model is enabled.\n   * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.\n   *\n   * @default true\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking\n   */\n  readonly useHostNetwork?: boolean;\n\n  /**\n   * The name of the service account that's used to run the container.\n   * service accounts are Kubernetes method of identification and authentication,\n   * roughly analogous to IAM users.\n   *\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html\n   * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html\n   *\n   * @default - the default service account of the container\n   */\n  readonly serviceAccount?: string;\n}\n\n/**\n * Props for EksJobDefinition\n */\nexport interface EksJobDefinitionProps extends JobDefinitionProps {\n  /**\n   * The container this Job Definition will run\n   */\n  readonly container: EksContainerDefinition;\n\n  /**\n   * The DNS Policy of the pod used by this Job Definition\n   *\n   * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n   *\n   * @default `DnsPolicy.CLUSTER_FIRST`\n   */\n  readonly dnsPolicy?: DnsPolicy;\n\n  /**\n   * If specified, the Pod used by this Job Definition will use the host's network IP address.\n   * Otherwise, the Kubernetes pod networking model is enabled.\n   * Most AWS Batch workloads are egress-only and don't require the overhead of IP allocation for each pod for incoming connections.\n   *\n   * @default true\n   *\n   * @see https://kubernetes.io/docs/concepts/security/pod-security-policy/#host-namespaces\n   * @see https://kubernetes.io/docs/concepts/workloads/pods/#pod-networking\n   */\n  readonly useHostNetwork?: boolean;\n\n  /**\n   * The name of the service account that's used to run the container.\n   * service accounts are Kubernetes method of identification and authentication,\n   * roughly analogous to IAM users.\n   *\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/service-accounts.html\n   * @see https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/\n   * @see https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html\n   *\n   * @default - the default service account of the container\n   */\n  readonly serviceAccount?: string;\n}\n\n/**\n * The DNS Policy for the pod used by the Job Definition\n *\n * @see https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy\n */\nexport enum DnsPolicy {\n  /**\n   * The Pod inherits the name resolution configuration from the node that the Pods run on\n   */\n  DEFAULT = 'Default',\n\n  /**\n   * Any DNS query that does not match the configured cluster domain suffix, such as `\"www.kubernetes.io\"`,\n   * is forwarded to an upstream nameserver by the DNS server.\n   * Cluster administrators may have extra stub-domain and upstream DNS servers configured.\n   */\n  CLUSTER_FIRST = 'ClusterFirst',\n\n  /**\n   * For Pods running with `hostNetwork`, you should explicitly set its DNS policy to `CLUSTER_FIRST_WITH_HOST_NET`.\n   * Otherwise, Pods running with `hostNetwork` and `CLUSTER_FIRST` will fallback to the behavior of the `DEFAULT` policy.\n   */\n  CLUSTER_FIRST_WITH_HOST_NET = 'ClusterFirstWithHostNet',\n}\n\n/**\n * A JobDefinition that uses Eks orchestration\n *\n * @resource AWS::Batch::JobDefinition\n */\nexport class EksJobDefinition extends JobDefinitionBase implements IEksJobDefinition {\n  /**\n   * Import an EksJobDefinition by its arn\n   */\n  public static fromEksJobDefinitionArn(scope: Construct, id: string, eksJobDefinitionArn: string): IEksJobDefinition {\n    const stack = Stack.of(scope);\n    const jobDefinitionName = stack.splitArn(eksJobDefinitionArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends JobDefinitionBase implements IJobDefinition {\n      public readonly jobDefinitionArn = eksJobDefinitionArn;\n      public readonly jobDefinitionName = jobDefinitionName;\n      public readonly enabled = true;\n      public readonly container = {} as any;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly container: EksContainerDefinition;\n  public readonly dnsPolicy?: DnsPolicy;\n  public readonly useHostNetwork?: boolean;\n  public readonly serviceAccount?: string;\n\n  public readonly jobDefinitionArn: string;\n  public readonly jobDefinitionName: string;\n\n  constructor(scope: Construct, id: string, props: EksJobDefinitionProps) {\n    super(scope, id, props);\n\n    this.container = props.container;\n    this.dnsPolicy = props.dnsPolicy;\n    this.useHostNetwork = props.useHostNetwork;\n    this.serviceAccount = props.serviceAccount;\n\n    const resource = new CfnJobDefinition(this, 'Resource', {\n      ...baseJobDefinitionProperties(this),\n      type: 'container',\n      jobDefinitionName: props.jobDefinitionName,\n      eksProperties: {\n        podProperties: {\n          containers: [\n            this.container._renderContainerDefinition(),\n          ],\n          dnsPolicy: this.dnsPolicy,\n          hostNetwork: this.useHostNetwork,\n          serviceAccountName: this.serviceAccount,\n          volumes: Lazy.any({\n            produce: () => {\n              if (this.container.volumes.length === 0) {\n                return undefined;\n              }\n              return this.container.volumes.map((volume) => {\n                if (EmptyDirVolume.isEmptyDirVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    emptyDir: {\n                      medium: volume.medium,\n                      sizeLimit: volume.sizeLimit ? volume.sizeLimit.toMebibytes().toString() + 'Mi' : undefined,\n                    },\n                  };\n                }\n                if (HostPathVolume.isHostPathVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    hostPath: {\n                      path: volume.path,\n                    },\n                  };\n                }\n                if (SecretPathVolume.isSecretPathVolume(volume)) {\n                  return {\n                    name: volume.name,\n                    secret: {\n                      optional: volume.optional,\n                      secretName: volume.secretName,\n                    },\n                  };\n                }\n\n                throw new Error('unknown volume type');\n              });\n            },\n          }),\n        },\n      },\n    });\n    this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, {\n      service: 'batch',\n      resource: 'job-definition',\n      resourceName: this.physicalName,\n    });\n    this.jobDefinitionName = this.getResourceNameAttribute(resource.ref);\n  }\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts deleted file mode 100644 index ffad48bef4c02..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/index.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -export * from './ecs-job-definition'; -export { IComputeEnvironment, ComputeEnvironmentProps } from './compute-environment-base'; -export * from './eks-job-definition'; -export * from './ecs-container-definition'; -export * from './eks-container-definition'; -export * from './job-definition-base'; -export * from './job-queue'; -export * from './linux-parameters'; -export * from './managed-compute-environment'; -export * from './multinode-job-definition'; -export * from './scheduling-policy'; -export * from './unmanaged-compute-environment'; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/index.js b/packages/@aws-cdk/aws-batch-alpha/lib/index.js deleted file mode 100644 index 586a60b134365..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/index.js +++ /dev/null @@ -1,29 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - var desc = Object.getOwnPropertyDescriptor(m, k); - if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { - desc = { enumerable: true, get: function() { return m[k]; } }; - } - Object.defineProperty(o, k2, desc); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __exportStar = (this && this.__exportStar) || function(m, exports) { - for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); -}; -Object.defineProperty(exports, "__esModule", { value: true }); -// AWS::Batch CloudFormation Resources: -__exportStar(require("./ecs-job-definition"), exports); -__exportStar(require("./eks-job-definition"), exports); -__exportStar(require("./ecs-container-definition"), exports); -__exportStar(require("./eks-container-definition"), exports); -__exportStar(require("./job-definition-base"), exports); -__exportStar(require("./job-queue"), exports); -__exportStar(require("./linux-parameters"), exports); -__exportStar(require("./managed-compute-environment"), exports); -__exportStar(require("./multinode-job-definition"), exports); -__exportStar(require("./scheduling-policy"), exports); -__exportStar(require("./unmanaged-compute-environment"), exports); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdUNBQXVDO0FBQ3ZDLHVEQUFxQztBQUVyQyx1REFBcUM7QUFDckMsNkRBQTJDO0FBQzNDLDZEQUEyQztBQUMzQyx3REFBc0M7QUFDdEMsOENBQTRCO0FBQzVCLHFEQUFtQztBQUNuQyxnRUFBOEM7QUFDOUMsNkRBQTJDO0FBQzNDLHNEQUFvQztBQUNwQyxrRUFBZ0QiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBV1M6OkJhdGNoIENsb3VkRm9ybWF0aW9uIFJlc291cmNlczpcbmV4cG9ydCAqIGZyb20gJy4vZWNzLWpvYi1kZWZpbml0aW9uJztcbmV4cG9ydCB7IElDb21wdXRlRW52aXJvbm1lbnQsIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIH0gZnJvbSAnLi9jb21wdXRlLWVudmlyb25tZW50LWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9la3Mtam9iLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9lY3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9la3MtY29udGFpbmVyLWRlZmluaXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9qb2ItZGVmaW5pdGlvbi1iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vam9iLXF1ZXVlJztcbmV4cG9ydCAqIGZyb20gJy4vbGludXgtcGFyYW1ldGVycyc7XG5leHBvcnQgKiBmcm9tICcuL21hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudCc7XG5leHBvcnQgKiBmcm9tICcuL211bHRpbm9kZS1qb2ItZGVmaW5pdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3NjaGVkdWxpbmctcG9saWN5JztcbmV4cG9ydCAqIGZyb20gJy4vdW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQnOyJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts deleted file mode 100644 index 27ab7a53f3600..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.d.ts +++ /dev/null @@ -1,217 +0,0 @@ -import { Duration, IResource, Resource } from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -import { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch'; -/** - * Represents a JobDefinition - */ -export interface IJobDefinition extends IResource { - /** - * The ARN of this job definition - * - * @attribute - */ - readonly jobDefinitionArn: string; - /** - * The name of this job definition - * - * @attribute - */ - readonly jobDefinitionName: string; - /** - * The default parameters passed to the container - * These parameters can be referenced in the `command` that - * you give to the container - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters - * - * @default none - */ - readonly parameters?: { - [key: string]: any; - }; - /** - * The number of times to retry a job. - * The job is retried on failure the same number of attempts as the value. - * - * @default 1 - */ - readonly retryAttempts?: number; - /** - * Defines the retry behavior for this job - * - * @default - no `RetryStrategy` - */ - readonly retryStrategies: RetryStrategy[]; - /** - * The priority of this Job. Only used in Fairshare Scheduling - * to decide which job to run first when there are multiple jobs - * with the same share identifier. - * - * @default none - */ - readonly schedulingPriority?: number; - /** - * The timeout time for jobs that are submitted with this job definition. - * After the amount of time you specify passes, - * Batch terminates your jobs if they aren't finished. - * - * @default - no timeout - */ - readonly timeout?: Duration; - /** - * Add a RetryStrategy to this JobDefinition - */ - addRetryStrategy(strategy: RetryStrategy): void; -} -/** - * Props common to all JobDefinitions - */ -export interface JobDefinitionProps { - /** - * The name of this job definition - * - * @default - generated by CloudFormation - */ - readonly jobDefinitionName?: string; - /** - * The default parameters passed to the container - * These parameters can be referenced in the `command` that - * you give to the container - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters - * - * @default none - */ - readonly parameters?: { - [key: string]: any; - }; - /** - * The number of times to retry a job. - * The job is retried on failure the same number of attempts as the value. - * - * @default 1 - */ - readonly retryAttempts?: number; - /** - * Defines the retry behavior for this job - * - * @default - no `RetryStrategy` - */ - readonly retryStrategies?: RetryStrategy[]; - /** - * The priority of this Job. Only used in Fairshare Scheduling - * to decide which job to run first when there are multiple jobs - * with the same share identifier. - * - * @default none - */ - readonly schedulingPriority?: number; - /** - * The timeout time for jobs that are submitted with this job definition. - * After the amount of time you specify passes, - * Batch terminates your jobs if they aren't finished. - * - * @default - no timeout - */ - readonly timeout?: Duration; -} -/** - * Define how Jobs using this JobDefinition respond to different exit conditions - */ -export declare class RetryStrategy { - /** - * Create a new RetryStrategy - */ - static of(action: Action, on: Reason): RetryStrategy; - /** - * The action to take when the job exits with the Reason specified - */ - readonly action: Action; - /** - * If the job exits with this Reason it will trigger the specified Action - */ - readonly on: Reason; - constructor(action: Action, on: Reason); -} -/** - * The Action to take when all specified conditions in a RetryStrategy are met - */ -export declare enum Action { - /** - * The job will not retry - */ - EXIT = "EXIT", - /** - * The job will retry. It can be retried up to the number of times specified in `retryAttempts`. - */ - RETRY = "RETRY" -} -/** - * The corresponding Action will only be taken if *all* of the conditions specified here are met. - */ -export interface CustomReason { - /** - * A glob string that will match on the job exit code. For example, `'40*'` will match 400, 404, 40123456789012 - * - * @default - will not match on the exit code - */ - readonly onExitCode?: string; - /** - * A glob string that will match on the statusReason returned by the exiting job. - * For example, `'Host EC2*'` indicates that the spot instance has been reclaimed. - * - * @default - will not match on the status reason - */ - readonly onStatusReason?: string; - /** - * A glob string that will match on the reason returned by the exiting job - * For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled. - * - * @default - will not match on the reason - */ - readonly onReason?: string; -} -/** - * Common job exit reasons - */ -export declare class Reason { - /** - * Will match any non-zero exit code - */ - static readonly NON_ZERO_EXIT_CODE: Reason; - /** - * Will only match if the Docker container could not be pulled - */ - static readonly CANNOT_PULL_CONTAINER: Reason; - /** - * Will only match if the Spot instance executing the job was reclaimed - */ - static readonly SPOT_INSTANCE_RECLAIMED: Reason; - /** - * A custom Reason that can match on multiple conditions. - * Note that all specified conditions must be met for this reason to match. - */ - static custom(customReasonProps: CustomReason): Reason; -} -/** - * Abstract base class for JobDefinitions - * - * @internal - */ -export declare abstract class JobDefinitionBase extends Resource implements IJobDefinition { - abstract readonly jobDefinitionArn: string; - abstract readonly jobDefinitionName: string; - readonly parameters?: { - [key: string]: any; - }; - readonly retryAttempts?: number; - readonly retryStrategies: RetryStrategy[]; - readonly schedulingPriority?: number; - readonly timeout?: Duration; - constructor(scope: Construct, id: string, props?: JobDefinitionProps); - addRetryStrategy(strategy: RetryStrategy): void; -} -/** - * @internal - */ -export declare function baseJobDefinitionProperties(baseJobDefinition: JobDefinitionBase): CfnJobDefinitionProps; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js b/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js deleted file mode 100644 index 14745de9bb71c..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/job-definition-base.js +++ /dev/null @@ -1,153 +0,0 @@ -"use strict"; -var _a, _b; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.baseJobDefinitionProperties = exports.JobDefinitionBase = exports.Reason = exports.Action = exports.RetryStrategy = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -/** - * Define how Jobs using this JobDefinition respond to different exit conditions - */ -class RetryStrategy { - /** - * Create a new RetryStrategy - */ - static of(action, on) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Action(action); - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Reason(on); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.of); - } - throw error; - } - return new RetryStrategy(action, on); - } - constructor(action, on) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Action(action); - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Reason(on); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, RetryStrategy); - } - throw error; - } - this.action = action; - this.on = on; - } -} -exports.RetryStrategy = RetryStrategy; -_a = JSII_RTTI_SYMBOL_1; -RetryStrategy[_a] = { fqn: "@aws-cdk/aws-batch-alpha.RetryStrategy", version: "0.0.0" }; -/** - * The Action to take when all specified conditions in a RetryStrategy are met - */ -var Action; -(function (Action) { - /** - * The job will not retry - */ - Action["EXIT"] = "EXIT"; - /** - * The job will retry. It can be retried up to the number of times specified in `retryAttempts`. - */ - Action["RETRY"] = "RETRY"; -})(Action || (exports.Action = Action = {})); -/** - * Common job exit reasons - */ -class Reason { - /** - * A custom Reason that can match on multiple conditions. - * Note that all specified conditions must be met for this reason to match. - */ - static custom(customReasonProps) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_CustomReason(customReasonProps); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.custom); - } - throw error; - } - return customReasonProps; - } -} -exports.Reason = Reason; -_b = JSII_RTTI_SYMBOL_1; -Reason[_b] = { fqn: "@aws-cdk/aws-batch-alpha.Reason", version: "0.0.0" }; -/** - * Will match any non-zero exit code - */ -Reason.NON_ZERO_EXIT_CODE = { - onExitCode: '*', -}; -/** - * Will only match if the Docker container could not be pulled - */ -Reason.CANNOT_PULL_CONTAINER = { - onReason: 'CannotPullContainerError:*', -}; -/** - * Will only match if the Spot instance executing the job was reclaimed - */ -Reason.SPOT_INSTANCE_RECLAIMED = { - onStatusReason: 'Host EC2*', -}; -/** - * Abstract base class for JobDefinitions - * - * @internal - */ -class JobDefinitionBase extends core_1.Resource { - constructor(scope, id, props) { - super(scope, id, { - physicalName: props?.jobDefinitionName, - }); - this.parameters = props?.parameters; - this.retryAttempts = props?.retryAttempts; - this.retryStrategies = props?.retryStrategies ?? []; - this.schedulingPriority = props?.schedulingPriority; - this.timeout = props?.timeout; - } - addRetryStrategy(strategy) { - this.retryStrategies.push(strategy); - } -} -exports.JobDefinitionBase = JobDefinitionBase; -/** - * @internal - */ -function baseJobDefinitionProperties(baseJobDefinition) { - return { - parameters: baseJobDefinition.parameters, - retryStrategy: { - attempts: baseJobDefinition.retryAttempts, - evaluateOnExit: core_1.Lazy.any({ - produce: () => { - if (baseJobDefinition.retryStrategies.length === 0) { - return undefined; - } - return baseJobDefinition.retryStrategies.map((strategy) => { - return { - action: strategy.action, - ...strategy.on, - }; - }); - }, - }), - }, - schedulingPriority: baseJobDefinition.schedulingPriority, - timeout: { - attemptDurationSeconds: baseJobDefinition.timeout?.toSeconds(), - }, - type: 'dummy', - }; -} -exports.baseJobDefinitionProperties = baseJobDefinitionProperties; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-definition-base.js","sourceRoot":"","sources":["job-definition-base.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAuE;AAgIvE;;GAEG;AACH,MAAa,aAAa;IACxB;;OAEG;IACI,MAAM,CAAC,EAAE,CAAC,MAAc,EAAE,EAAU;;;;;;;;;;;QACzC,OAAO,IAAI,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;KACtC;IAYD,YAAY,MAAc,EAAE,EAAU;;;;;;;+CAlB3B,aAAa;;;;QAmBtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;KACd;;AArBH,sCAsBC;;;AAED;;GAEG;AACH,IAAY,MASX;AATD,WAAY,MAAM;IAChB;;OAEG;IACH,uBAAa,CAAA;IACb;;OAEG;IACH,yBAAe,CAAA;AACjB,CAAC,EATW,MAAM,sBAAN,MAAM,QASjB;AA8BD;;GAEG;AACH,MAAa,MAAM;IAsBjB;;;OAGG;IACH,MAAM,CAAC,MAAM,CAAC,iBAA+B;;;;;;;;;;QAC3C,OAAO,iBAAiB,CAAC;KAC1B;;AA5BH,wBA6BC;;;AA5BC;;GAEG;AACa,yBAAkB,GAAW;IAC3C,UAAU,EAAE,GAAG;CAChB,CAAC;AAEF;;GAEG;AACa,4BAAqB,GAAW;IAC9C,QAAQ,EAAE,4BAA4B;CACvC,CAAA;AAED;;GAEG;AACa,8BAAuB,GAAW;IAChD,cAAc,EAAE,WAAW;CAC5B,CAAA;AAWH;;;;GAIG;AACH,MAAsB,iBAAkB,SAAQ,eAAQ;IAUtD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,EAAE,iBAAiB;SACvC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,KAAK,EAAE,UAAU,CAAC;QACpC,IAAI,CAAC,aAAa,GAAG,KAAK,EAAE,aAAa,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG,KAAK,EAAE,eAAe,IAAI,EAAE,CAAC;QACpD,IAAI,CAAC,kBAAkB,GAAG,KAAK,EAAE,kBAAkB,CAAC;QACpD,IAAI,CAAC,OAAO,GAAG,KAAK,EAAE,OAAO,CAAC;KAC/B;IAED,gBAAgB,CAAC,QAAuB;QACtC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACrC;CACF;AAzBD,8CAyBC;AAED;;GAEG;AACH,SAAgB,2BAA2B,CAAC,iBAAoC;IAC9E,OAAO;QACL,UAAU,EAAE,iBAAiB,CAAC,UAAU;QACxC,aAAa,EAAE;YACb,QAAQ,EAAE,iBAAiB,CAAC,aAAa;YACzC,cAAc,EAAE,WAAI,CAAC,GAAG,CAAC;gBACvB,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,iBAAiB,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;wBAClD,OAAO,SAAS,CAAC;qBAClB;oBACD,OAAO,iBAAiB,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;wBACxD,OAAO;4BACL,MAAM,EAAE,QAAQ,CAAC,MAAM;4BACvB,GAAG,QAAQ,CAAC,EAAE;yBACf,CAAC;oBACJ,CAAC,CAAC,CAAC;gBACL,CAAC;aACF,CAAC;SACH;QACD,kBAAkB,EAAE,iBAAiB,CAAC,kBAAkB;QACxD,OAAO,EAAE;YACP,sBAAsB,EAAE,iBAAiB,CAAC,OAAO,EAAE,SAAS,EAAE;SAC/D;QACD,IAAI,EAAE,OAAO;KACd,CAAC;AACJ,CAAC;AAzBD,kEAyBC","sourcesContent":["import { Duration, IResource, Lazy, Resource } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\n/**\n * Represents a JobDefinition\n */\nexport interface IJobDefinition extends IResource {\n  /**\n   * The ARN of this job definition\n   *\n   * @attribute\n   */\n  readonly jobDefinitionArn: string;\n\n  /**\n   * The name of this job definition\n   *\n   * @attribute\n   */\n  readonly jobDefinitionName: string;\n\n  /**\n   * The default parameters passed to the container\n   * These parameters can be referenced in the `command` that\n   * you give to the container\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters\n   *\n   * @default none\n   */\n  readonly parameters?: { [key:string]: any };\n\n  /**\n   * The number of times to retry a job.\n   * The job is retried on failure the same number of attempts as the value.\n   *\n   * @default 1\n   */\n  readonly retryAttempts?: number;\n\n  /**\n   * Defines the retry behavior for this job\n   *\n   * @default - no `RetryStrategy`\n   */\n  readonly retryStrategies: RetryStrategy[];\n\n  /**\n   * The priority of this Job. Only used in Fairshare Scheduling\n   * to decide which job to run first when there are multiple jobs\n   * with the same share identifier.\n   *\n   * @default none\n   */\n  readonly schedulingPriority?: number;\n\n  /**\n   * The timeout time for jobs that are submitted with this job definition.\n   * After the amount of time you specify passes,\n   * Batch terminates your jobs if they aren't finished.\n   *\n   * @default - no timeout\n   */\n  readonly timeout?: Duration;\n\n  /**\n   * Add a RetryStrategy to this JobDefinition\n   */\n  addRetryStrategy(strategy: RetryStrategy): void;\n}\n\n/**\n * Props common to all JobDefinitions\n */\nexport interface JobDefinitionProps {\n  /**\n   * The name of this job definition\n   *\n   * @default - generated by CloudFormation\n   */\n  readonly jobDefinitionName?: string;\n\n  /**\n   * The default parameters passed to the container\n   * These parameters can be referenced in the `command` that\n   * you give to the container\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/job_definition_parameters.html#parameters\n   *\n   * @default none\n   */\n  readonly parameters?: { [key:string]: any };\n\n  /**\n   * The number of times to retry a job.\n   * The job is retried on failure the same number of attempts as the value.\n   *\n   * @default 1\n   */\n  readonly retryAttempts?: number;\n\n  /**\n   * Defines the retry behavior for this job\n   *\n   * @default - no `RetryStrategy`\n   */\n  readonly retryStrategies?: RetryStrategy[];\n\n  /**\n   * The priority of this Job. Only used in Fairshare Scheduling\n   * to decide which job to run first when there are multiple jobs\n   * with the same share identifier.\n   *\n   * @default none\n   */\n  readonly schedulingPriority?: number;\n\n  /**\n   * The timeout time for jobs that are submitted with this job definition.\n   * After the amount of time you specify passes,\n   * Batch terminates your jobs if they aren't finished.\n   *\n   * @default - no timeout\n   */\n  readonly timeout?: Duration;\n}\n\n/**\n * Define how Jobs using this JobDefinition respond to different exit conditions\n */\nexport class RetryStrategy {\n  /**\n   * Create a new RetryStrategy\n   */\n  public static of(action: Action, on: Reason) {\n    return new RetryStrategy(action, on);\n  }\n\n  /**\n   * The action to take when the job exits with the Reason specified\n   */\n  public readonly action: Action;\n\n  /**\n   * If the job exits with this Reason it will trigger the specified Action\n   */\n  public readonly on: Reason;\n\n  constructor(action: Action, on: Reason) {\n    this.action = action;\n    this.on = on;\n  }\n}\n\n/**\n * The Action to take when all specified conditions in a RetryStrategy are met\n */\nexport enum Action {\n  /**\n   * The job will not retry\n   */\n  EXIT = 'EXIT',\n  /**\n   * The job will retry. It can be retried up to the number of times specified in `retryAttempts`.\n   */\n  RETRY = 'RETRY',\n}\n\n/**\n * The corresponding Action will only be taken if *all* of the conditions specified here are met.\n */\nexport interface CustomReason {\n  /**\n   * A glob string that will match on the job exit code. For example, `'40*'` will match 400, 404, 40123456789012\n   *\n   * @default - will not match on the exit code\n   */\n  readonly onExitCode?: string;\n\n  /**\n   * A glob string that will match on the statusReason returned by the exiting job.\n   * For example, `'Host EC2*'` indicates that the spot instance has been reclaimed.\n   *\n   * @default - will not match on the status reason\n   */\n  readonly onStatusReason?: string;\n\n  /**\n   * A glob string that will match on the reason returned by the exiting job\n   * For example, `'CannotPullContainerError*'` indicates that container needed to start the job could not be pulled.\n   *\n   * @default - will not match on the reason\n   */\n  readonly onReason?: string;\n}\n\n/**\n * Common job exit reasons\n */\nexport class Reason {\n  /**\n   * Will match any non-zero exit code\n   */\n  static readonly NON_ZERO_EXIT_CODE: Reason = {\n    onExitCode: '*',\n  };\n\n  /**\n   * Will only match if the Docker container could not be pulled\n   */\n  static readonly CANNOT_PULL_CONTAINER: Reason = {\n    onReason: 'CannotPullContainerError:*',\n  }\n\n  /**\n   * Will only match if the Spot instance executing the job was reclaimed\n   */\n  static readonly SPOT_INSTANCE_RECLAIMED: Reason = {\n    onStatusReason: 'Host EC2*',\n  }\n\n  /**\n   * A custom Reason that can match on multiple conditions.\n   * Note that all specified conditions must be met for this reason to match.\n   */\n  static custom(customReasonProps: CustomReason): Reason {\n    return customReasonProps;\n  }\n}\n\n/**\n * Abstract base class for JobDefinitions\n *\n * @internal\n */\nexport abstract class JobDefinitionBase extends Resource implements IJobDefinition {\n  public readonly abstract jobDefinitionArn: string;\n  public readonly abstract jobDefinitionName: string;\n\n  public readonly parameters?: { [key:string]: any };\n  public readonly retryAttempts?: number;\n  public readonly retryStrategies: RetryStrategy[];\n  public readonly schedulingPriority?: number;\n  public readonly timeout?: Duration;\n\n  constructor(scope: Construct, id: string, props?: JobDefinitionProps) {\n    super(scope, id, {\n      physicalName: props?.jobDefinitionName,\n    });\n\n    this.parameters = props?.parameters;\n    this.retryAttempts = props?.retryAttempts;\n    this.retryStrategies = props?.retryStrategies ?? [];\n    this.schedulingPriority = props?.schedulingPriority;\n    this.timeout = props?.timeout;\n  }\n\n  addRetryStrategy(strategy: RetryStrategy): void {\n    this.retryStrategies.push(strategy);\n  }\n}\n\n/**\n * @internal\n */\nexport function baseJobDefinitionProperties(baseJobDefinition: JobDefinitionBase): CfnJobDefinitionProps {\n  return {\n    parameters: baseJobDefinition.parameters,\n    retryStrategy: {\n      attempts: baseJobDefinition.retryAttempts,\n      evaluateOnExit: Lazy.any({\n        produce: () => {\n          if (baseJobDefinition.retryStrategies.length === 0) {\n            return undefined;\n          }\n          return baseJobDefinition.retryStrategies.map((strategy) => {\n            return {\n              action: strategy.action,\n              ...strategy.on,\n            };\n          });\n        },\n      }),\n    },\n    schedulingPriority: baseJobDefinition.schedulingPriority,\n    timeout: {\n      attemptDurationSeconds: baseJobDefinition.timeout?.toSeconds(),\n    },\n    type: 'dummy',\n  };\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts deleted file mode 100644 index d72695ba8bdbb..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.d.ts +++ /dev/null @@ -1,140 +0,0 @@ -import { IResource, Resource } from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -import { IComputeEnvironment } from './compute-environment-base'; -import { ISchedulingPolicy } from './scheduling-policy'; -/** - * Represents a JobQueue - */ -export interface IJobQueue extends IResource { - /** - * The name of the job queue. It can be up to 128 letters long. - * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_) - * - * @attribute - */ - readonly jobQueueName: string; - /** - * The ARN of this job queue - * - * @attribute - */ - readonly jobQueueArn: string; - /** - * The set of compute environments mapped to a job queue and their order relative to each other. - * The job scheduler uses this parameter to determine which compute environment runs a specific job. - * Compute environments must be in the VALID state before you can associate them with a job queue. - * You can associate up to three compute environments with a job queue. - * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT); - * EC2 and Fargate compute environments can't be mixed. - * - * *Note*: All compute environments that are associated with a job queue must share the same architecture. - * AWS Batch doesn't support mixing compute environment architecture types in a single job queue. - */ - readonly computeEnvironments: OrderedComputeEnvironment[]; - /** - * The priority of the job queue. - * Job queues with a higher priority are evaluated first when associated with the same compute environment. - * Priority is determined in descending order. - * For example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1. - */ - readonly priority: number; - /** - * If the job queue is enabled, it is able to accept jobs. - * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish. - * - * @default true - */ - readonly enabled?: boolean; - /** - * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs. - * - * @default - no scheduling policy - */ - readonly schedulingPolicy?: ISchedulingPolicy; - /** - * Add a `ComputeEnvironment` to this Queue. - * The Queue will prefer lower-order `ComputeEnvironment`s. - */ - addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void; -} -/** - * Props to configure a JobQueue - */ -export interface JobQueueProps { - /** - * The set of compute environments mapped to a job queue and their order relative to each other. - * The job scheduler uses this parameter to determine which compute environment runs a specific job. - * Compute environments must be in the VALID state before you can associate them with a job queue. - * You can associate up to three compute environments with a job queue. - * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT); - * EC2 and Fargate compute environments can't be mixed. - * - * *Note*: All compute environments that are associated with a job queue must share the same architecture. - * AWS Batch doesn't support mixing compute environment architecture types in a single job queue. - * - * @default none - */ - readonly computeEnvironments?: OrderedComputeEnvironment[]; - /** - * The priority of the job queue. - * Job queues with a higher priority are evaluated first when associated with the same compute environment. - * Priority is determined in descending order. - * For example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1. - * - * @default 1 - */ - readonly priority?: number; - /** - * The name of the job queue. It can be up to 128 letters long. - * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_) - * - * @default - no name - */ - readonly jobQueueName?: string; - /** - * If the job queue is enabled, it is able to accept jobs. - * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish. - * - * @default true - */ - readonly enabled?: boolean; - /** - * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs. - * - * @default - no scheduling policy - */ - readonly schedulingPolicy?: ISchedulingPolicy; -} -/** - * Assigns an order to a ComputeEnvironment. - * The JobQueue will prioritize the lowest-order ComputeEnvironment. - */ -export interface OrderedComputeEnvironment { - /** - * The ComputeEnvironment to link to this JobQueue - */ - readonly computeEnvironment: IComputeEnvironment; - /** - * The order associated with `computeEnvironment` - */ - readonly order: number; -} -/** - * JobQueues can receive Jobs, which are removed from the queue when - * sent to the linked ComputeEnvironment(s) to be executed. - * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked. - */ -export declare class JobQueue extends Resource implements IJobQueue { - /** - * refer to an existing JobQueue by its arn - */ - static fromJobQueueArn(scope: Construct, id: string, jobQueueArn: string): IJobQueue; - readonly computeEnvironments: OrderedComputeEnvironment[]; - readonly priority: number; - readonly enabled?: boolean; - readonly schedulingPolicy?: ISchedulingPolicy; - readonly jobQueueArn: string; - readonly jobQueueName: string; - constructor(scope: Construct, id: string, props?: JobQueueProps); - addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void; -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js b/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js deleted file mode 100644 index a769e9e07cb5e..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/job-queue.js +++ /dev/null @@ -1,102 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.JobQueue = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -/** - * JobQueues can receive Jobs, which are removed from the queue when - * sent to the linked ComputeEnvironment(s) to be executed. - * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked. - */ -class JobQueue extends core_1.Resource { - /** - * refer to an existing JobQueue by its arn - */ - static fromJobQueueArn(scope, id, jobQueueArn) { - const stack = core_1.Stack.of(scope); - class Import extends core_1.Resource { - constructor() { - super(...arguments); - this.computeEnvironments = []; - this.priority = 1; - this.jobQueueArn = jobQueueArn; - this.jobQueueName = stack.splitArn(jobQueueArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - } - addComputeEnvironment(_computeEnvironment, _order) { - throw new Error(`cannot add ComputeEnvironments to imported JobQueue '${id}'`); - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, { - physicalName: props?.jobQueueName, - }); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_JobQueueProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, JobQueue); - } - throw error; - } - this.computeEnvironments = props?.computeEnvironments ?? []; - this.priority = props?.priority ?? 1; - this.enabled = props?.enabled; - this.schedulingPolicy = props?.schedulingPolicy; - const resource = new aws_batch_1.CfnJobQueue(this, 'Resource', { - computeEnvironmentOrder: core_1.Lazy.any({ - produce: () => this.computeEnvironments.map((ce) => { - return { - computeEnvironment: ce.computeEnvironment.computeEnvironmentArn, - order: ce.order, - }; - }), - }), - priority: this.priority, - jobQueueName: props?.jobQueueName, - state: (this.enabled ?? true) ? 'ENABLED' : 'DISABLED', - schedulingPolicyArn: this.schedulingPolicy?.schedulingPolicyArn, - }); - this.jobQueueArn = this.getResourceArnAttribute(resource.attrJobQueueArn, { - service: 'batch', - resource: 'job-queue', - resourceName: this.physicalName, - }); - this.jobQueueName = core_1.Stack.of(this).splitArn(this.jobQueueArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - this.node.addValidation({ validate: () => validateOrderedComputeEnvironments(this.computeEnvironments) }); - } - addComputeEnvironment(computeEnvironment, order) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_IComputeEnvironment(computeEnvironment); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addComputeEnvironment); - } - throw error; - } - this.computeEnvironments.push({ - computeEnvironment, - order, - }); - } -} -exports.JobQueue = JobQueue; -_a = JSII_RTTI_SYMBOL_1; -JobQueue[_a] = { fqn: "@aws-cdk/aws-batch-alpha.JobQueue", version: "0.0.0" }; -function validateOrderedComputeEnvironments(computeEnvironments) { - const seenOrders = []; - for (const ce of computeEnvironments) { - if (seenOrders.includes(ce.order)) { - return ['assigns the same order to different ComputeEnvironments']; - } - seenOrders.push(ce.order); - } - return seenOrders.length === 0 ? ['This JobQueue does not link any ComputeEnvironments'] : []; -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-queue.js","sourceRoot":"","sources":["job-queue.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArnFormat, IResource, Lazy, Resource, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobQueue } from 'aws-cdk-lib/aws-batch';\nimport { IComputeEnvironment } from './compute-environment-base';\nimport { ISchedulingPolicy } from './scheduling-policy';\n\n/**\n * Represents a JobQueue\n */\nexport interface IJobQueue extends IResource {\n  /**\n   * The name of the job queue. It can be up to 128 letters long.\n   * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)\n   *\n   * @attribute\n   */\n  readonly jobQueueName: string\n\n  /**\n   * The ARN of this job queue\n   *\n   * @attribute\n   */\n  readonly jobQueueArn: string;\n\n  /**\n   * The set of compute environments mapped to a job queue and their order relative to each other.\n   * The job scheduler uses this parameter to determine which compute environment runs a specific job.\n   * Compute environments must be in the VALID state before you can associate them with a job queue.\n   * You can associate up to three compute environments with a job queue.\n   * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\n   * EC2 and Fargate compute environments can't be mixed.\n   *\n   * *Note*: All compute environments that are associated with a job queue must share the same architecture.\n   * AWS Batch doesn't support mixing compute environment architecture types in a single job queue.\n   */\n  readonly computeEnvironments: OrderedComputeEnvironment[]\n\n  /**\n   * The priority of the job queue.\n   * Job queues with a higher priority are evaluated first when associated with the same compute environment.\n   * Priority is determined in descending order.\n   * For example, a job queue with a priority value of 10 is given scheduling preference over a job queue with a priority value of 1.\n   */\n  readonly priority: number\n\n  /**\n   * If the job queue is enabled, it is able to accept jobs.\n   * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.\n   *\n   * @default true\n   */\n  readonly enabled?: boolean\n\n  /**\n   * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs.\n   *\n   * @default - no scheduling policy\n   */\n  readonly schedulingPolicy?: ISchedulingPolicy\n\n  /**\n   * Add a `ComputeEnvironment` to this Queue.\n   * The Queue will prefer lower-order `ComputeEnvironment`s.\n   */\n  addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void;\n}\n\n/**\n * Props to configure a JobQueue\n */\nexport interface JobQueueProps {\n  /**\n   * The set of compute environments mapped to a job queue and their order relative to each other.\n   * The job scheduler uses this parameter to determine which compute environment runs a specific job.\n   * Compute environments must be in the VALID state before you can associate them with a job queue.\n   * You can associate up to three compute environments with a job queue.\n   * All of the compute environments must be either EC2 (EC2 or SPOT) or Fargate (FARGATE or FARGATE_SPOT);\n   * EC2 and Fargate compute environments can't be mixed.\n   *\n   * *Note*: All compute environments that are associated with a job queue must share the same architecture.\n   * AWS Batch doesn't support mixing compute environment architecture types in a single job queue.\n   *\n   * @default none\n   */\n  readonly computeEnvironments?: OrderedComputeEnvironment[]\n\n  /**\n   * The priority of the job queue.\n   * Job queues with a higher priority are evaluated first when associated with the same compute environment.\n   * Priority is determined in descending order.\n   * For example, a job queue with a priority of 10 is given scheduling preference over a job queue with a priority of 1.\n   *\n   * @default 1\n   */\n  readonly priority?: number\n\n  /**\n   * The name of the job queue. It can be up to 128 letters long.\n   * It can contain uppercase and lowercase letters, numbers, hyphens (-), and underscores (_)\n   *\n   * @default - no name\n   */\n  readonly jobQueueName?: string\n\n  /**\n   * If the job queue is enabled, it is able to accept jobs.\n   * Otherwise, new jobs can't be added to the queue, but jobs already in the queue can finish.\n   *\n   * @default true\n   */\n  readonly enabled?: boolean\n\n  /**\n   * The SchedulingPolicy for this JobQueue. Instructs the Scheduler how to schedule different jobs.\n   *\n   * @default - no scheduling policy\n   */\n  readonly schedulingPolicy?: ISchedulingPolicy\n}\n\n/**\n * Assigns an order to a ComputeEnvironment.\n * The JobQueue will prioritize the lowest-order ComputeEnvironment.\n */\nexport interface OrderedComputeEnvironment {\n  /**\n   * The ComputeEnvironment to link to this JobQueue\n   */\n  readonly computeEnvironment: IComputeEnvironment;\n\n  /**\n   * The order associated with `computeEnvironment`\n   */\n  readonly order: number;\n}\n\n/**\n * JobQueues can receive Jobs, which are removed from the queue when\n * sent to the linked ComputeEnvironment(s) to be executed.\n * Jobs exit the queue in FIFO order unless a `SchedulingPolicy` is linked.\n */\nexport class JobQueue extends Resource implements IJobQueue {\n  /**\n   * refer to an existing JobQueue by its arn\n   */\n  public static fromJobQueueArn(scope: Construct, id: string, jobQueueArn: string): IJobQueue {\n    const stack = Stack.of(scope);\n    class Import extends Resource implements IJobQueue {\n      public readonly computeEnvironments = [];\n      public readonly priority = 1;\n      public readonly jobQueueArn = jobQueueArn;\n      public readonly jobQueueName = stack.splitArn(jobQueueArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n      public addComputeEnvironment(_computeEnvironment: IComputeEnvironment, _order: number): void {\n        throw new Error(`cannot add ComputeEnvironments to imported JobQueue '${id}'`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeEnvironments: OrderedComputeEnvironment[]\n  public readonly priority: number\n  public readonly enabled?: boolean\n  public readonly schedulingPolicy?: ISchedulingPolicy\n\n  public readonly jobQueueArn: string;\n  public readonly jobQueueName: string;\n\n  constructor(scope: Construct, id: string, props?: JobQueueProps) {\n    super(scope, id, {\n      physicalName: props?.jobQueueName,\n    });\n\n    this.computeEnvironments = props?.computeEnvironments ?? [];\n    this.priority = props?.priority ?? 1;\n    this.enabled = props?.enabled;\n    this.schedulingPolicy = props?.schedulingPolicy;\n\n    const resource = new CfnJobQueue(this, 'Resource', {\n      computeEnvironmentOrder: Lazy.any({\n        produce: () => this.computeEnvironments.map((ce) => {\n          return {\n            computeEnvironment: ce.computeEnvironment.computeEnvironmentArn,\n            order: ce.order,\n          };\n        }),\n      }),\n      priority: this.priority,\n      jobQueueName: props?.jobQueueName,\n      state: (this.enabled ?? true) ? 'ENABLED' : 'DISABLED',\n      schedulingPolicyArn: this.schedulingPolicy?.schedulingPolicyArn,\n    });\n\n    this.jobQueueArn = this.getResourceArnAttribute(resource.attrJobQueueArn, {\n      service: 'batch',\n      resource: 'job-queue',\n      resourceName: this.physicalName,\n    });\n    this.jobQueueName = Stack.of(this).splitArn(this.jobQueueArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    this.node.addValidation({ validate: () => validateOrderedComputeEnvironments(this.computeEnvironments) });\n  }\n\n  addComputeEnvironment(computeEnvironment: IComputeEnvironment, order: number): void {\n    this.computeEnvironments.push({\n      computeEnvironment,\n      order,\n    });\n  }\n}\n\nfunction validateOrderedComputeEnvironments(computeEnvironments: OrderedComputeEnvironment[]): string[] {\n  const seenOrders: number[] = [];\n\n  for (const ce of computeEnvironments) {\n    if (seenOrders.includes(ce.order)) {\n      return ['assigns the same order to different ComputeEnvironments'];\n    }\n    seenOrders.push(ce.order);\n  }\n\n  return seenOrders.length === 0 ? ['This JobQueue does not link any ComputeEnvironments'] : [];\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts deleted file mode 100644 index e9336be95bd7a..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.d.ts +++ /dev/null @@ -1,196 +0,0 @@ -import * as cdk from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -import { CfnJobDefinition } from 'aws-cdk-lib/aws-batch'; -/** - * The properties for defining Linux-specific options that are applied to the container. - */ -export interface LinuxParametersProps { - /** - * Specifies whether to run an init process inside the container that forwards signals and reaps processes. - * - * @default false - */ - readonly initProcessEnabled?: boolean; - /** - * The value for the size of the /dev/shm volume. - * - * @default No shared memory. - */ - readonly sharedMemorySize?: cdk.Size; - /** - * The total amount of swap memory a container can use. This parameter - * will be translated to the --memory-swap option to docker run. - * - * This parameter is only supported when you are using the EC2 launch type. - * Accepted values are positive integers. - * - * @default No swap. - */ - readonly maxSwap?: cdk.Size; - /** - * This allows you to tune a container's memory swappiness behavior. This parameter - * maps to the --memory-swappiness option to docker run. The swappiness relates - * to the kernel's tendency to swap memory. A value of 0 will cause swapping to - * not happen unless absolutely necessary. A value of 100 will cause pages to - * be swapped very aggressively. - * - * This parameter is only supported when you are using the EC2 launch type. - * Accepted values are whole numbers between 0 and 100. If a value is not - * specified for maxSwap then this parameter is ignored. - * - * @default 60 - */ - readonly swappiness?: number; -} -/** - * Linux-specific options that are applied to the container. - */ -export declare class LinuxParameters extends Construct { - /** - * Whether the init process is enabled - */ - protected readonly initProcessEnabled?: boolean; - /** - * The shared memory size (in MiB). Not valid for Fargate launch type - */ - protected readonly sharedMemorySize?: cdk.Size; - /** - * The max swap memory - */ - protected readonly maxSwap?: cdk.Size; - /** - * The swappiness behavior - */ - protected readonly swappiness?: number; - /** - * Device mounts - */ - protected readonly devices: Device[]; - /** - * TmpFs mounts - */ - protected readonly tmpfs: Tmpfs[]; - /** - * Constructs a new instance of the LinuxParameters class. - */ - constructor(scope: Construct, id: string, props?: LinuxParametersProps); - private validateProps; - /** - * Adds one or more host devices to a container. - */ - addDevices(...device: Device[]): void; - /** - * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container. - * - * Only works with EC2 launch type. - */ - addTmpfs(...tmpfs: Tmpfs[]): void; - /** - * Renders the Linux parameters to the Batch version of this resource, - * which does not have 'capabilities' and requires tmpfs.containerPath to be defined. - */ - renderLinuxParameters(): CfnJobDefinition.LinuxParametersProperty; -} -/** - * A container instance host device. - */ -export interface Device { - /** - * The path inside the container at which to expose the host device. - * - * @default Same path as the host - */ - readonly containerPath?: string; - /** - * The path for the device on the host container instance. - */ - readonly hostPath: string; - /** - * The explicit permissions to provide to the container for the device. - * By default, the container has permissions for read, write, and mknod for the device. - * - * @default Readonly - */ - readonly permissions?: DevicePermission[]; -} -/** - * The details of a tmpfs mount for a container. - */ -export interface Tmpfs { - /** - * The absolute file path where the tmpfs volume is to be mounted. - */ - readonly containerPath: string; - /** - * The size (in MiB) of the tmpfs volume. - */ - readonly size: cdk.Size; - /** - * The list of tmpfs volume mount options. For more information, see - * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html). - * - * @default none - */ - readonly mountOptions?: TmpfsMountOption[]; -} -/** - * Permissions for device access - */ -export declare enum DevicePermission { - /** - * Read - */ - READ = "read", - /** - * Write - */ - WRITE = "write", - /** - * Make a node - */ - MKNOD = "mknod" -} -/** - * The supported options for a tmpfs mount for a container. - */ -export declare enum TmpfsMountOption { - DEFAULTS = "defaults", - RO = "ro", - RW = "rw", - SUID = "suid", - NOSUID = "nosuid", - DEV = "dev", - NODEV = "nodev", - EXEC = "exec", - NOEXEC = "noexec", - SYNC = "sync", - ASYNC = "async", - DIRSYNC = "dirsync", - REMOUNT = "remount", - MAND = "mand", - NOMAND = "nomand", - ATIME = "atime", - NOATIME = "noatime", - DIRATIME = "diratime", - NODIRATIME = "nodiratime", - BIND = "bind", - RBIND = "rbind", - UNBINDABLE = "unbindable", - RUNBINDABLE = "runbindable", - PRIVATE = "private", - RPRIVATE = "rprivate", - SHARED = "shared", - RSHARED = "rshared", - SLAVE = "slave", - RSLAVE = "rslave", - RELATIME = "relatime", - NORELATIME = "norelatime", - STRICTATIME = "strictatime", - NOSTRICTATIME = "nostrictatime", - MODE = "mode", - UID = "uid", - GID = "gid", - NR_INODES = "nr_inodes", - NR_BLOCKS = "nr_blocks", - MPOL = "mpol" -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js b/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js deleted file mode 100644 index 2a00173e4d6da..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/linux-parameters.js +++ /dev/null @@ -1,175 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.TmpfsMountOption = exports.DevicePermission = exports.LinuxParameters = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const cdk = require("aws-cdk-lib/core"); -const constructs_1 = require("constructs"); -/** - * Linux-specific options that are applied to the container. - */ -class LinuxParameters extends constructs_1.Construct { - /** - * Constructs a new instance of the LinuxParameters class. - */ - constructor(scope, id, props = {}) { - super(scope, id); - /** - * Device mounts - */ - this.devices = new Array(); - /** - * TmpFs mounts - */ - this.tmpfs = new Array(); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_LinuxParametersProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, LinuxParameters); - } - throw error; - } - this.validateProps(props); - this.sharedMemorySize = props.sharedMemorySize; - this.initProcessEnabled = props.initProcessEnabled; - this.maxSwap = props.maxSwap; - this.swappiness = props.maxSwap ? props.swappiness : undefined; - } - validateProps(props) { - if (!cdk.Token.isUnresolved(props.swappiness) && - props.swappiness !== undefined && - (!Number.isInteger(props.swappiness) || props.swappiness < 0 || props.swappiness > 100)) { - throw new Error(`swappiness: Must be an integer between 0 and 100; received ${props.swappiness}.`); - } - } - /** - * Adds one or more host devices to a container. - */ - addDevices(...device) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Device(device); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addDevices); - } - throw error; - } - this.devices.push(...device); - } - /** - * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container. - * - * Only works with EC2 launch type. - */ - addTmpfs(...tmpfs) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Tmpfs(tmpfs); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addTmpfs); - } - throw error; - } - this.tmpfs.push(...tmpfs); - } - /** - * Renders the Linux parameters to the Batch version of this resource, - * which does not have 'capabilities' and requires tmpfs.containerPath to be defined. - */ - renderLinuxParameters() { - return { - initProcessEnabled: this.initProcessEnabled, - sharedMemorySize: this.sharedMemorySize?.toMebibytes(), - maxSwap: this.maxSwap?.toMebibytes(), - swappiness: this.swappiness, - devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }), - tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }), - }; - } -} -exports.LinuxParameters = LinuxParameters; -_a = JSII_RTTI_SYMBOL_1; -LinuxParameters[_a] = { fqn: "@aws-cdk/aws-batch-alpha.LinuxParameters", version: "0.0.0" }; -/** - * Permissions for device access - */ -var DevicePermission; -(function (DevicePermission) { - /** - * Read - */ - DevicePermission["READ"] = "read"; - /** - * Write - */ - DevicePermission["WRITE"] = "write"; - /** - * Make a node - */ - DevicePermission["MKNOD"] = "mknod"; -})(DevicePermission || (exports.DevicePermission = DevicePermission = {})); -/** - * The supported options for a tmpfs mount for a container. - */ -var TmpfsMountOption; -(function (TmpfsMountOption) { - TmpfsMountOption["DEFAULTS"] = "defaults"; - TmpfsMountOption["RO"] = "ro"; - TmpfsMountOption["RW"] = "rw"; - TmpfsMountOption["SUID"] = "suid"; - TmpfsMountOption["NOSUID"] = "nosuid"; - TmpfsMountOption["DEV"] = "dev"; - TmpfsMountOption["NODEV"] = "nodev"; - TmpfsMountOption["EXEC"] = "exec"; - TmpfsMountOption["NOEXEC"] = "noexec"; - TmpfsMountOption["SYNC"] = "sync"; - TmpfsMountOption["ASYNC"] = "async"; - TmpfsMountOption["DIRSYNC"] = "dirsync"; - TmpfsMountOption["REMOUNT"] = "remount"; - TmpfsMountOption["MAND"] = "mand"; - TmpfsMountOption["NOMAND"] = "nomand"; - TmpfsMountOption["ATIME"] = "atime"; - TmpfsMountOption["NOATIME"] = "noatime"; - TmpfsMountOption["DIRATIME"] = "diratime"; - TmpfsMountOption["NODIRATIME"] = "nodiratime"; - TmpfsMountOption["BIND"] = "bind"; - TmpfsMountOption["RBIND"] = "rbind"; - TmpfsMountOption["UNBINDABLE"] = "unbindable"; - TmpfsMountOption["RUNBINDABLE"] = "runbindable"; - TmpfsMountOption["PRIVATE"] = "private"; - TmpfsMountOption["RPRIVATE"] = "rprivate"; - TmpfsMountOption["SHARED"] = "shared"; - TmpfsMountOption["RSHARED"] = "rshared"; - TmpfsMountOption["SLAVE"] = "slave"; - TmpfsMountOption["RSLAVE"] = "rslave"; - TmpfsMountOption["RELATIME"] = "relatime"; - TmpfsMountOption["NORELATIME"] = "norelatime"; - TmpfsMountOption["STRICTATIME"] = "strictatime"; - TmpfsMountOption["NOSTRICTATIME"] = "nostrictatime"; - TmpfsMountOption["MODE"] = "mode"; - TmpfsMountOption["UID"] = "uid"; - TmpfsMountOption["GID"] = "gid"; - TmpfsMountOption["NR_INODES"] = "nr_inodes"; - TmpfsMountOption["NR_BLOCKS"] = "nr_blocks"; - TmpfsMountOption["MPOL"] = "mpol"; -})(TmpfsMountOption || (exports.TmpfsMountOption = TmpfsMountOption = {})); -function renderTmpfs(tmpfs) { - return { - containerPath: tmpfs.containerPath, - size: tmpfs.size.toMebibytes(), - mountOptions: tmpfs.mountOptions, - }; -} -function renderDevice(device) { - return { - containerPath: device.containerPath, - hostPath: device.hostPath, - permissions: device.permissions, - }; -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-parameters.js","sourceRoot":"","sources":["linux-parameters.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\n\n/**\n * The properties for defining Linux-specific options that are applied to the container.\n */\nexport interface LinuxParametersProps {\n  /**\n   * Specifies whether to run an init process inside the container that forwards signals and reaps processes.\n   *\n   * @default false\n   */\n  readonly initProcessEnabled?: boolean;\n\n  /**\n   * The value for the size of the /dev/shm volume.\n   *\n   * @default No shared memory.\n   */\n  readonly sharedMemorySize?: cdk.Size;\n\n  /**\n   * The total amount of swap memory a container can use. This parameter\n   * will be translated to the --memory-swap option to docker run.\n   *\n   * This parameter is only supported when you are using the EC2 launch type.\n   * Accepted values are positive integers.\n   *\n   * @default No swap.\n   */\n  readonly maxSwap?: cdk.Size;\n\n  /**\n    * This allows you to tune a container's memory swappiness behavior. This parameter\n    * maps to the --memory-swappiness option to docker run. The swappiness relates\n    * to the kernel's tendency to swap memory. A value of 0 will cause swapping to\n    * not happen unless absolutely necessary. A value of 100 will cause pages to\n    * be swapped very aggressively.\n    *\n    * This parameter is only supported when you are using the EC2 launch type.\n    * Accepted values are whole numbers between 0 and 100. If a value is not\n    * specified for maxSwap then this parameter is ignored.\n    *\n    * @default 60\n    */\n  readonly swappiness?: number;\n}\n\n/**\n * Linux-specific options that are applied to the container.\n */\nexport class LinuxParameters extends Construct {\n  /**\n   * Whether the init process is enabled\n   */\n  protected readonly initProcessEnabled?: boolean;\n\n  /**\n   * The shared memory size (in MiB). Not valid for Fargate launch type\n   */\n  protected readonly sharedMemorySize?: cdk.Size;\n\n  /**\n   * The max swap memory\n   */\n  protected readonly maxSwap?: cdk.Size;\n\n  /**\n   * The swappiness behavior\n   */\n  protected readonly swappiness?: number;\n\n  /**\n   * Device mounts\n   */\n  protected readonly devices = new Array<Device>();\n\n  /**\n   * TmpFs mounts\n   */\n  protected readonly tmpfs = new Array<Tmpfs>();\n\n  /**\n   * Constructs a new instance of the LinuxParameters class.\n   */\n  constructor(scope: Construct, id: string, props: LinuxParametersProps = {}) {\n    super(scope, id);\n\n    this.validateProps(props);\n\n    this.sharedMemorySize = props.sharedMemorySize;\n    this.initProcessEnabled = props.initProcessEnabled;\n    this.maxSwap = props.maxSwap;\n    this.swappiness = props.maxSwap ? props.swappiness : undefined;\n  }\n\n  private validateProps(props: LinuxParametersProps) {\n    if (\n      !cdk.Token.isUnresolved(props.swappiness) &&\n      props.swappiness !== undefined &&\n      (!Number.isInteger(props.swappiness) || props.swappiness < 0 || props.swappiness > 100)\n    ) {\n      throw new Error(`swappiness: Must be an integer between 0 and 100; received ${props.swappiness}.`);\n    }\n  }\n\n  /**\n   * Adds one or more host devices to a container.\n   */\n  public addDevices(...device: Device[]) {\n    this.devices.push(...device);\n  }\n\n  /**\n   * Specifies the container path, mount options, and size (in MiB) of the tmpfs mount for a container.\n   *\n   * Only works with EC2 launch type.\n   */\n  public addTmpfs(...tmpfs: Tmpfs[]) {\n    this.tmpfs.push(...tmpfs);\n  }\n\n  /**\n   * Renders the Linux parameters to the Batch version of this resource,\n   * which does not have 'capabilities' and requires tmpfs.containerPath to be defined.\n   */\n  public renderLinuxParameters(): CfnJobDefinition.LinuxParametersProperty {\n    return {\n      initProcessEnabled: this.initProcessEnabled,\n      sharedMemorySize: this.sharedMemorySize?.toMebibytes(),\n      maxSwap: this.maxSwap?.toMebibytes(),\n      swappiness: this.swappiness,\n      devices: cdk.Lazy.any({ produce: () => this.devices.map(renderDevice) }, { omitEmptyArray: true }),\n      tmpfs: cdk.Lazy.any({ produce: () => this.tmpfs.map(renderTmpfs) }, { omitEmptyArray: true }),\n    };\n  }\n}\n\n/**\n * A container instance host device.\n */\nexport interface Device {\n  /**\n   * The path inside the container at which to expose the host device.\n   *\n   * @default Same path as the host\n   */\n  readonly containerPath?: string,\n\n  /**\n   * The path for the device on the host container instance.\n   */\n  readonly hostPath: string,\n\n  /**\n   * The explicit permissions to provide to the container for the device.\n   * By default, the container has permissions for read, write, and mknod for the device.\n   *\n   * @default Readonly\n   */\n  readonly permissions?: DevicePermission[]\n}\n\n/**\n * The details of a tmpfs mount for a container.\n */\nexport interface Tmpfs {\n  /**\n   * The absolute file path where the tmpfs volume is to be mounted.\n   */\n  readonly containerPath: string,\n\n  /**\n   * The size (in MiB) of the tmpfs volume.\n   */\n  readonly size: cdk.Size,\n\n  /**\n   * The list of tmpfs volume mount options. For more information, see\n   * [TmpfsMountOptions](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_Tmpfs.html).\n   *\n   * @default none\n   */\n  readonly mountOptions?: TmpfsMountOption[],\n}\n\n/**\n * Permissions for device access\n */\nexport enum DevicePermission {\n  /**\n   * Read\n   */\n  READ = 'read',\n\n  /**\n   * Write\n   */\n  WRITE = 'write',\n\n  /**\n   * Make a node\n   */\n  MKNOD = 'mknod',\n}\n\n/**\n * The supported options for a tmpfs mount for a container.\n */\nexport enum TmpfsMountOption {\n  DEFAULTS = 'defaults',\n  RO = 'ro',\n  RW = 'rw',\n  SUID = 'suid',\n  NOSUID = 'nosuid',\n  DEV = 'dev',\n  NODEV = 'nodev',\n  EXEC = 'exec',\n  NOEXEC = 'noexec',\n  SYNC = 'sync',\n  ASYNC = 'async',\n  DIRSYNC = 'dirsync',\n  REMOUNT = 'remount',\n  MAND = 'mand',\n  NOMAND = 'nomand',\n  ATIME = 'atime',\n  NOATIME = 'noatime',\n  DIRATIME = 'diratime',\n  NODIRATIME = 'nodiratime',\n  BIND = 'bind',\n  RBIND = 'rbind',\n  UNBINDABLE = 'unbindable',\n  RUNBINDABLE = 'runbindable',\n  PRIVATE = 'private',\n  RPRIVATE = 'rprivate',\n  SHARED = 'shared',\n  RSHARED = 'rshared',\n  SLAVE = 'slave',\n  RSLAVE = 'rslave',\n  RELATIME = 'relatime',\n  NORELATIME = 'norelatime',\n  STRICTATIME = 'strictatime',\n  NOSTRICTATIME = 'nostrictatime',\n  MODE = 'mode',\n  UID = 'uid',\n  GID = 'gid',\n  NR_INODES = 'nr_inodes',\n  NR_BLOCKS = 'nr_blocks',\n  MPOL = 'mpol'\n}\n\nfunction renderTmpfs(tmpfs: Tmpfs): CfnJobDefinition.TmpfsProperty {\n  return {\n    containerPath: tmpfs.containerPath,\n    size: tmpfs.size.toMebibytes(),\n    mountOptions: tmpfs.mountOptions,\n  };\n}\n\nfunction renderDevice(device: Device): CfnJobDefinition.DeviceProperty {\n  return {\n    containerPath: device.containerPath,\n    hostPath: device.hostPath,\n    permissions: device.permissions,\n  };\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts deleted file mode 100644 index 6578bdcb3fd27..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.d.ts +++ /dev/null @@ -1,806 +0,0 @@ -import * as ec2 from 'aws-cdk-lib/aws-ec2'; -import * as eks from 'aws-cdk-lib/aws-eks'; -import * as iam from 'aws-cdk-lib/aws-iam'; -import { Duration, ITaggable, TagManager } from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -import { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base'; -/** - * Represents a Managed ComputeEnvironment. Batch will provision EC2 Instances to - * meet the requirements of the jobs executing in this ComputeEnvironment. - */ -export interface IManagedComputeEnvironment extends IComputeEnvironment, ec2.IConnectable, ITaggable { - /** - * The maximum vCpus this `ManagedComputeEnvironment` can scale up to. - * - * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or - * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances, - * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes` - * or `instanceClasses`. - */ - readonly maxvCpus: number; - /** - * Specifies whether this Compute Environment is replaced if an update is made that requires - * replacing its instances. To enable more properties to be updated, - * set this property to `false`. When changing the value of this property to false, - * do not change any other properties at the same time. - * If other properties are changed at the same time, - * and the change needs to be rolled back but it can't, - * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state. - * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state. - * However, if you can continue to roll it back, - * you can return the stack to its original settings and then try to update it again. - * - * The properties which require a replacement of the Compute Environment are: - * - * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment - * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html - */ - readonly replaceComputeEnvironment?: boolean; - /** - * Whether or not to use spot instances. - * Spot instances are less expensive EC2 instances that can be - * reclaimed by EC2 at any time; your job will be given two minutes - * of notice before reclamation. - * - * @default false - */ - readonly spot?: boolean; - /** - * Only meaningful if `terminateOnUpdate` is `false`. If so, - * when an infrastructure update is triggered, any running jobs - * will be allowed to run until `updateTimeout` has expired. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html - * @default 30 minutes - */ - readonly updateTimeout?: Duration; - /** - * Whether or not any running jobs will be immediately terminated when an infrastructure update - * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's - * retry policy. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html - * - * @default false - */ - readonly terminateOnUpdate?: boolean; - /** - * The security groups this Compute Environment will launch instances in. - */ - readonly securityGroups: ec2.ISecurityGroup[]; - /** - * The VPC Subnets this Compute Environment will launch instances in. - */ - readonly vpcSubnets?: ec2.SubnetSelection; - /** - * Whether or not the AMI is updated to the latest one supported by Batch - * when an infrastructure update occurs. - * - * If you specify a specific AMI, this property will be ignored. - * - * @default true - */ - readonly updateToLatestImageVersion?: boolean; -} -/** - * Props for a ManagedComputeEnvironment - */ -export interface ManagedComputeEnvironmentProps extends ComputeEnvironmentProps { - /** - * The maximum vCpus this `ManagedComputeEnvironment` can scale up to. - * Each vCPU is equivalent to 1024 CPU shares. - * - * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or - * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances, - * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes` - * or `instanceClasses`. - * - * @default 256 - */ - readonly maxvCpus?: number; - /** - * Specifies whether this Compute Environment is replaced if an update is made that requires - * replacing its instances. To enable more properties to be updated, - * set this property to `false`. When changing the value of this property to false, - * do not change any other properties at the same time. - * If other properties are changed at the same time, - * and the change needs to be rolled back but it can't, - * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state. - * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state. - * However, if you can continue to roll it back, - * you can return the stack to its original settings and then try to update it again. - * - * The properties which require a replacement of the Compute Environment are: - * - * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment - * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html - * - * @default false - */ - readonly replaceComputeEnvironment?: boolean; - /** - * Whether or not to use spot instances. - * Spot instances are less expensive EC2 instances that can be - * reclaimed by EC2 at any time; your job will be given two minutes - * of notice before reclamation. - * - * @default false - */ - readonly spot?: boolean; - /** - * Only meaningful if `terminateOnUpdate` is `false`. If so, - * when an infrastructure update is triggered, any running jobs - * will be allowed to run until `updateTimeout` has expired. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html - * - * @default 30 minutes - */ - readonly updateTimeout?: Duration; - /** - * Whether or not any running jobs will be immediately terminated when an infrastructure update - * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's - * retry policy. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html - * - * @default false - */ - readonly terminateOnUpdate?: boolean; - /** - * VPC in which this Compute Environment will launch Instances - */ - readonly vpc: ec2.IVpc; - /** - * The security groups this Compute Environment will launch instances in. - * - * @default new security groups will be created - */ - readonly securityGroups?: ec2.ISecurityGroup[]; - /** - * The VPC Subnets this Compute Environment will launch instances in. - * - * @default new subnets will be created - */ - readonly vpcSubnets?: ec2.SubnetSelection; - /** - * Whether or not the AMI is updated to the latest one supported by Batch - * when an infrastructure update occurs. - * - * If you specify a specific AMI, this property will be ignored. - * - * @default true - */ - readonly updateToLatestImageVersion?: boolean; -} -/** - * Abstract base class for ManagedComputeEnvironments - * @internal - */ -export declare abstract class ManagedComputeEnvironmentBase extends ComputeEnvironmentBase implements IManagedComputeEnvironment { - readonly maxvCpus: number; - readonly replaceComputeEnvironment?: boolean; - readonly spot?: boolean; - readonly updateTimeout?: Duration; - readonly terminateOnUpdate?: boolean; - readonly securityGroups: ec2.ISecurityGroup[]; - readonly updateToLatestImageVersion?: boolean; - readonly tags: TagManager; - readonly connections: ec2.Connections; - constructor(scope: Construct, id: string, props: ManagedComputeEnvironmentProps); -} -/** - * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. - */ -export interface IManagedEc2EcsComputeEnvironment extends IManagedComputeEnvironment { - /** - * Configure which AMIs this Compute Environment can launch. - * - * Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches. - * - * @default - * - ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances - */ - readonly images?: EcsMachineImage[]; - /** - * The allocation strategy to use if not enough instances of - * the best fitting instance type can be allocated. - * - * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, - * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. - */ - readonly allocationStrategy?: AllocationStrategy; - /** - * The maximum percentage that a Spot Instance price can be when compared with the - * On-Demand price for that instance type before instances are launched. - * For example, if your maximum percentage is 20%, the Spot price must be - * less than 20% of the current On-Demand price for that Instance. - * You always pay the lowest market price and never more than your maximum percentage. - * For most use cases, Batch recommends leaving this field empty. - * - * @default - 100% - */ - readonly spotBidPercentage?: number; - /** - * The service-linked role that Spot Fleet needs to launch instances on your behalf. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html - * - * @default - a new Role will be created - */ - readonly spotFleetRole?: iam.IRole; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - */ - readonly instanceTypes: ec2.InstanceType[]; - /** - * The instance classes that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - * Batch will automatically choose the size. - */ - readonly instanceClasses: ec2.InstanceClass[]; - /** - * Whether or not to use batch's optimal instance type. - * The optimal instance type is equivalent to adding the - * C4, M4, and R4 instance classes. You can specify other instance classes - * (of the same architecture) in addition to the optimal instance classes. - * - * @default true - */ - readonly useOptimalInstanceClasses?: boolean; - /** - * The execution Role that instances launched by this Compute Environment will use. - * - * @default - a role will be created - */ - readonly instanceRole?: iam.IRole; - /** - * The Launch Template that this Compute Environment - * will use to provision EC2 Instances. - * - * *Note*: if `securityGroups` is specified on both your - * launch template and this Compute Environment, **the - * `securityGroup`s on the Compute Environment override the - * ones on the launch template. - * - * @default no launch template - */ - readonly launchTemplate?: ec2.ILaunchTemplate; - /** - * The minimum vCPUs that an environment should maintain, - * even if the compute environment is DISABLED. - * - * @default 0 - */ - readonly minvCpus?: number; - /** - * The EC2 placement group to associate with your compute resources. - * If you intend to submit multi-node parallel jobs to this Compute Environment, - * you should consider creating a cluster placement group and associate it with your compute resources. - * This keeps your multi-node parallel job on a logical grouping of instances - * within a single Availability Zone with high network flow potential. - * - * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html - * - * @default - no placement group - */ - readonly placementGroup?: ec2.IPlacementGroup; - /** - * Add an instance type to this compute environment - */ - addInstanceType(instanceType: ec2.InstanceType): void; - /** - * Add an instance class to this compute environment - */ - addInstanceClass(instanceClass: ec2.InstanceClass): void; -} -/** - * Base interface for containing all information needed to - * configure a MachineImage in Batch - */ -interface MachineImage { - /** - * The machine image to use - * - * @default - chosen by batch - */ - readonly image?: ec2.IMachineImage; -} -/** - * A Batch MachineImage that is compatible with ECS - */ -export interface EcsMachineImage extends MachineImage { - /** - * Tells Batch which instance type to launch this image on - * - * @default - 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances - */ - readonly imageType?: EcsMachineImageType; -} -/** - * A Batch MachineImage that is compatible with EKS - */ -export interface EksMachineImage extends MachineImage { - /** - * Tells Batch which instance type to launch this image on - * - * @default - 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances - */ - readonly imageType?: EksMachineImageType; -} -/** - * Maps the image to instance types - */ -export declare enum EcsMachineImageType { - /** - * Tells Batch that this machine image runs on non-GPU instances - */ - ECS_AL2 = "ECS_AL2", - /** - * Tells Batch that this machine image runs on GPU instances - */ - ECS_AL2_NVIDIA = "ECS_AL2_NVIDIA" -} -/** - * Maps the image to instance types - */ -export declare enum EksMachineImageType { - /** - * Tells Batch that this machine image runs on non-GPU instances - */ - EKS_AL2 = "EKS_AL2", - /** - * Tells Batch that this machine image runs on GPU instances - */ - EKS_AL2_NVIDIA = "EKS_AL2_NVIDIA" -} -/** - * Determines how this compute environment chooses instances to spawn - * - * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/ - */ -export declare enum AllocationStrategy { - /** - * Batch chooses the lowest-cost instance type that fits all the jobs in the queue. - * If instances of that type are not available, the queue will not choose a new type; - * instead, it will wait for the instance to become available. - * This can stall your `Queue`, with your compute environment only using part of its max capacity - * (or none at all) until the `BEST_FIT` instance becomes available. - * This allocation strategy keeps costs lower but can limit scaling. - * `BEST_FIT` isn't supported when updating compute environments - */ - BEST_FIT = "BEST_FIT", - /** - * This is the default Allocation Strategy if `spot` is `false` or unspecified. - * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements - * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`. - * However, if not all of the capacity can be filled with this instance type, - * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity. - * To make the most use of this allocation strategy, - * it is recommended to use as many instance classes as is feasible for your workload. - */ - BEST_FIT_PROGRESSIVE = "BEST_FIT_PROGRESSIVE", - /** - * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` - * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled). - * This will tell Batch to choose the instance types from the ones you’ve specified that have - * the most spot capacity available to minimize the chance of interruption. - * To get the most benefit from your spot instances, - * you should allow Batch to choose from as many different instance types as possible. - */ - SPOT_CAPACITY_OPTIMIZED = "SPOT_CAPACITY_OPTIMIZED", - /** - * The price and capacity optimized allocation strategy looks at both price and capacity - * to select the Spot Instance pools that are the least likely to be interrupted - * and have the lowest possible price. - * - * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances. - */ - SPOT_PRICE_CAPACITY_OPTIMIZED = "SPOT_PRICE_CAPACITY_OPTIMIZED" -} -/** - * Props for a ManagedEc2EcsComputeEnvironment - */ -export interface ManagedEc2EcsComputeEnvironmentProps extends ManagedComputeEnvironmentProps { - /** - * Whether or not to use batch's optimal instance type. - * The optimal instance type is equivalent to adding the - * C4, M4, and R4 instance classes. You can specify other instance classes - * (of the same architecture) in addition to the optimal instance classes. - * - * @default true - */ - readonly useOptimalInstanceClasses?: boolean; - /** - * Configure which AMIs this Compute Environment can launch. - * If you specify this property with only `image` specified, then the - * `imageType` will default to `ECS_AL2`. *If your image needs GPU resources, - * specify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly - * join the ComputeEnvironment*. - * - * @default - * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances - */ - readonly images?: EcsMachineImage[]; - /** - * The allocation strategy to use if not enough instances of - * the best fitting instance type can be allocated. - * - * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, - * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. - */ - readonly allocationStrategy?: AllocationStrategy; - /** - * The maximum percentage that a Spot Instance price can be when compared with the - * On-Demand price for that instance type before instances are launched. - * For example, if your maximum percentage is 20%, the Spot price must be - * less than 20% of the current On-Demand price for that Instance. - * You always pay the lowest market price and never more than your maximum percentage. - * For most use cases, Batch recommends leaving this field empty. - * - * Implies `spot == true` if set - * - * @default 100% - */ - readonly spotBidPercentage?: number; - /** - * The service-linked role that Spot Fleet needs to launch instances on your behalf. - * - * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html - * - * @default - a new role will be created - */ - readonly spotFleetRole?: iam.IRole; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - * - * @default - the instances Batch considers will be used (currently C4, M4, and R4) - */ - readonly instanceTypes?: ec2.InstanceType[]; - /** - * The instance classes that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - * Batch will automatically choose the instance size. - * - * @default - the instances Batch considers will be used (currently C4, M4, and R4) - */ - readonly instanceClasses?: ec2.InstanceClass[]; - /** - * The execution Role that instances launched by this Compute Environment will use. - * - * @default - a role will be created - */ - readonly instanceRole?: iam.IRole; - /** - * The Launch Template that this Compute Environment - * will use to provision EC2 Instances. - * - * *Note*: if `securityGroups` is specified on both your - * launch template and this Compute Environment, **the - * `securityGroup`s on the Compute Environment override the - * ones on the launch template. - * - * @default no launch template - */ - readonly launchTemplate?: ec2.ILaunchTemplate; - /** - * The minimum vCPUs that an environment should maintain, - * even if the compute environment is DISABLED. - * - * @default 0 - */ - readonly minvCpus?: number; - /** - * The EC2 placement group to associate with your compute resources. - * If you intend to submit multi-node parallel jobs to this Compute Environment, - * you should consider creating a cluster placement group and associate it with your compute resources. - * This keeps your multi-node parallel job on a logical grouping of instances - * within a single Availability Zone with high network flow potential. - * - * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html - * - * @default - no placement group - */ - readonly placementGroup?: ec2.IPlacementGroup; -} -/** - * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -export declare class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EcsComputeEnvironment { - /** - * refer to an existing ComputeEnvironment by its arn. - */ - static fromManagedEc2EcsComputeEnvironmentArn(scope: Construct, id: string, managedEc2EcsComputeEnvironmentArn: string): IManagedEc2EcsComputeEnvironment; - readonly computeEnvironmentArn: string; - readonly computeEnvironmentName: string; - readonly images?: EcsMachineImage[]; - readonly allocationStrategy?: AllocationStrategy; - readonly spotBidPercentage?: number; - readonly spotFleetRole?: iam.IRole; - readonly instanceTypes: ec2.InstanceType[]; - readonly instanceClasses: ec2.InstanceClass[]; - readonly instanceRole?: iam.IRole; - readonly launchTemplate?: ec2.ILaunchTemplate; - readonly minvCpus?: number; - readonly placementGroup?: ec2.IPlacementGroup; - private readonly instanceProfile; - constructor(scope: Construct, id: string, props: ManagedEc2EcsComputeEnvironmentProps); - addInstanceType(instanceType: ec2.InstanceType): void; - addInstanceClass(instanceClass: ec2.InstanceClass): void; -} -/** - * A ManagedComputeEnvironment that uses EKS orchestration on EC2 instances. - */ -interface IManagedEc2EksComputeEnvironment extends IManagedComputeEnvironment { - /** - * The namespace of the Cluster - * - * Cannot be 'default', start with 'kube-', or be longer than 64 characters. - * - * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ - */ - readonly kubernetesNamespace?: string; - /** - * The cluster that backs this Compute Environment. Required - * for Compute Environments running Kubernetes jobs. - * - * Please ensure that you have followed the steps at - * - * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html - * - * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster. - * If you do not follow the steps in the link, the deployment fail with a message that the - * compute environment did not stabilize. - */ - readonly eksCluster: eks.ICluster; - /** - * Configure which AMIs this Compute Environment can launch. - * - * @default - * EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances, - */ - readonly images?: EksMachineImage[]; - /** - * The allocation strategy to use if not enough instances of - * the best fitting instance type can be allocated. - * - * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, - * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. - */ - readonly allocationStrategy?: AllocationStrategy; - /** - * The maximum percentage that a Spot Instance price can be when compared with the - * On-Demand price for that instance type before instances are launched. - * For example, if your maximum percentage is 20%, the Spot price must be - * less than 20% of the current On-Demand price for that Instance. - * You always pay the lowest market price and never more than your maximum percentage. - * For most use cases, Batch recommends leaving this field empty. - * - * Implies `spot == true` if set - * - * @default - 100% - */ - readonly spotBidPercentage?: number; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - */ - readonly instanceTypes: ec2.InstanceType[]; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - */ - readonly instanceClasses: ec2.InstanceClass[]; - /** - * The execution Role that instances launched by this Compute Environment will use. - * - * @default - a role will be created - */ - readonly instanceRole?: iam.IRole; - /** - * The Launch Template that this Compute Environment - * will use to provision EC2 Instances. - * - * *Note*: if `securityGroups` is specified on both your - * launch template and this Compute Environment, **the - * `securityGroup`s on the Compute Environment override the - * ones on the launch template. - * - * @default - no launch template - */ - readonly launchTemplate?: ec2.ILaunchTemplate; - /** - * The minimum vCPUs that an environment should maintain, - * even if the compute environment is DISABLED. - * - * @default 0 - */ - readonly minvCpus?: number; - /** - * The EC2 placement group to associate with your compute resources. - * If you intend to submit multi-node parallel jobs to this Compute Environment, - * you should consider creating a cluster placement group and associate it with your compute resources. - * This keeps your multi-node parallel job on a logical grouping of instances - * within a single Availability Zone with high network flow potential. - * - * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html - * - * @default - no placement group - */ - readonly placementGroup?: ec2.IPlacementGroup; - /** - * Add an instance type to this compute environment - */ - addInstanceType(instanceType: ec2.InstanceType): void; - /** - * Add an instance class to this compute environment - */ - addInstanceClass(instanceClass: ec2.InstanceClass): void; -} -/** - * Props for a ManagedEc2EksComputeEnvironment - */ -export interface ManagedEc2EksComputeEnvironmentProps extends ManagedComputeEnvironmentProps { - /** - * The namespace of the Cluster - */ - readonly kubernetesNamespace: string; - /** - * The cluster that backs this Compute Environment. Required - * for Compute Environments running Kubernetes jobs. - * - * Please ensure that you have followed the steps at - * - * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html - * - * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster. - * If you do not follow the steps in the link, the deployment fail with a message that the - * compute environment did not stabilize. - */ - readonly eksCluster: eks.ICluster; - /** - * Whether or not to use batch's optimal instance type. - * The optimal instance type is equivalent to adding the - * C4, M4, and R4 instance classes. You can specify other instance classes - * (of the same architecture) in addition to the optimal instance classes. - * - * @default true - */ - readonly useOptimalInstanceClasses?: boolean; - /** - * Configure which AMIs this Compute Environment can launch. - * - * @default - * If `imageKubernetesVersion` is specified, - * - EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances, - * Otherwise, - * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances, - */ - readonly images?: EksMachineImage[]; - /** - * The allocation strategy to use if not enough instances of - * the best fitting instance type can be allocated. - * - * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances, - * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances. - */ - readonly allocationStrategy?: AllocationStrategy; - /** - * The maximum percentage that a Spot Instance price can be when compared with the - * On-Demand price for that instance type before instances are launched. - * For example, if your maximum percentage is 20%, the Spot price must be - * less than 20% of the current On-Demand price for that Instance. - * You always pay the lowest market price and never more than your maximum percentage. - * For most use cases, Batch recommends leaving this field empty. - * - * Implies `spot == true` if set - * - * @default - 100% - */ - readonly spotBidPercentage?: number; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - * - * @default - the instances Batch considers will be used (currently C4, M4, and R4) - */ - readonly instanceTypes?: ec2.InstanceType[]; - /** - * The instance types that this Compute Environment can launch. - * Which one is chosen depends on the `AllocationStrategy` used. - * Batch will automatically choose the instance size. - * - * @default - the instances Batch considers will be used (currently C4, M4, and R4) - */ - readonly instanceClasses?: ec2.InstanceClass[]; - /** - * The execution Role that instances launched by this Compute Environment will use. - * - * @default - a role will be created - */ - readonly instanceRole?: iam.IRole; - /** - * The Launch Template that this Compute Environment - * will use to provision EC2 Instances. - * - * *Note*: if `securityGroups` is specified on both your - * launch template and this Compute Environment, **the - * `securityGroup`s on the Compute Environment override the - * ones on the launch template.** - * - * @default - no launch template - */ - readonly launchTemplate?: ec2.ILaunchTemplate; - /** - * The minimum vCPUs that an environment should maintain, - * even if the compute environment is DISABLED. - * - * @default 0 - */ - readonly minvCpus?: number; - /** - * The EC2 placement group to associate with your compute resources. - * If you intend to submit multi-node parallel jobs to this Compute Environment, - * you should consider creating a cluster placement group and associate it with your compute resources. - * This keeps your multi-node parallel job on a logical grouping of instances - * within a single Availability Zone with high network flow potential. - * - * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html - * - * @default - no placement group - */ - readonly placementGroup?: ec2.IPlacementGroup; -} -/** - * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -export declare class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EksComputeEnvironment { - readonly kubernetesNamespace?: string; - readonly eksCluster: eks.ICluster; - readonly computeEnvironmentName: string; - readonly computeEnvironmentArn: string; - readonly images?: EksMachineImage[]; - readonly allocationStrategy?: AllocationStrategy; - readonly spotBidPercentage?: number; - readonly instanceTypes: ec2.InstanceType[]; - readonly instanceClasses: ec2.InstanceClass[]; - readonly instanceRole?: iam.IRole; - readonly launchTemplate?: ec2.ILaunchTemplate; - readonly minvCpus?: number; - readonly placementGroup?: ec2.IPlacementGroup; - private readonly instanceProfile; - constructor(scope: Construct, id: string, props: ManagedEc2EksComputeEnvironmentProps); - addInstanceType(instanceType: ec2.InstanceType): void; - addInstanceClass(instanceClass: ec2.InstanceClass): void; -} -/** - * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. - */ -export interface IFargateComputeEnvironment extends IManagedComputeEnvironment { -} -/** - * Props for a FargateComputeEnvironment - */ -export interface FargateComputeEnvironmentProps extends ManagedComputeEnvironmentProps { -} -/** - * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -export declare class FargateComputeEnvironment extends ManagedComputeEnvironmentBase implements IFargateComputeEnvironment { - /** - * Reference an existing FargateComputeEnvironment by its arn - */ - static fromFargateComputeEnvironmentArn(scope: Construct, id: string, fargateComputeEnvironmentArn: string): IFargateComputeEnvironment; - readonly computeEnvironmentName: string; - readonly computeEnvironmentArn: string; - constructor(scope: Construct, id: string, props: FargateComputeEnvironmentProps); -} -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js deleted file mode 100644 index 378fcc005e21b..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/managed-compute-environment.js +++ /dev/null @@ -1,451 +0,0 @@ -"use strict"; -var _a, _b, _c; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.FargateComputeEnvironment = exports.ManagedEc2EksComputeEnvironment = exports.ManagedEc2EcsComputeEnvironment = exports.AllocationStrategy = exports.EksMachineImageType = exports.EcsMachineImageType = exports.ManagedComputeEnvironmentBase = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const iam = require("aws-cdk-lib/aws-iam"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -const compute_environment_base_1 = require("./compute-environment-base"); -/** - * Abstract base class for ManagedComputeEnvironments - * @internal - */ -class ManagedComputeEnvironmentBase extends compute_environment_base_1.ComputeEnvironmentBase { - constructor(scope, id, props) { - super(scope, id, props); - this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); - this.maxvCpus = props.maxvCpus ?? DEFAULT_MAX_VCPUS; - this.replaceComputeEnvironment = props.replaceComputeEnvironment ?? false; - this.spot = props.spot; - this.updateTimeout = props.updateTimeout; - this.terminateOnUpdate = props.terminateOnUpdate; - this.updateToLatestImageVersion = props.updateToLatestImageVersion ?? true; - this.securityGroups = props.securityGroups ?? [ - new ec2.SecurityGroup(this, 'SecurityGroup', { - vpc: props.vpc, - }), - ]; - this.connections = new ec2.Connections({ - securityGroups: this.securityGroups, - }); - } -} -exports.ManagedComputeEnvironmentBase = ManagedComputeEnvironmentBase; -/** - * Maps the image to instance types - */ -var EcsMachineImageType; -(function (EcsMachineImageType) { - /** - * Tells Batch that this machine image runs on non-GPU instances - */ - EcsMachineImageType["ECS_AL2"] = "ECS_AL2"; - /** - * Tells Batch that this machine image runs on GPU instances - */ - EcsMachineImageType["ECS_AL2_NVIDIA"] = "ECS_AL2_NVIDIA"; -})(EcsMachineImageType || (exports.EcsMachineImageType = EcsMachineImageType = {})); -/** - * Maps the image to instance types - */ -var EksMachineImageType; -(function (EksMachineImageType) { - /** - * Tells Batch that this machine image runs on non-GPU instances - */ - EksMachineImageType["EKS_AL2"] = "EKS_AL2"; - /** - * Tells Batch that this machine image runs on GPU instances - */ - EksMachineImageType["EKS_AL2_NVIDIA"] = "EKS_AL2_NVIDIA"; -})(EksMachineImageType || (exports.EksMachineImageType = EksMachineImageType = {})); -/** - * Determines how this compute environment chooses instances to spawn - * - * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/ - */ -var AllocationStrategy; -(function (AllocationStrategy) { - /** - * Batch chooses the lowest-cost instance type that fits all the jobs in the queue. - * If instances of that type are not available, the queue will not choose a new type; - * instead, it will wait for the instance to become available. - * This can stall your `Queue`, with your compute environment only using part of its max capacity - * (or none at all) until the `BEST_FIT` instance becomes available. - * This allocation strategy keeps costs lower but can limit scaling. - * `BEST_FIT` isn't supported when updating compute environments - */ - AllocationStrategy["BEST_FIT"] = "BEST_FIT"; - /** - * This is the default Allocation Strategy if `spot` is `false` or unspecified. - * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements - * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`. - * However, if not all of the capacity can be filled with this instance type, - * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity. - * To make the most use of this allocation strategy, - * it is recommended to use as many instance classes as is feasible for your workload. - */ - AllocationStrategy["BEST_FIT_PROGRESSIVE"] = "BEST_FIT_PROGRESSIVE"; - /** - * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment` - * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled). - * This will tell Batch to choose the instance types from the ones you’ve specified that have - * the most spot capacity available to minimize the chance of interruption. - * To get the most benefit from your spot instances, - * you should allow Batch to choose from as many different instance types as possible. - */ - AllocationStrategy["SPOT_CAPACITY_OPTIMIZED"] = "SPOT_CAPACITY_OPTIMIZED"; - /** - * The price and capacity optimized allocation strategy looks at both price and capacity - * to select the Spot Instance pools that are the least likely to be interrupted - * and have the lowest possible price. - * - * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances. - */ - AllocationStrategy["SPOT_PRICE_CAPACITY_OPTIMIZED"] = "SPOT_PRICE_CAPACITY_OPTIMIZED"; -})(AllocationStrategy || (exports.AllocationStrategy = AllocationStrategy = {})); -/** - * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase { - /** - * refer to an existing ComputeEnvironment by its arn. - */ - static fromManagedEc2EcsComputeEnvironmentArn(scope, id, managedEc2EcsComputeEnvironmentArn) { - const stack = core_1.Stack.of(scope); - const computeEnvironmentName = stack.splitArn(managedEc2EcsComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - class Import extends core_1.Resource { - constructor() { - super(...arguments); - this.computeEnvironmentArn = managedEc2EcsComputeEnvironmentArn; - this.computeEnvironmentName = computeEnvironmentName; - this.enabled = true; - this.instanceClasses = []; - this.instanceTypes = []; - this.maxvCpus = 1; - this.connections = {}; - this.securityGroups = []; - this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); - } - addInstanceClass(_instanceClass) { - throw new Error(`cannot add instance class to imported ComputeEnvironment '${id}'`); - } - addInstanceType(_instanceType) { - throw new Error(`cannot add instance type to imported ComputeEnvironment '${id}'`); - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_ManagedEc2EcsComputeEnvironmentProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, ManagedEc2EcsComputeEnvironment); - } - throw error; - } - this.images = props.images; - this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot); - this.spotBidPercentage = props.spotBidPercentage; - this.spotFleetRole = props.spotFleetRole ?? (this.spot && this.allocationStrategy === AllocationStrategy.BEST_FIT - ? createSpotFleetRole(this) - : undefined); - this.instanceTypes = props.instanceTypes ?? []; - this.instanceClasses = props.instanceClasses ?? []; - const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole); - this.instanceRole = instanceRole; - this.instanceProfile = instanceProfile; - this.launchTemplate = props.launchTemplate; - this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS; - this.placementGroup = props.placementGroup; - validateVCpus(id, this.minvCpus, this.maxvCpus); - validateSpotConfig(id, this.spot, this.spotBidPercentage, this.spotFleetRole); - const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); - const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { - ...baseManagedResourceProperties(this, subnetIds), - computeEnvironmentName: props.computeEnvironmentName, - computeResources: { - ...baseManagedResourceProperties(this, subnetIds).computeResources, - minvCpus: this.minvCpus, - instanceRole: this.instanceProfile.attrArn, - instanceTypes: core_1.Lazy.list({ - produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses), - }), - type: this.spot ? 'SPOT' : 'EC2', - spotIamFleetRole: this.spotFleetRole?.roleArn, - allocationStrategy: this.allocationStrategy, - bidPercentage: this.spotBidPercentage, - launchTemplate: this.launchTemplate ? { - launchTemplateId: this.launchTemplate?.launchTemplateId, - } : undefined, - ec2Configuration: this.images?.map((image) => { - return { - imageIdOverride: image.image?.getImage(this).imageId, - imageType: image.imageType ?? EcsMachineImageType.ECS_AL2, - }; - }), - placementGroup: this.placementGroup?.placementGroupName, - tags: this.tags.renderedTags, - }, - }); - this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); - this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { - service: 'batch', - resource: 'compute-environment', - resourceName: this.physicalName, - }); - this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }); - } - addInstanceType(instanceType) { - this.instanceTypes.push(instanceType); - } - addInstanceClass(instanceClass) { - this.instanceClasses.push(instanceClass); - } -} -exports.ManagedEc2EcsComputeEnvironment = ManagedEc2EcsComputeEnvironment; -_a = JSII_RTTI_SYMBOL_1; -ManagedEc2EcsComputeEnvironment[_a] = { fqn: "@aws-cdk/aws-batch-alpha.ManagedEc2EcsComputeEnvironment", version: "0.0.0" }; -/** - * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase { - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_ManagedEc2EksComputeEnvironmentProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, ManagedEc2EksComputeEnvironment); - } - throw error; - } - this.kubernetesNamespace = props.kubernetesNamespace; - this.eksCluster = props.eksCluster; - this.images = props.images; - this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot); - if (this.allocationStrategy === AllocationStrategy.BEST_FIT) { - throw new Error(`ManagedEc2EksComputeEnvironment '${id}' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'`); - } - this.spotBidPercentage = props.spotBidPercentage; - this.instanceTypes = props.instanceTypes ?? []; - this.instanceClasses = props.instanceClasses ?? []; - const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole); - this.instanceRole = instanceRole; - this.instanceProfile = instanceProfile; - this.launchTemplate = props.launchTemplate; - this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS; - this.placementGroup = props.placementGroup; - validateVCpus(id, this.minvCpus, this.maxvCpus); - validateSpotConfig(id, this.spot, this.spotBidPercentage); - const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); - const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { - ...baseManagedResourceProperties(this, subnetIds), - computeEnvironmentName: props.computeEnvironmentName, - eksConfiguration: { - eksClusterArn: this.eksCluster.clusterArn, - kubernetesNamespace: this.kubernetesNamespace, - }, - computeResources: { - ...baseManagedResourceProperties(this, subnetIds).computeResources, - minvCpus: this.minvCpus, - instanceRole: this.instanceProfile.attrArn, - instanceTypes: core_1.Lazy.list({ produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }), - type: this.spot ? 'SPOT' : 'EC2', - allocationStrategy: this.allocationStrategy, - bidPercentage: this.spotBidPercentage, - launchTemplate: this.launchTemplate ? { - launchTemplateId: this.launchTemplate?.launchTemplateId, - } : undefined, - ec2Configuration: this.images?.map((image) => { - return { - imageIdOverride: image.image?.getImage(this).imageId, - imageType: image.imageType ?? EksMachineImageType.EKS_AL2, - }; - }), - placementGroup: this.placementGroup?.placementGroupName, - tags: this.tags.renderedTags, - }, - }); - this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); - this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { - service: 'batch', - resource: 'compute-environment', - resourceName: this.physicalName, - }); - this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }); - } - addInstanceType(instanceType) { - this.instanceTypes.push(instanceType); - } - addInstanceClass(instanceClass) { - this.instanceClasses.push(instanceClass); - } -} -exports.ManagedEc2EksComputeEnvironment = ManagedEc2EksComputeEnvironment; -_b = JSII_RTTI_SYMBOL_1; -ManagedEc2EksComputeEnvironment[_b] = { fqn: "@aws-cdk/aws-batch-alpha.ManagedEc2EksComputeEnvironment", version: "0.0.0" }; -/** - * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances. - * - * @resource AWS::Batch::ComputeEnvironment - */ -class FargateComputeEnvironment extends ManagedComputeEnvironmentBase { - /** - * Reference an existing FargateComputeEnvironment by its arn - */ - static fromFargateComputeEnvironmentArn(scope, id, fargateComputeEnvironmentArn) { - const stack = core_1.Stack.of(scope); - const computeEnvironmentName = stack.splitArn(fargateComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - class Import extends core_1.Resource { - constructor() { - super(...arguments); - this.computeEnvironmentArn = fargateComputeEnvironmentArn; - this.computeEnvironmentName = computeEnvironmentName; - this.enabled = true; - this.maxvCpus = 1; - this.connections = {}; - this.securityGroups = []; - this.tags = new core_1.TagManager(core_1.TagType.MAP, 'AWS::Batch::ComputeEnvironment'); - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_FargateComputeEnvironmentProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, FargateComputeEnvironment); - } - throw error; - } - const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); - const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { - ...baseManagedResourceProperties(this, subnetIds), - computeEnvironmentName: props.computeEnvironmentName, - computeResources: { - ...baseManagedResourceProperties(this, subnetIds).computeResources, - type: this.spot ? 'FARGATE_SPOT' : 'FARGATE', - }, - }); - this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); - this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { - service: 'batch', - resource: 'compute-environment', - resourceName: this.physicalName, - }); - } -} -exports.FargateComputeEnvironment = FargateComputeEnvironment; -_c = JSII_RTTI_SYMBOL_1; -FargateComputeEnvironment[_c] = { fqn: "@aws-cdk/aws-batch-alpha.FargateComputeEnvironment", version: "0.0.0" }; -function renderInstances(types, classes, useOptimalInstanceClasses) { - const instances = []; - for (const instanceType of types ?? []) { - instances.push(instanceType.toString()); - } - for (const instanceClass of classes ?? []) { - instances.push(instanceClass); - } - if (useOptimalInstanceClasses || useOptimalInstanceClasses === undefined) { - instances.push('optimal'); - } - return instances; -} -function createInstanceRoleAndProfile(scope, instanceRole) { - const result = {}; - result.instanceRole = instanceRole ?? new iam.Role(scope, 'InstanceProfileRole', { - assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'), - managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonEC2ContainerServiceforEC2Role')], - }); - result.instanceProfile = new iam.CfnInstanceProfile(scope, 'InstanceProfile', { - roles: [result.instanceRole.roleName], - }); - return result; -} -function createSpotFleetRole(scope) { - return new iam.Role(scope, 'SpotFleetRole', { - assumedBy: new iam.ServicePrincipal('spotfleet.amazonaws.com'), - }); -} -function determineAllocationStrategy(id, allocationStrategy, spot) { - let result = allocationStrategy; - if (!allocationStrategy) { - result = spot ? AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED : AllocationStrategy.BEST_FIT_PROGRESSIVE; - } - else if (allocationStrategy === AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED && !spot) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances`); - } - else if (allocationStrategy === AllocationStrategy.SPOT_CAPACITY_OPTIMIZED && !spot) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances`); - } - return result; -} -function validateInstances(types, classes, useOptimalInstanceClasses) { - if (renderInstances(types, classes, useOptimalInstanceClasses).length === 0) { - return ["Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes"]; - } - return []; -} -function validateSpotConfig(id, spot, spotBidPercentage, spotFleetRole) { - if (spotBidPercentage) { - if (!spot) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' without specifying 'spot'`); - } - else if (spotBidPercentage > 100) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' > 100`); - } - else if (spotBidPercentage < 0) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' < 0`); - } - } - if (spotFleetRole) { - if (!spot) { - throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotFleetRole' without specifying 'spot'`); - } - } -} -function validateVCpus(id, minvCpus, maxvCpus) { - if (minvCpus < 0) { - throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} < 0; 'minvCpus' cannot be less than zero`); - } - if (minvCpus > maxvCpus) { - throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} > 'maxvCpus' = ${maxvCpus}; 'minvCpus' cannot be greater than 'maxvCpus'`); - } -} -function baseManagedResourceProperties(baseComputeEnvironment, subnetIds) { - return { - serviceRole: baseComputeEnvironment.serviceRole?.roleArn, - state: baseComputeEnvironment.enabled ? 'ENABLED' : 'DISABLED', - computeResources: { - maxvCpus: baseComputeEnvironment.maxvCpus, - type: 'managed', - updateToLatestImageVersion: baseComputeEnvironment.updateToLatestImageVersion, - securityGroupIds: baseComputeEnvironment.securityGroups.map((securityGroup) => securityGroup.securityGroupId), - subnets: subnetIds, - }, - updatePolicy: { - terminateJobsOnUpdate: baseComputeEnvironment.terminateOnUpdate, - jobExecutionTimeoutMinutes: baseComputeEnvironment.updateTimeout?.toMinutes(), - }, - replaceComputeEnvironment: baseComputeEnvironment.replaceComputeEnvironment, - type: 'managed', - }; -} -const DEFAULT_MIN_VCPUS = 0; -const DEFAULT_MAX_VCPUS = 256; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-compute-environment.js","sourceRoot":"","sources":["managed-compute-environment.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as eks from 'aws-cdk-lib/aws-eks';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\nimport { ArnFormat, Duration, ITaggable, Lazy, Resource, Stack, TagManager, TagType } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnComputeEnvironment } from 'aws-cdk-lib/aws-batch';\nimport { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base';\n\n/**\n * Represents a Managed ComputeEnvironment. Batch will provision EC2 Instances to\n * meet the requirements of the jobs executing in this ComputeEnvironment.\n */\nexport interface IManagedComputeEnvironment extends IComputeEnvironment, ec2.IConnectable, ITaggable {\n  /**\n   * The maximum vCpus this `ManagedComputeEnvironment` can scale up to.\n   *\n   * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n   * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\n   * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\n   * or `instanceClasses`.\n   */\n  readonly maxvCpus: number;\n\n  /**\n   * Specifies whether this Compute Environment is replaced if an update is made that requires\n   * replacing its instances. To enable more properties to be updated,\n   * set this property to `false`. When changing the value of this property to false,\n   * do not change any other properties at the same time.\n   * If other properties are changed at the same time,\n   * and the change needs to be rolled back but it can't,\n   * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\n   * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\n   * However, if you can continue to roll it back,\n   * you can return the stack to its original settings and then try to update it again.\n   *\n   * The properties which require a replacement of the Compute Environment are:\n   *\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html\n   */\n  readonly replaceComputeEnvironment?: boolean;\n\n  /**\n   * Whether or not to use spot instances.\n   * Spot instances are less expensive EC2 instances that can be\n   * reclaimed by EC2 at any time; your job will be given two minutes\n   * of notice before reclamation.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Only meaningful if `terminateOnUpdate` is `false`. If so,\n   * when an infrastructure update is triggered, any running jobs\n   * will be allowed to run until `updateTimeout` has expired.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   * @default 30 minutes\n   */\n  readonly updateTimeout?: Duration;\n\n  /**\n   * Whether or not any running jobs will be immediately terminated when an infrastructure update\n   * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's\n   * retry policy.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default false\n   */\n  readonly terminateOnUpdate?: boolean;\n\n  /**\n   * The security groups this Compute Environment will launch instances in.\n   */\n  readonly securityGroups: ec2.ISecurityGroup[];\n\n  /**\n   * The VPC Subnets this Compute Environment will launch instances in.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * Whether or not the AMI is updated to the latest one supported by Batch\n   * when an infrastructure update occurs.\n   *\n   * If you specify a specific AMI, this property will be ignored.\n   *\n   * @default true\n   */\n  readonly updateToLatestImageVersion?: boolean;\n}\n\n/**\n * Props for a ManagedComputeEnvironment\n */\nexport interface ManagedComputeEnvironmentProps extends ComputeEnvironmentProps {\n  /**\n  * The maximum vCpus this `ManagedComputeEnvironment` can scale up to.\n  * Each vCPU is equivalent to 1024 CPU shares.\n  *\n  * *Note*: if this Compute Environment uses EC2 resources (not Fargate) with either `AllocationStrategy.BEST_FIT_PROGRESSIVE` or\n  * `AllocationStrategy.SPOT_CAPACITY_OPTIMIZED`, or `AllocationStrategy.BEST_FIT` with Spot instances,\n  * The scheduler may exceed this number by at most one of the instances specified in `instanceTypes`\n  * or `instanceClasses`.\n  *\n  * @default 256\n  */\n  readonly maxvCpus?: number;\n\n  /**\n  * Specifies whether this Compute Environment is replaced if an update is made that requires\n  * replacing its instances. To enable more properties to be updated,\n  * set this property to `false`. When changing the value of this property to false,\n  * do not change any other properties at the same time.\n  * If other properties are changed at the same time,\n  * and the change needs to be rolled back but it can't,\n  * it's possible for the stack to go into the UPDATE_ROLLBACK_FAILED state.\n  * You can't update a stack that is in the UPDATE_ROLLBACK_FAILED state.\n  * However, if you can continue to roll it back,\n  * you can return the stack to its original settings and then try to update it again.\n  *\n  * The properties which require a replacement of the Compute Environment are:\n  *\n  * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-batch-computeenvironment.html#cfn-batch-computeenvironment-replacecomputeenvironment\n  * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-cfn-updating-stacks-continueupdaterollback.html\n  *\n  * @default false\n  */\n  readonly replaceComputeEnvironment?: boolean;\n\n  /**\n   * Whether or not to use spot instances.\n   * Spot instances are less expensive EC2 instances that can be\n   * reclaimed by EC2 at any time; your job will be given two minutes\n   * of notice before reclamation.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Only meaningful if `terminateOnUpdate` is `false`. If so,\n   * when an infrastructure update is triggered, any running jobs\n   * will be allowed to run until `updateTimeout` has expired.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default 30 minutes\n   */\n  readonly updateTimeout?: Duration;\n\n  /**\n   * Whether or not any running jobs will be immediately terminated when an infrastructure update\n   * occurs. If this is enabled, any terminated jobs may be retried, depending on the job's\n   * retry policy.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/updating-compute-environments.html\n   *\n   * @default false\n   */\n  readonly terminateOnUpdate?: boolean;\n\n  /**\n   * VPC in which this Compute Environment will launch Instances\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n  * The security groups this Compute Environment will launch instances in.\n  *\n  * @default new security groups will be created\n  */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n  * The VPC Subnets this Compute Environment will launch instances in.\n  *\n  * @default new subnets will be created\n  */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n  * Whether or not the AMI is updated to the latest one supported by Batch\n  * when an infrastructure update occurs.\n  *\n  * If you specify a specific AMI, this property will be ignored.\n  *\n  * @default true\n  */\n  readonly updateToLatestImageVersion?: boolean;\n}\n\n/**\n * Abstract base class for ManagedComputeEnvironments\n * @internal\n */\nexport abstract class ManagedComputeEnvironmentBase extends ComputeEnvironmentBase implements IManagedComputeEnvironment {\n  public readonly maxvCpus: number;\n  public readonly replaceComputeEnvironment?: boolean;\n  public readonly spot?: boolean;\n  public readonly updateTimeout?: Duration;\n  public readonly terminateOnUpdate?: boolean;\n  public readonly securityGroups: ec2.ISecurityGroup[];\n  public readonly updateToLatestImageVersion?: boolean;\n  public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n\n  public readonly connections: ec2.Connections;\n\n  constructor(scope: Construct, id: string, props: ManagedComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.maxvCpus = props.maxvCpus ?? DEFAULT_MAX_VCPUS;\n    this.replaceComputeEnvironment = props.replaceComputeEnvironment ?? false;\n    this.spot = props.spot;\n    this.updateTimeout = props.updateTimeout;\n    this.terminateOnUpdate = props.terminateOnUpdate;\n    this.updateToLatestImageVersion = props.updateToLatestImageVersion ?? true;\n    this.securityGroups = props.securityGroups ?? [\n      new ec2.SecurityGroup(this, 'SecurityGroup', {\n        vpc: props.vpc,\n      }),\n    ];\n    this.connections = new ec2.Connections({\n      securityGroups: this.securityGroups,\n    });\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n */\nexport interface IManagedEc2EcsComputeEnvironment extends IManagedComputeEnvironment {\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * Leave this `undefined` to allow Batch to choose the latest AMIs it supports for each instance that it launches.\n   *\n   * @default\n   * - ECS_AL2 compatible AMI ids for non-GPU instances, ECS_AL2_NVIDIA compatible AMI ids for GPU instances\n   */\n  readonly images?: EcsMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The service-linked role that Spot Fleet needs to launch instances on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html\n   *\n   * @default - a new Role will be created\n   */\n  readonly spotFleetRole?: iam.IRole;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceTypes: ec2.InstanceType[];\n\n  /**\n   * The instance classes that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the size.\n   */\n  readonly instanceClasses: ec2.InstanceClass[];\n\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n\n  /**\n   * Add an instance type to this compute environment\n   */\n  addInstanceType(instanceType: ec2.InstanceType): void;\n\n  /**\n   * Add an instance class to this compute environment\n   */\n  addInstanceClass(instanceClass: ec2.InstanceClass): void;\n}\n\n/**\n * Base interface for containing all information needed to\n * configure a MachineImage in Batch\n */\ninterface MachineImage {\n  /**\n   * The machine image to use\n   *\n   * @default - chosen by batch\n   */\n  readonly image?: ec2.IMachineImage;\n}\n\n/**\n * A Batch MachineImage that is compatible with ECS\n */\nexport interface EcsMachineImage extends MachineImage {\n  /**\n   * Tells Batch which instance type to launch this image on\n   *\n   * @default - 'ECS_AL2' for non-gpu instances, 'ECS_AL2_NVIDIA' for gpu instances\n   */\n  readonly imageType?: EcsMachineImageType;\n}\n\n/**\n * A Batch MachineImage that is compatible with EKS\n */\nexport interface EksMachineImage extends MachineImage{\n  /**\n   * Tells Batch which instance type to launch this image on\n   *\n   * @default - 'EKS_AL2' for non-gpu instances, 'EKS_AL2_NVIDIA' for gpu instances\n   */\n  readonly imageType?: EksMachineImageType;\n}\n\n/**\n * Maps the image to instance types\n */\nexport enum EcsMachineImageType {\n  /**\n   * Tells Batch that this machine image runs on non-GPU instances\n   */\n  ECS_AL2 = 'ECS_AL2',\n\n  /**\n   * Tells Batch that this machine image runs on GPU instances\n   */\n  ECS_AL2_NVIDIA = 'ECS_AL2_NVIDIA',\n}\n\n/**\n * Maps the image to instance types\n */\nexport enum EksMachineImageType {\n  /**\n   * Tells Batch that this machine image runs on non-GPU instances\n   */\n  EKS_AL2 = 'EKS_AL2',\n\n  /**\n   * Tells Batch that this machine image runs on GPU instances\n   */\n  EKS_AL2_NVIDIA = 'EKS_AL2_NVIDIA',\n}\n\n/**\n * Determines how this compute environment chooses instances to spawn\n *\n * @see https://aws.amazon.com/blogs/compute/optimizing-for-cost-availability-and-throughput-by-selecting-your-aws-batch-allocation-strategy/\n */\nexport enum AllocationStrategy {\n  /**\n   * Batch chooses the lowest-cost instance type that fits all the jobs in the queue.\n   * If instances of that type are not available, the queue will not choose a new type;\n   * instead, it will wait for the instance to become available.\n   * This can stall your `Queue`, with your compute environment only using part of its max capacity\n   * (or none at all) until the `BEST_FIT` instance becomes available.\n   * This allocation strategy keeps costs lower but can limit scaling.\n   * `BEST_FIT` isn't supported when updating compute environments\n   */\n  BEST_FIT = 'BEST_FIT',\n\n  /**\n   * This is the default Allocation Strategy if `spot` is `false` or unspecified.\n   * This strategy will examine the Jobs in the queue and choose whichever instance type meets the requirements\n   * of the jobs in the queue and with the lowest cost per vCPU, just as `BEST_FIT`.\n   * However, if not all of the capacity can be filled with this instance type,\n   * it will choose a new next-best instance type to run any jobs that couldn’t fit into the `BEST_FIT` capacity.\n   * To make the most use of this allocation strategy,\n   * it is recommended to use as many instance classes as is feasible for your workload.\n   */\n  BEST_FIT_PROGRESSIVE = 'BEST_FIT_PROGRESSIVE',\n\n  /**\n   * If your workflow tolerates interruptions, you should enable `spot` on your `ComputeEnvironment`\n   * and use `SPOT_CAPACITY_OPTIMIZED` (this is the default if `spot` is enabled).\n   * This will tell Batch to choose the instance types from the ones you’ve specified that have\n   * the most spot capacity available to minimize the chance of interruption.\n   * To get the most benefit from your spot instances,\n   * you should allow Batch to choose from as many different instance types as possible.\n   */\n  SPOT_CAPACITY_OPTIMIZED = 'SPOT_CAPACITY_OPTIMIZED',\n\n  /**\n   * The price and capacity optimized allocation strategy looks at both price and capacity\n   * to select the Spot Instance pools that are the least likely to be interrupted\n   * and have the lowest possible price.\n   *\n   * The Batch team recommends this over `SPOT_CAPACITY_OPTIMIZED` in most instances.\n   */\n  SPOT_PRICE_CAPACITY_OPTIMIZED = 'SPOT_PRICE_CAPACITY_OPTIMIZED',\n}\n\n/**\n * Props for a ManagedEc2EcsComputeEnvironment\n */\nexport interface ManagedEc2EcsComputeEnvironmentProps extends ManagedComputeEnvironmentProps {\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   * If you specify this property with only `image` specified, then the\n   * `imageType` will default to `ECS_AL2`. *If your image needs GPU resources,\n   * specify `ECS_AL2_NVIDIA`; otherwise, the instances will not be able to properly\n   * join the ComputeEnvironment*.\n   *\n   * @default\n   * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances\n   */\n  readonly images?: EcsMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The service-linked role that Spot Fleet needs to launch instances on your behalf.\n   *\n   * @see https://docs.aws.amazon.com/batch/latest/userguide/spot_fleet_IAM_role.html\n   *\n   * @default - a new role will be created\n   */\n  readonly spotFleetRole?: iam.IRole;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceTypes?: ec2.InstanceType[];\n\n  /**\n   * The instance classes that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the instance size.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceClasses?: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class ManagedEc2EcsComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EcsComputeEnvironment {\n  /**\n   * refer to an existing ComputeEnvironment by its arn.\n   */\n  public static fromManagedEc2EcsComputeEnvironmentArn(\n    scope: Construct, id: string, managedEc2EcsComputeEnvironmentArn: string,\n  ): IManagedEc2EcsComputeEnvironment {\n    const stack = Stack.of(scope);\n    const computeEnvironmentName = stack.splitArn(managedEc2EcsComputeEnvironmentArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends Resource implements IManagedEc2EcsComputeEnvironment {\n      public readonly computeEnvironmentArn = managedEc2EcsComputeEnvironmentArn;\n      public readonly computeEnvironmentName = computeEnvironmentName;\n      public readonly enabled = true;\n      public readonly instanceClasses = [];\n      public readonly instanceTypes = [];\n      public readonly maxvCpus = 1;\n      public readonly connections = { } as any;\n      public readonly securityGroups = [];\n      public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n\n      public addInstanceClass(_instanceClass: ec2.InstanceClass): void {\n        throw new Error(`cannot add instance class to imported ComputeEnvironment '${id}'`);\n      }\n      public addInstanceType(_instanceType: ec2.InstanceType): void {\n        throw new Error(`cannot add instance type to imported ComputeEnvironment '${id}'`);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n  public readonly computeEnvironmentArn: string;\n  public readonly computeEnvironmentName: string;\n\n  public readonly images?: EcsMachineImage[];\n  public readonly allocationStrategy?: AllocationStrategy;\n  public readonly spotBidPercentage?: number;\n  public readonly spotFleetRole?: iam.IRole;\n  public readonly instanceTypes: ec2.InstanceType[];\n  public readonly instanceClasses: ec2.InstanceClass[];\n  public readonly instanceRole?: iam.IRole;\n  public readonly launchTemplate?: ec2.ILaunchTemplate;\n  public readonly minvCpus?: number;\n  public readonly placementGroup?: ec2.IPlacementGroup;\n\n  private readonly instanceProfile: iam.CfnInstanceProfile;\n\n  constructor(scope: Construct, id: string, props: ManagedEc2EcsComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.images = props.images;\n    this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot);\n    this.spotBidPercentage = props.spotBidPercentage;\n\n    this.spotFleetRole = props.spotFleetRole ?? (\n      this.spot && this.allocationStrategy === AllocationStrategy.BEST_FIT\n        ? createSpotFleetRole(this)\n        : undefined\n    );\n\n    this.instanceTypes = props.instanceTypes ?? [];\n    this.instanceClasses = props.instanceClasses ?? [];\n\n    const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole);\n    this.instanceRole = instanceRole;\n    this.instanceProfile = instanceProfile;\n\n    this.launchTemplate = props.launchTemplate;\n    this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS;\n    this.placementGroup = props.placementGroup;\n\n    validateVCpus(id, this.minvCpus, this.maxvCpus);\n    validateSpotConfig(id, this.spot, this.spotBidPercentage, this.spotFleetRole);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        minvCpus: this.minvCpus,\n        instanceRole: this.instanceProfile.attrArn, // this is not a typo; this property actually takes a profile, not a standard role\n        instanceTypes: Lazy.list({\n          produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses),\n        }),\n        type: this.spot ? 'SPOT' : 'EC2',\n        spotIamFleetRole: this.spotFleetRole?.roleArn,\n        allocationStrategy: this.allocationStrategy,\n        bidPercentage: this.spotBidPercentage,\n        launchTemplate: this.launchTemplate ? {\n          launchTemplateId: this.launchTemplate?.launchTemplateId,\n        } : undefined,\n        ec2Configuration: this.images?.map((image) => {\n          return {\n            imageIdOverride: image.image?.getImage(this).imageId,\n            imageType: image.imageType ?? EcsMachineImageType.ECS_AL2,\n          };\n        }),\n        placementGroup: this.placementGroup?.placementGroupName,\n        tags: this.tags.renderedTags as any,\n      },\n    });\n\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n\n    this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) });\n  }\n\n  public addInstanceType(instanceType: ec2.InstanceType): void {\n    this.instanceTypes.push(instanceType);\n  }\n\n  public addInstanceClass(instanceClass: ec2.InstanceClass): void {\n    this.instanceClasses.push(instanceClass);\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses EKS orchestration on EC2 instances.\n */\ninterface IManagedEc2EksComputeEnvironment extends IManagedComputeEnvironment {\n  /**\n   * The namespace of the Cluster\n   *\n   * Cannot be 'default', start with 'kube-', or be longer than 64 characters.\n   *\n   * @see https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/\n   */\n  readonly kubernetesNamespace?: string;\n\n  /**\n   * The cluster that backs this Compute Environment. Required\n   * for Compute Environments running Kubernetes jobs.\n   *\n   * Please ensure that you have followed the steps at\n   *\n   * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n   *\n   * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\n   * If you do not follow the steps in the link, the deployment fail with a message that the\n   * compute environment did not stabilize.\n   */\n  readonly eksCluster: eks.ICluster;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * @default\n   * EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\n   */\n  readonly images?: EksMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceTypes: ec2.InstanceType[];\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   */\n  readonly instanceClasses: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.\n   *\n   * @default - no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n\n  /**\n   * Add an instance type to this compute environment\n   */\n  addInstanceType(instanceType: ec2.InstanceType): void;\n\n  /**\n   * Add an instance class to this compute environment\n   */\n  addInstanceClass(instanceClass: ec2.InstanceClass): void;\n}\n\n/**\n * Props for a ManagedEc2EksComputeEnvironment\n */\nexport interface ManagedEc2EksComputeEnvironmentProps extends ManagedComputeEnvironmentProps {\n  /**\n   * The namespace of the Cluster\n   */\n  readonly kubernetesNamespace: string;\n\n  /**\n   * The cluster that backs this Compute Environment. Required\n   * for Compute Environments running Kubernetes jobs.\n   *\n   * Please ensure that you have followed the steps at\n   *\n   * https://docs.aws.amazon.com/batch/latest/userguide/getting-started-eks.html\n   *\n   * before attempting to deploy a `ManagedEc2EksComputeEnvironment` that uses this cluster.\n   * If you do not follow the steps in the link, the deployment fail with a message that the\n   * compute environment did not stabilize.\n   */\n  readonly eksCluster: eks.ICluster;\n\n  /**\n   * Whether or not to use batch's optimal instance type.\n   * The optimal instance type is equivalent to adding the\n   * C4, M4, and R4 instance classes. You can specify other instance classes\n   * (of the same architecture) in addition to the optimal instance classes.\n   *\n   * @default true\n   */\n  readonly useOptimalInstanceClasses?: boolean;\n\n  /**\n   * Configure which AMIs this Compute Environment can launch.\n   *\n   * @default\n   * If `imageKubernetesVersion` is specified,\n   * - EKS_AL2 for non-GPU instances, EKS_AL2_NVIDIA for GPU instances,\n   * Otherwise,\n   * - ECS_AL2 for non-GPU instances, ECS_AL2_NVIDIA for GPU instances,\n   */\n  readonly images?: EksMachineImage[];\n\n  /**\n   * The allocation strategy to use if not enough instances of\n   * the best fitting instance type can be allocated.\n   *\n   * @default - `BEST_FIT_PROGRESSIVE` if not using Spot instances,\n   * `SPOT_CAPACITY_OPTIMIZED` if using Spot instances.\n   */\n  readonly allocationStrategy?: AllocationStrategy;\n\n  /**\n   * The maximum percentage that a Spot Instance price can be when compared with the\n   * On-Demand price for that instance type before instances are launched.\n   * For example, if your maximum percentage is 20%, the Spot price must be\n   * less than 20% of the current On-Demand price for that Instance.\n   * You always pay the lowest market price and never more than your maximum percentage.\n   * For most use cases, Batch recommends leaving this field empty.\n   *\n   * Implies `spot == true` if set\n   *\n   * @default - 100%\n   */\n  readonly spotBidPercentage?: number;\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceTypes?: ec2.InstanceType[];\n\n  /**\n   * The instance types that this Compute Environment can launch.\n   * Which one is chosen depends on the `AllocationStrategy` used.\n   * Batch will automatically choose the instance size.\n   *\n   * @default - the instances Batch considers will be used (currently C4, M4, and R4)\n   */\n  readonly instanceClasses?: ec2.InstanceClass[];\n\n  /**\n   * The execution Role that instances launched by this Compute Environment will use.\n   *\n   * @default - a role will be created\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * The Launch Template that this Compute Environment\n   * will use to provision EC2 Instances.\n   *\n   * *Note*: if `securityGroups` is specified on both your\n   * launch template and this Compute Environment, **the\n   * `securityGroup`s on the Compute Environment override the\n   * ones on the launch template.**\n   *\n   * @default - no launch template\n   */\n  readonly launchTemplate?: ec2.ILaunchTemplate;\n\n  /**\n   * The minimum vCPUs that an environment should maintain,\n   * even if the compute environment is DISABLED.\n   *\n   * @default 0\n   */\n  readonly minvCpus?: number;\n\n  /**\n   * The EC2 placement group to associate with your compute resources.\n   * If you intend to submit multi-node parallel jobs to this Compute Environment,\n   * you should consider creating a cluster placement group and associate it with your compute resources.\n   * This keeps your multi-node parallel job on a logical grouping of instances\n   * within a single Availability Zone with high network flow potential.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/placement-groups.html\n   *\n   * @default - no placement group\n   */\n  readonly placementGroup?: ec2.IPlacementGroup;\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on EC2 instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class ManagedEc2EksComputeEnvironment extends ManagedComputeEnvironmentBase implements IManagedEc2EksComputeEnvironment {\n  public readonly kubernetesNamespace?: string;\n  public readonly eksCluster: eks.ICluster;\n\n  public readonly computeEnvironmentName: string;\n  public readonly computeEnvironmentArn: string;\n\n  public readonly images?: EksMachineImage[];\n  public readonly allocationStrategy?: AllocationStrategy;\n  public readonly spotBidPercentage?: number;\n  public readonly instanceTypes: ec2.InstanceType[];\n  public readonly instanceClasses: ec2.InstanceClass[];\n  public readonly instanceRole?: iam.IRole;\n  public readonly launchTemplate?: ec2.ILaunchTemplate;\n  public readonly minvCpus?: number;\n  public readonly placementGroup?: ec2.IPlacementGroup;\n\n  private readonly instanceProfile: iam.CfnInstanceProfile;\n\n  constructor(scope: Construct, id: string, props: ManagedEc2EksComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    this.kubernetesNamespace = props.kubernetesNamespace;\n    this.eksCluster = props.eksCluster;\n\n    this.images = props.images;\n    this.allocationStrategy = determineAllocationStrategy(id, props.allocationStrategy, this.spot);\n    if (this.allocationStrategy === AllocationStrategy.BEST_FIT) {\n      throw new Error(`ManagedEc2EksComputeEnvironment '${id}' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'`);\n    }\n    this.spotBidPercentage = props.spotBidPercentage;\n    this.instanceTypes = props.instanceTypes ?? [];\n    this.instanceClasses = props.instanceClasses ?? [];\n\n    const { instanceRole, instanceProfile } = createInstanceRoleAndProfile(this, props.instanceRole);\n    this.instanceRole = instanceRole;\n    this.instanceProfile = instanceProfile;\n\n    this.launchTemplate = props.launchTemplate;\n    this.minvCpus = props.minvCpus ?? DEFAULT_MIN_VCPUS;\n    this.placementGroup = props.placementGroup;\n\n    validateVCpus(id, this.minvCpus, this.maxvCpus);\n    validateSpotConfig(id, this.spot, this.spotBidPercentage);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      eksConfiguration: {\n        eksClusterArn: this.eksCluster.clusterArn,\n        kubernetesNamespace: this.kubernetesNamespace,\n      },\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        minvCpus: this.minvCpus,\n        instanceRole: this.instanceProfile.attrArn, // this is not a typo; this property actually takes a profile, not a standard role\n        instanceTypes: Lazy.list({ produce: () => renderInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) }),\n        type: this.spot ? 'SPOT' : 'EC2',\n        allocationStrategy: this.allocationStrategy,\n        bidPercentage: this.spotBidPercentage,\n        launchTemplate: this.launchTemplate ? {\n          launchTemplateId: this.launchTemplate?.launchTemplateId,\n        } : undefined,\n        ec2Configuration: this.images?.map((image) => {\n          return {\n            imageIdOverride: image.image?.getImage(this).imageId,\n            imageType: image.imageType ?? EksMachineImageType.EKS_AL2,\n          };\n        }),\n        placementGroup: this.placementGroup?.placementGroupName,\n        tags: this.tags.renderedTags as any,\n      },\n    });\n\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n\n    this.node.addValidation({ validate: () => validateInstances(this.instanceTypes, this.instanceClasses, props.useOptimalInstanceClasses) });\n  }\n\n  public addInstanceType(instanceType: ec2.InstanceType): void {\n    this.instanceTypes.push(instanceType);\n  }\n\n  public addInstanceClass(instanceClass: ec2.InstanceClass): void {\n    this.instanceClasses.push(instanceClass);\n  }\n}\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances.\n */\nexport interface IFargateComputeEnvironment extends IManagedComputeEnvironment { }\n\n/**\n * Props for a FargateComputeEnvironment\n */\nexport interface FargateComputeEnvironmentProps extends ManagedComputeEnvironmentProps { }\n\n/**\n * A ManagedComputeEnvironment that uses ECS orchestration on Fargate instances.\n *\n * @resource AWS::Batch::ComputeEnvironment\n */\nexport class FargateComputeEnvironment extends ManagedComputeEnvironmentBase implements IFargateComputeEnvironment {\n  /**\n   * Reference an existing FargateComputeEnvironment by its arn\n   */\n  public static fromFargateComputeEnvironmentArn(scope: Construct, id: string, fargateComputeEnvironmentArn: string): IFargateComputeEnvironment {\n    const stack = Stack.of(scope);\n    const computeEnvironmentName = stack.splitArn(fargateComputeEnvironmentArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends Resource implements IFargateComputeEnvironment {\n      public readonly computeEnvironmentArn = fargateComputeEnvironmentArn;\n      public readonly computeEnvironmentName = computeEnvironmentName;\n      public readonly enabled = true;\n      public readonly maxvCpus = 1;\n      public readonly connections = { } as any;\n      public readonly securityGroups = [];\n      public readonly tags: TagManager = new TagManager(TagType.MAP, 'AWS::Batch::ComputeEnvironment');\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeEnvironmentName: string;\n  public readonly computeEnvironmentArn: string;\n\n  constructor(scope: Construct, id: string, props: FargateComputeEnvironmentProps) {\n    super(scope, id, props);\n\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const resource = new CfnComputeEnvironment(this, 'Resource', {\n      ...baseManagedResourceProperties(this, subnetIds),\n      computeEnvironmentName: props.computeEnvironmentName,\n      computeResources: {\n        ...baseManagedResourceProperties(this, subnetIds).computeResources as CfnComputeEnvironment.ComputeResourcesProperty,\n        type: this.spot ? 'FARGATE_SPOT' : 'FARGATE',\n      },\n    });\n    this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref);\n    this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, {\n      service: 'batch',\n      resource: 'compute-environment',\n      resourceName: this.physicalName,\n    });\n  }\n}\n\nfunction renderInstances(types?: ec2.InstanceType[], classes?: ec2.InstanceClass[], useOptimalInstanceClasses?: boolean): string[] {\n  const instances = [];\n\n  for (const instanceType of types ?? []) {\n    instances.push(instanceType.toString());\n  }\n  for (const instanceClass of classes ?? []) {\n    instances.push(instanceClass);\n  }\n  if (useOptimalInstanceClasses || useOptimalInstanceClasses === undefined) {\n    instances.push('optimal');\n  }\n\n  return instances;\n}\n\nfunction createInstanceRoleAndProfile(scope: Construct, instanceRole?: iam.IRole) {\n  const result: any = {};\n\n  result.instanceRole = instanceRole ?? new iam.Role(scope, 'InstanceProfileRole', {\n    assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n    managedPolicies: [iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AmazonEC2ContainerServiceforEC2Role')],\n  });\n\n  result.instanceProfile = new iam.CfnInstanceProfile(scope, 'InstanceProfile', {\n    roles: [result.instanceRole.roleName],\n  });\n\n  return result;\n}\n\nfunction createSpotFleetRole(scope: Construct): IRole {\n  return new iam.Role(scope, 'SpotFleetRole', {\n    assumedBy: new iam.ServicePrincipal('spotfleet.amazonaws.com'),\n  });\n}\n\nfunction determineAllocationStrategy(id: string, allocationStrategy?: AllocationStrategy, spot?: boolean): AllocationStrategy | undefined {\n  let result = allocationStrategy;\n  if (!allocationStrategy) {\n    result = spot ? AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED : AllocationStrategy.BEST_FIT_PROGRESSIVE;\n  } else if (allocationStrategy === AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED && !spot) {\n    throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances`);\n  } else if (allocationStrategy === AllocationStrategy.SPOT_CAPACITY_OPTIMIZED && !spot) {\n    throw new Error(`Managed ComputeEnvironment '${id}' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances`);\n  }\n\n  return result;\n}\n\nfunction validateInstances(types?: ec2.InstanceType[], classes?: ec2.InstanceClass[], useOptimalInstanceClasses?: boolean): string[] {\n  if (renderInstances(types, classes, useOptimalInstanceClasses).length === 0) {\n    return [\"Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes\"];\n  }\n\n  return [];\n}\n\nfunction validateSpotConfig(id: string, spot?: boolean, spotBidPercentage?: number, spotFleetRole?: iam.IRole): void {\n  if (spotBidPercentage) {\n    if (!spot) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' without specifying 'spot'`);\n    } else if (spotBidPercentage > 100) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' > 100`);\n    } else if (spotBidPercentage < 0) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotBidPercentage' < 0`);\n    }\n  }\n\n  if (spotFleetRole) {\n    if (!spot) {\n      throw new Error(`Managed ComputeEnvironment '${id}' specifies 'spotFleetRole' without specifying 'spot'`);\n    }\n  }\n}\n\nfunction validateVCpus(id: string, minvCpus: number, maxvCpus: number): void {\n  if (minvCpus < 0) {\n    throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} < 0; 'minvCpus' cannot be less than zero`);\n  }\n  if (minvCpus > maxvCpus) {\n    throw new Error(`Managed ComputeEnvironment '${id}' has 'minvCpus' = ${minvCpus} > 'maxvCpus' = ${maxvCpus}; 'minvCpus' cannot be greater than 'maxvCpus'`);\n  }\n}\n\nfunction baseManagedResourceProperties(baseComputeEnvironment: ManagedComputeEnvironmentBase, subnetIds: string[]) {\n  return {\n    serviceRole: baseComputeEnvironment.serviceRole?.roleArn,\n    state: baseComputeEnvironment.enabled ? 'ENABLED' : 'DISABLED',\n    computeResources: {\n      maxvCpus: baseComputeEnvironment.maxvCpus,\n      type: 'managed',\n      updateToLatestImageVersion: baseComputeEnvironment.updateToLatestImageVersion,\n      securityGroupIds: baseComputeEnvironment.securityGroups.map((securityGroup) => securityGroup.securityGroupId),\n      subnets: subnetIds,\n    },\n    updatePolicy: {\n      terminateJobsOnUpdate: baseComputeEnvironment.terminateOnUpdate,\n      jobExecutionTimeoutMinutes: baseComputeEnvironment.updateTimeout?.toMinutes(),\n    },\n    replaceComputeEnvironment: baseComputeEnvironment.replaceComputeEnvironment,\n    type: 'managed',\n  };\n}\n\nconst DEFAULT_MIN_VCPUS = 0;\nconst DEFAULT_MAX_VCPUS = 256;\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts deleted file mode 100644 index 460a7d679e9eb..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.d.ts +++ /dev/null @@ -1,107 +0,0 @@ -import * as ec2 from 'aws-cdk-lib/aws-ec2'; -import { Construct } from 'constructs'; -import { IEcsContainerDefinition } from './ecs-container-definition'; -import { IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base'; -interface IMultiNodeJobDefinition extends IJobDefinition { - /** - * The containers that this multinode job will run. - * - * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/ - */ - readonly containers: MultiNodeContainer[]; - /** - * The instance type that this job definition will run - */ - readonly instanceType: ec2.InstanceType; - /** - * The index of the main node in this job. - * The main node is responsible for orchestration. - * - * @default 0 - */ - readonly mainNode?: number; - /** - * Whether to propogate tags from the JobDefinition - * to the ECS task that Batch spawns - * - * @default false - */ - readonly propagateTags?: boolean; - /** - * Add a container to this multinode job - */ - addContainer(container: MultiNodeContainer): void; -} -/** - * Runs the container on nodes [startNode, endNode] - */ -export interface MultiNodeContainer { - /** - * The index of the first node to run this container - * - * The container is run on all nodes in the range [startNode, endNode] (inclusive) - */ - readonly startNode: number; - /** - * The index of the last node to run this container. - * - * The container is run on all nodes in the range [startNode, endNode] (inclusive) - */ - readonly endNode: number; - /** - * The container that this node range will run - */ - readonly container: IEcsContainerDefinition; -} -/** - * Props to configure a MultiNodeJobDefinition - */ -export interface MultiNodeJobDefinitionProps extends JobDefinitionProps { - /** - * The instance type that this job definition - * will run. - */ - readonly instanceType: ec2.InstanceType; - /** - * The containers that this multinode job will run. - * - * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/ - * - * @default none - */ - readonly containers?: MultiNodeContainer[]; - /** - * The index of the main node in this job. - * The main node is responsible for orchestration. - * - * @default 0 - */ - readonly mainNode?: number; - /** - * Whether to propogate tags from the JobDefinition - * to the ECS task that Batch spawns - * - * @default false - */ - readonly propagateTags?: boolean; -} -/** - * A JobDefinition that uses Ecs orchestration to run multiple containers - * - * @resource AWS::Batch::JobDefinition - */ -export declare class MultiNodeJobDefinition extends JobDefinitionBase implements IMultiNodeJobDefinition { - /** - * refer to an existing JobDefinition by its arn - */ - static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition; - readonly containers: MultiNodeContainer[]; - readonly instanceType: ec2.InstanceType; - readonly mainNode?: number; - readonly propagateTags?: boolean; - readonly jobDefinitionArn: string; - readonly jobDefinitionName: string; - constructor(scope: Construct, id: string, props: MultiNodeJobDefinitionProps); - addContainer(container: MultiNodeContainer): void; -} -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js deleted file mode 100644 index dac94633d7c25..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/multinode-job-definition.js +++ /dev/null @@ -1,104 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.MultiNodeJobDefinition = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -const ecs_job_definition_1 = require("./ecs-job-definition"); -const job_definition_base_1 = require("./job-definition-base"); -/** - * A JobDefinition that uses Ecs orchestration to run multiple containers - * - * @resource AWS::Batch::JobDefinition - */ -class MultiNodeJobDefinition extends job_definition_base_1.JobDefinitionBase { - /** - * refer to an existing JobDefinition by its arn - */ - static fromJobDefinitionArn(scope, id, jobDefinitionArn) { - const stack = core_1.Stack.of(scope); - const jobDefinitionName = stack.splitArn(jobDefinitionArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - class Import extends job_definition_base_1.JobDefinitionBase { - constructor() { - super(...arguments); - this.jobDefinitionArn = jobDefinitionArn; - this.jobDefinitionName = jobDefinitionName; - this.enabled = true; - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_MultiNodeJobDefinitionProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, MultiNodeJobDefinition); - } - throw error; - } - this.containers = props.containers ?? []; - this.mainNode = props.mainNode; - this.instanceType = props.instanceType; - this.propagateTags = props?.propagateTags; - const resource = new aws_batch_1.CfnJobDefinition(this, 'Resource', { - ...(0, job_definition_base_1.baseJobDefinitionProperties)(this), - type: 'multinode', - jobDefinitionName: props.jobDefinitionName, - propagateTags: this.propagateTags, - nodeProperties: { - mainNode: this.mainNode ?? 0, - nodeRangeProperties: core_1.Lazy.any({ - produce: () => this.containers.map((container) => ({ - targetNodes: container.startNode + ':' + container.endNode, - container: { - ...container.container._renderContainerDefinition(), - instanceType: this.instanceType.toString(), - }, - })), - }), - numNodes: core_1.Lazy.number({ - produce: () => computeNumNodes(this.containers), - }), - }, - platformCapabilities: [ecs_job_definition_1.Compatibility.EC2], - }); - this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, { - service: 'batch', - resource: 'job-definition', - resourceName: this.physicalName, - }); - this.jobDefinitionName = this.getResourceNameAttribute(resource.ref); - this.node.addValidation({ validate: () => validateContainers(this.containers) }); - } - addContainer(container) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_MultiNodeContainer(container); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addContainer); - } - throw error; - } - this.containers.push(container); - } -} -exports.MultiNodeJobDefinition = MultiNodeJobDefinition; -_a = JSII_RTTI_SYMBOL_1; -MultiNodeJobDefinition[_a] = { fqn: "@aws-cdk/aws-batch-alpha.MultiNodeJobDefinition", version: "0.0.0" }; -function computeNumNodes(containers) { - let result = 0; - for (const container of containers) { - result += container.endNode - container.startNode + 1; - } - return result; -} -function validateContainers(containers) { - return containers.length === 0 ? ['multinode job has no containers!'] : []; -} -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multinode-job-definition.js","sourceRoot":"","sources":["multinode-job-definition.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport { ArnFormat, Lazy, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnJobDefinition } from 'aws-cdk-lib/aws-batch';\nimport { IEcsContainerDefinition } from './ecs-container-definition';\nimport { Compatibility } from './ecs-job-definition';\nimport { baseJobDefinitionProperties, IJobDefinition, JobDefinitionBase, JobDefinitionProps } from './job-definition-base';\n\ninterface IMultiNodeJobDefinition extends IJobDefinition {\n  /**\n   * The containers that this multinode job will run.\n   *\n   * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/\n   */\n  readonly containers: MultiNodeContainer[];\n\n  /**\n   * The instance type that this job definition will run\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The index of the main node in this job.\n   * The main node is responsible for orchestration.\n   *\n   * @default 0\n   */\n  readonly mainNode?: number;\n\n  /**\n   * Whether to propogate tags from the JobDefinition\n   * to the ECS task that Batch spawns\n   *\n   * @default false\n   */\n  readonly propagateTags?: boolean;\n\n  /**\n   * Add a container to this multinode job\n   */\n  addContainer(container: MultiNodeContainer): void;\n}\n\n/**\n * Runs the container on nodes [startNode, endNode]\n */\nexport interface MultiNodeContainer {\n  /**\n   * The index of the first node to run this container\n   *\n   * The container is run on all nodes in the range [startNode, endNode] (inclusive)\n   */\n  readonly startNode: number;\n\n  /**\n   * The index of the last node to run this container.\n   *\n   * The container is run on all nodes in the range [startNode, endNode] (inclusive)\n   */\n  readonly endNode: number;\n\n  /**\n   * The container that this node range will run\n   */\n  readonly container: IEcsContainerDefinition;\n}\n\n/**\n * Props to configure a MultiNodeJobDefinition\n */\nexport interface MultiNodeJobDefinitionProps extends JobDefinitionProps {\n  /**\n   * The instance type that this job definition\n   * will run.\n   */\n  readonly instanceType: ec2.InstanceType;\n\n  /**\n   * The containers that this multinode job will run.\n   *\n   * @see https://aws.amazon.com/blogs/compute/building-a-tightly-coupled-molecular-dynamics-workflow-with-multi-node-parallel-jobs-in-aws-batch/\n   *\n   * @default none\n   */\n  readonly containers?: MultiNodeContainer[];\n\n  /**\n   * The index of the main node in this job.\n   * The main node is responsible for orchestration.\n   *\n   * @default 0\n   */\n  readonly mainNode?: number;\n\n  /**\n   * Whether to propogate tags from the JobDefinition\n   * to the ECS task that Batch spawns\n   *\n   * @default false\n   */\n  readonly propagateTags?: boolean;\n}\n\n/**\n * A JobDefinition that uses Ecs orchestration to run multiple containers\n *\n * @resource AWS::Batch::JobDefinition\n */\nexport class MultiNodeJobDefinition extends JobDefinitionBase implements IMultiNodeJobDefinition {\n  /**\n   * refer to an existing JobDefinition by its arn\n   */\n  public static fromJobDefinitionArn(scope: Construct, id: string, jobDefinitionArn: string): IJobDefinition {\n    const stack = Stack.of(scope);\n    const jobDefinitionName = stack.splitArn(jobDefinitionArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n\n    class Import extends JobDefinitionBase implements IJobDefinition {\n      public readonly jobDefinitionArn = jobDefinitionArn;\n      public readonly jobDefinitionName = jobDefinitionName;\n      public readonly enabled = true;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly containers: MultiNodeContainer[];\n  public readonly instanceType: ec2.InstanceType;\n  public readonly mainNode?: number;\n  public readonly propagateTags?: boolean;\n\n  public readonly jobDefinitionArn: string;\n  public readonly jobDefinitionName: string;\n\n  constructor(scope: Construct, id: string, props: MultiNodeJobDefinitionProps) {\n    super(scope, id, props);\n\n    this.containers = props.containers ?? [];\n    this.mainNode = props.mainNode;\n    this.instanceType = props.instanceType;\n    this.propagateTags = props?.propagateTags;\n\n    const resource = new CfnJobDefinition(this, 'Resource', {\n      ...baseJobDefinitionProperties(this),\n      type: 'multinode',\n      jobDefinitionName: props.jobDefinitionName,\n      propagateTags: this.propagateTags,\n      nodeProperties: {\n        mainNode: this.mainNode ?? 0,\n        nodeRangeProperties: Lazy.any({\n          produce: () => this.containers.map((container) => ({\n            targetNodes: container.startNode + ':' + container.endNode,\n            container: {\n              ...container.container._renderContainerDefinition(),\n              instanceType: this.instanceType.toString(),\n            },\n          })),\n        }),\n        numNodes: Lazy.number({\n          produce: () => computeNumNodes(this.containers),\n        }),\n      },\n      platformCapabilities: [Compatibility.EC2],\n    });\n    this.jobDefinitionArn = this.getResourceArnAttribute(resource.ref, {\n      service: 'batch',\n      resource: 'job-definition',\n      resourceName: this.physicalName,\n    });\n    this.jobDefinitionName = this.getResourceNameAttribute(resource.ref);\n\n    this.node.addValidation({ validate: () => validateContainers(this.containers) });\n  }\n\n  public addContainer(container: MultiNodeContainer) {\n    this.containers.push(container);\n  }\n}\n\nfunction computeNumNodes(containers: MultiNodeContainer[]) {\n  let result = 0;\n\n  for (const container of containers) {\n    result += container.endNode - container.startNode + 1;\n  }\n\n  return result;\n}\n\nfunction validateContainers(containers: MultiNodeContainer[]): string[] {\n  return containers.length === 0 ? ['multinode job has no containers!'] : [];\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts deleted file mode 100644 index 1359eddcba414..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.d.ts +++ /dev/null @@ -1,188 +0,0 @@ -import { Duration, IResource, Resource } from 'aws-cdk-lib/core'; -import { Construct } from 'constructs'; -/** - * Represents a Scheduling Policy. Scheduling Policies tell the Batch - * Job Scheduler how to schedule incoming jobs. - */ -export interface ISchedulingPolicy extends IResource { - /** - * The name of this scheduling policy - * - * @attribute - */ - readonly schedulingPolicyName: string; - /** - * The arn of this scheduling policy - * - * @attribute - */ - readonly schedulingPolicyArn: string; -} -/** - * Props to configure a SchedulingPolicy - */ -interface SchedulingPolicyProps { - /** - * The name of this SchedulingPolicy - * - * @default - generated by CloudFormation - */ - readonly schedulingPolicyName?: string; -} -/** - * @internal - */ -export declare abstract class SchedulingPolicyBase extends Resource implements ISchedulingPolicy { - abstract readonly schedulingPolicyName: string; - abstract readonly schedulingPolicyArn: string; - constructor(scope: Construct, id: string, props?: SchedulingPolicyProps); -} -/** - * Represents a group of Job Definitions. All Job Definitions that - * declare a share identifier will be considered members of the Share - * defined by that share identifier. - * - * The Scheduler divides the maximum available vCPUs of the ComputeEnvironment - * among Jobs in the Queue based on their shareIdentifier and the weightFactor - * associated with that shareIdentifier. - */ -export interface Share { - /** - * The identifier of this Share. All jobs that specify this share identifier - * when submitted to the queue will be considered as part of this Share. - */ - readonly shareIdentifier: string; - /** - * The weight factor given to this Share. The Scheduler decides which jobs to put in the Compute Environment - * such that the following ratio is equal for each job: - * - * `sharevCpu / weightFactor`, - * - * where `sharevCpu` is the total amount of vCPU given to that particular share; that is, - * the sum of the vCPU of each job currently in the Compute Environment for that share. - * - * See the readme of this module for a detailed example that shows how these are used, - * how it relates to `computeReservation`, and how `shareDecay` affects these calculations. - */ - readonly weightFactor: number; -} -/** - * Represents a Fairshare Scheduling Policy. Instructs the scheduler - * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. - * - * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. - * It does this by deciding how many Jobs of each share to schedule *relative to how many jobs of - * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with - * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of - * fairshare policies. - */ -export interface IFairshareSchedulingPolicy extends ISchedulingPolicy { - /** - * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue. - * - * The percentage reserved is defined by the Scheduler as: - * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers. - * - * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the - * maximum available vCPU if there's only one fair share identifier. - * It reserves 25% if there are two fair share identifiers. - * It reserves 12.5% if there are three fair share identifiers. - * - * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the - * maximum available vCPU if there's only one fair share identifier, - * 6.25% if there are two fair share identifiers, - * and 1.56% if there are three fair share identifiers. - * - * @default - no vCPU is reserved - */ - readonly computeReservation?: number; - /** - * The amount of time to use to measure the usage of each job. - * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue. - * A value of zero (0) indicates that only current usage is measured. - * The decay is linear and gives preference to newer jobs. - * - * The maximum supported value is 604800 seconds (1 week). - * - * @default - 0: only the current job usage is considered - */ - readonly shareDecay?: Duration; - /** - * The shares that this Scheduling Policy applies to. - * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that - * are not recognized by the Scheduling Policy. - */ - readonly shares: Share[]; -} -/** - * Fairshare SchedulingPolicy configuration - */ -export interface FairshareSchedulingPolicyProps extends SchedulingPolicyProps { - /** - * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue. - * - * The percentage reserved is defined by the Scheduler as: - * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers. - * - * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the - * maximum available vCPU if there's only one fair share identifier. - * It reserves 25% if there are two fair share identifiers. - * It reserves 12.5% if there are three fair share identifiers. - * - * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the - * maximum available vCPU if there's only one fair share identifier, - * 6.25% if there are two fair share identifiers, - * and 1.56% if there are three fair share identifiers. - * - * @default - no vCPU is reserved - */ - readonly computeReservation?: number; - /** - * The amount of time to use to measure the usage of each job. - * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue. - * A value of zero (0) indicates that only current usage is measured. - * The decay is linear and gives preference to newer jobs. - * - * The maximum supported value is 604800 seconds (1 week). - * - * @default - 0: only the current job usage is considered - */ - readonly shareDecay?: Duration; - /** - * The shares that this Scheduling Policy applies to. - * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that - * are not recognized by the Scheduling Policy. - * - * @default - no shares - */ - readonly shares?: Share[]; -} -/** - * Represents a Fairshare Scheduling Policy. Instructs the scheduler - * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. - * - * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. - * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of - * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with - * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of - * fairshare policies. - * - * @resource AWS::Batch::SchedulingPolicy - */ -export declare class FairshareSchedulingPolicy extends SchedulingPolicyBase implements IFairshareSchedulingPolicy { - /** - * Reference an exisiting Scheduling Policy by its ARN - */ - static fromFairshareSchedulingPolicyArn(scope: Construct, id: string, fairshareSchedulingPolicyArn: string): IFairshareSchedulingPolicy; - readonly computeReservation?: number; - readonly shareDecay?: Duration; - readonly shares: Share[]; - readonly schedulingPolicyArn: string; - readonly schedulingPolicyName: string; - constructor(scope: Construct, id: string, props?: FairshareSchedulingPolicyProps); - /** - * Add a share this to this Fairshare SchedulingPolicy - */ - addShare(share: Share): void; -} -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js b/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js deleted file mode 100644 index 927263fa715f3..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/scheduling-policy.js +++ /dev/null @@ -1,101 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.FairshareSchedulingPolicy = exports.SchedulingPolicyBase = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -/** - * @internal - */ -class SchedulingPolicyBase extends core_1.Resource { - constructor(scope, id, props) { - super(scope, id, { - physicalName: props?.schedulingPolicyName, - }); - } -} -exports.SchedulingPolicyBase = SchedulingPolicyBase; -/** - * Represents a Fairshare Scheduling Policy. Instructs the scheduler - * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers. - * - * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs. - * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of - * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with - * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of - * fairshare policies. - * - * @resource AWS::Batch::SchedulingPolicy - */ -class FairshareSchedulingPolicy extends SchedulingPolicyBase { - /** - * Reference an exisiting Scheduling Policy by its ARN - */ - static fromFairshareSchedulingPolicyArn(scope, id, fairshareSchedulingPolicyArn) { - const stack = core_1.Stack.of(scope); - class Import extends SchedulingPolicyBase { - constructor() { - super(...arguments); - this.schedulingPolicyArn = fairshareSchedulingPolicyArn; - this.schedulingPolicyName = stack.splitArn(fairshareSchedulingPolicyArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - this.shares = []; - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_FairshareSchedulingPolicyProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, FairshareSchedulingPolicy); - } - throw error; - } - this.computeReservation = props?.computeReservation; - this.shareDecay = props?.shareDecay; - this.shares = props?.shares ?? []; - const resource = new aws_batch_1.CfnSchedulingPolicy(this, 'Resource', { - fairsharePolicy: { - computeReservation: this.computeReservation, - shareDecaySeconds: this.shareDecay?.toSeconds(), - shareDistribution: core_1.Lazy.any({ - produce: () => this.shares?.map((share) => ({ - shareIdentifier: share.shareIdentifier, - weightFactor: share.weightFactor, - })), - }), - }, - name: props?.schedulingPolicyName, - }); - this.schedulingPolicyArn = this.getResourceArnAttribute(resource.attrArn, { - service: 'batch', - resource: 'scheduling-policy', - resourceName: this.physicalName, - }); - this.schedulingPolicyName = this.getResourceNameAttribute(resource.ref); - } - /** - * Add a share this to this Fairshare SchedulingPolicy - */ - addShare(share) { - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_Share(share); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, this.addShare); - } - throw error; - } - this.shares.push(share); - } -} -exports.FairshareSchedulingPolicy = FairshareSchedulingPolicy; -_a = JSII_RTTI_SYMBOL_1; -FairshareSchedulingPolicy[_a] = { fqn: "@aws-cdk/aws-batch-alpha.FairshareSchedulingPolicy", version: "0.0.0" }; -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheduling-policy.js","sourceRoot":"","sources":["scheduling-policy.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAyF;AAEzF,qDAA4D;AAkC5D;;GAEG;AACH,MAAsB,oBAAqB,SAAQ,eAAQ;IAIzD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,EAAE,oBAAoB;SAC1C,CAAC,CAAC;KACJ;CACF;AATD,oDASC;AAkID;;;;;;;;;;;GAWG;AACH,MAAa,yBAA0B,SAAQ,oBAAoB;IACjE;;OAEG;IACI,MAAM,CAAC,gCAAgC,CAAC,KAAgB,EAAE,EAAU,EAAE,4BAAoC;QAC/G,MAAM,KAAK,GAAG,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,MAAO,SAAQ,oBAAoB;YAAzC;;gBACkB,wBAAmB,GAAG,4BAA4B,CAAC;gBACnD,yBAAoB,GAAG,KAAK,CAAC,QAAQ,CAAC,4BAA4B,EAAE,gBAAS,CAAC,mBAAmB,CAAC,CAAC,YAAa,CAAC;gBACjH,WAAM,GAAG,EAAE,CAAC;YAC9B,CAAC;SAAA;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IAQD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAsC;QAC9E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;;;;;;+CAtBf,yBAAyB;;;;QAuBlC,IAAI,CAAC,kBAAkB,GAAG,KAAK,EAAE,kBAAkB,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,KAAK,EAAE,UAAU,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,KAAK,EAAE,MAAM,IAAI,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,+BAAmB,CAAC,IAAI,EAAE,UAAU,EAAE;YACzD,eAAe,EAAE;gBACf,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;gBAC3C,iBAAiB,EAAE,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE;gBAC/C,iBAAiB,EAAE,WAAI,CAAC,GAAG,CAAC;oBAC1B,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;wBAC1C,eAAe,EAAE,KAAK,CAAC,eAAe;wBACtC,YAAY,EAAE,KAAK,CAAC,YAAY;qBACjC,CAAC,CAAC;iBACJ,CAAC;aACH;YACD,IAAI,EAAE,KAAK,EAAE,oBAAoB;SAClC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,OAAO,EAAE;YACxE,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,mBAAmB;YAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;KACzE;IAED;;OAEG;IACI,QAAQ,CAAC,KAAY;;;;;;;;;;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KACzB;;AArDH,8DAsDC","sourcesContent":["import { ArnFormat, Duration, IResource, Lazy, Resource, Stack } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnSchedulingPolicy } from 'aws-cdk-lib/aws-batch';\n\n/**\n * Represents a Scheduling Policy. Scheduling Policies tell the Batch\n * Job Scheduler how to schedule incoming jobs.\n */\nexport interface ISchedulingPolicy extends IResource {\n  /**\n   * The name of this scheduling policy\n   *\n   * @attribute\n   */\n  readonly schedulingPolicyName: string\n\n  /**\n   * The arn of this scheduling policy\n   *\n   * @attribute\n   */\n  readonly schedulingPolicyArn: string;\n}\n\n/**\n * Props to configure a SchedulingPolicy\n */\ninterface SchedulingPolicyProps {\n  /**\n   * The name of this SchedulingPolicy\n   *\n   * @default - generated by CloudFormation\n   */\n  readonly schedulingPolicyName?: string;\n}\n\n/**\n * @internal\n */\nexport abstract class SchedulingPolicyBase extends Resource implements ISchedulingPolicy {\n  public abstract readonly schedulingPolicyName: string;\n  public abstract readonly schedulingPolicyArn: string;\n\n  constructor(scope: Construct, id: string, props?: SchedulingPolicyProps) {\n    super(scope, id, {\n      physicalName: props?.schedulingPolicyName,\n    });\n  }\n}\n\n/**\n * Represents a group of Job Definitions. All Job Definitions that\n * declare a share identifier will be considered members of the Share\n * defined by that share identifier.\n *\n * The Scheduler divides the maximum available vCPUs of the ComputeEnvironment\n * among Jobs in the Queue based on their shareIdentifier and the weightFactor\n * associated with that shareIdentifier.\n */\nexport interface Share {\n  /**\n   * The identifier of this Share. All jobs that specify this share identifier\n   * when submitted to the queue will be considered as part of this Share.\n   */\n  readonly shareIdentifier: string;\n\n  /**\n   * The weight factor given to this Share. The Scheduler decides which jobs to put in the Compute Environment\n   * such that the following ratio is equal for each job:\n   *\n   * `sharevCpu / weightFactor`,\n   *\n   * where `sharevCpu` is the total amount of vCPU given to that particular share; that is,\n   * the sum of the vCPU of each job currently in the Compute Environment for that share.\n   *\n   * See the readme of this module for a detailed example that shows how these are used,\n   * how it relates to `computeReservation`, and how `shareDecay` affects these calculations.\n   */\n  readonly weightFactor: number;\n}\n\n/**\n * Represents a Fairshare Scheduling Policy. Instructs the scheduler\n * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers.\n *\n * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\n * It does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\n * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with\n * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\n * fairshare policies.\n */\nexport interface IFairshareSchedulingPolicy extends ISchedulingPolicy {\n  /**\n   * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue.\n   *\n   * The percentage reserved is defined by the Scheduler as:\n   * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n   *\n   * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\n   * maximum available vCPU if there's only one fair share identifier.\n   * It reserves 25% if there are two fair share identifiers.\n   * It reserves 12.5% if there are three fair share identifiers.\n   *\n   * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\n   * maximum available vCPU if there's only one fair share identifier,\n   * 6.25% if there are two fair share identifiers,\n   * and 1.56% if there are three fair share identifiers.\n   *\n   * @default - no vCPU is reserved\n   */\n  readonly computeReservation?: number;\n\n  /**\n   * The amount of time to use to measure the usage of each job.\n   * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\n   * A value of zero (0) indicates that only current usage is measured.\n   * The decay is linear and gives preference to newer jobs.\n   *\n   * The maximum supported value is 604800 seconds (1 week).\n   *\n   * @default - 0: only the current job usage is considered\n   */\n  readonly shareDecay?: Duration;\n\n  /**\n   * The shares that this Scheduling Policy applies to.\n   * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that\n   * are not recognized by the Scheduling Policy.\n   */\n  readonly shares: Share[];\n}\n\n/**\n * Fairshare SchedulingPolicy configuration\n */\nexport interface FairshareSchedulingPolicyProps extends SchedulingPolicyProps {\n  /**\n   * Used to calculate the percentage of the maximum available vCPU to reserve for share identifiers not present in the Queue.\n   *\n   * The percentage reserved is defined by the Scheduler as:\n   * `(computeReservation/100)^ActiveFairShares` where `ActiveFairShares` is the number of active fair share identifiers.\n   *\n   * For example, a computeReservation value of 50 indicates that AWS Batch reserves 50% of the\n   * maximum available vCPU if there's only one fair share identifier.\n   * It reserves 25% if there are two fair share identifiers.\n   * It reserves 12.5% if there are three fair share identifiers.\n   *\n   * A computeReservation value of 25 indicates that AWS Batch should reserve 25% of the\n   * maximum available vCPU if there's only one fair share identifier,\n   * 6.25% if there are two fair share identifiers,\n   * and 1.56% if there are three fair share identifiers.\n   *\n   * @default - no vCPU is reserved\n   */\n  readonly computeReservation?: number;\n\n  /**\n   * The amount of time to use to measure the usage of each job.\n   * The usage is used to calculate a fair share percentage for each fair share identifier currently in the Queue.\n   * A value of zero (0) indicates that only current usage is measured.\n   * The decay is linear and gives preference to newer jobs.\n   *\n   * The maximum supported value is 604800 seconds (1 week).\n   *\n   * @default - 0: only the current job usage is considered\n   */\n  readonly shareDecay?: Duration;\n\n  /**\n   * The shares that this Scheduling Policy applies to.\n   * *Note*: It is possible to submit Jobs to the queue with Share Identifiers that\n   * are not recognized by the Scheduling Policy.\n   *\n   * @default - no shares\n   */\n  readonly shares?: Share[];\n}\n\n/**\n * Represents a Fairshare Scheduling Policy. Instructs the scheduler\n * to allocate ComputeEnvironment vCPUs based on Job shareIdentifiers.\n *\n * The Faireshare Scheduling Policy ensures that each share gets a certain amount of vCPUs.\n * The scheduler does this by deciding how many Jobs of each share to schedule *relative to how many jobs of\n * each share are currently being executed by the ComputeEnvironment*. The weight factors associated with\n * each share determine the ratio of vCPUs allocated; see the readme for a more in-depth discussion of\n * fairshare policies.\n *\n * @resource AWS::Batch::SchedulingPolicy\n */\nexport class FairshareSchedulingPolicy extends SchedulingPolicyBase implements IFairshareSchedulingPolicy {\n  /**\n   * Reference an exisiting Scheduling Policy by its ARN\n   */\n  public static fromFairshareSchedulingPolicyArn(scope: Construct, id: string, fairshareSchedulingPolicyArn: string): IFairshareSchedulingPolicy {\n    const stack = Stack.of(scope);\n    class Import extends SchedulingPolicyBase implements IFairshareSchedulingPolicy {\n      public readonly schedulingPolicyArn = fairshareSchedulingPolicyArn;\n      public readonly schedulingPolicyName = stack.splitArn(fairshareSchedulingPolicyArn, ArnFormat.SLASH_RESOURCE_NAME).resourceName!;\n      public readonly shares = [];\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly computeReservation?: number;\n  public readonly shareDecay?: Duration;\n  public readonly shares: Share[];\n  public readonly schedulingPolicyArn: string;\n  public readonly schedulingPolicyName: string;\n\n  constructor(scope: Construct, id: string, props?: FairshareSchedulingPolicyProps) {\n    super(scope, id, props);\n    this.computeReservation = props?.computeReservation;\n    this.shareDecay = props?.shareDecay;\n    this.shares = props?.shares ?? [];\n    const resource = new CfnSchedulingPolicy(this, 'Resource', {\n      fairsharePolicy: {\n        computeReservation: this.computeReservation,\n        shareDecaySeconds: this.shareDecay?.toSeconds(),\n        shareDistribution: Lazy.any({\n          produce: () => this.shares?.map((share) => ({\n            shareIdentifier: share.shareIdentifier,\n            weightFactor: share.weightFactor,\n          })),\n        }),\n      },\n      name: props?.schedulingPolicyName,\n    });\n\n    this.schedulingPolicyArn = this.getResourceArnAttribute(resource.attrArn, {\n      service: 'batch',\n      resource: 'scheduling-policy',\n      resourceName: this.physicalName,\n    });\n    this.schedulingPolicyName = this.getResourceNameAttribute(resource.ref);\n  }\n\n  /**\n   * Add a share this to this Fairshare SchedulingPolicy\n   */\n  public addShare(share: Share) {\n    this.shares.push(share);\n  }\n}\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts deleted file mode 100644 index 80c8be1714cae..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.d.ts +++ /dev/null @@ -1,47 +0,0 @@ -import { Construct } from 'constructs'; -import { IComputeEnvironment, ComputeEnvironmentBase, ComputeEnvironmentProps } from './compute-environment-base'; -/** - * Represents an UnmanagedComputeEnvironment. Batch will not provision instances on your behalf - * in this ComputeEvironment. - */ -export interface IUnmanagedComputeEnvironment extends IComputeEnvironment { - /** - * The vCPUs this Compute Environment provides. Used only by the - * scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s. - * - * **If this parameter is not provided on a fairshare queue, no capacity is reserved**; - * that is, the `FairshareSchedulingPolicy` is ignored. - */ - readonly unmanagedvCPUs?: number; -} -/** - * Represents an UnmanagedComputeEnvironment. Batch will not provision instances on your behalf - * in this ComputeEvironment. - */ -export interface UnmanagedComputeEnvironmentProps extends ComputeEnvironmentProps { - /** - * The vCPUs this Compute Environment provides. Used only by the - * scheduler to schedule jobs in `Queue`s that use `FairshareSchedulingPolicy`s. - * - * **If this parameter is not provided on a fairshare queue, no capacity is reserved**; - * that is, the `FairshareSchedulingPolicy` is ignored. - * - * @default 0 - */ - readonly unmanagedvCpus?: number; -} -/** - * Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf. - * - * @resource AWS::Batch::ComputeEnvironment - */ -export declare class UnmanagedComputeEnvironment extends ComputeEnvironmentBase implements IUnmanagedComputeEnvironment { - /** - * Import an UnmanagedComputeEnvironment by its arn - */ - static fromUnmanagedComputeEnvironmentArn(scope: Construct, id: string, unmanagedComputeEnvironmentArn: string): IUnmanagedComputeEnvironment; - readonly unmanagedvCPUs?: number | undefined; - readonly computeEnvironmentArn: string; - readonly computeEnvironmentName: string; - constructor(scope: Construct, id: string, props?: UnmanagedComputeEnvironmentProps); -} diff --git a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js deleted file mode 100644 index 3a7d3f74798bd..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/lib/unmanaged-compute-environment.js +++ /dev/null @@ -1,70 +0,0 @@ -"use strict"; -var _a; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.UnmanagedComputeEnvironment = void 0; -const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); -const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const core_1 = require("aws-cdk-lib/core"); -const aws_batch_1 = require("aws-cdk-lib/aws-batch"); -const compute_environment_base_1 = require("./compute-environment-base"); -/** - * Unmanaged ComputeEnvironments do not provision or manage EC2 instances on your behalf. - * - * @resource AWS::Batch::ComputeEnvironment - */ -class UnmanagedComputeEnvironment extends compute_environment_base_1.ComputeEnvironmentBase { - /** - * Import an UnmanagedComputeEnvironment by its arn - */ - static fromUnmanagedComputeEnvironmentArn(scope, id, unmanagedComputeEnvironmentArn) { - const stack = core_1.Stack.of(scope); - const computeEnvironmentName = stack.splitArn(unmanagedComputeEnvironmentArn, core_1.ArnFormat.SLASH_RESOURCE_NAME).resourceName; - class Import extends compute_environment_base_1.ComputeEnvironmentBase { - constructor() { - super(...arguments); - this.computeEnvironmentArn = unmanagedComputeEnvironmentArn; - this.computeEnvironmentName = computeEnvironmentName; - this.enabled = true; - this.containerDefinition = {}; - } - } - return new Import(scope, id); - } - constructor(scope, id, props) { - super(scope, id, props); - try { - jsiiDeprecationWarnings._aws_cdk_aws_batch_alpha_UnmanagedComputeEnvironmentProps(props); - } - catch (error) { - if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { - Error.captureStackTrace(error, UnmanagedComputeEnvironment); - } - throw error; - } - this.unmanagedvCPUs = props?.unmanagedvCpus; - const resource = new aws_batch_1.CfnComputeEnvironment(this, 'Resource', { - type: 'unmanaged', - state: this.enabled ? 'ENABLED' : 'DISABLED', - computeEnvironmentName: props?.computeEnvironmentName, - unmanagedvCpus: this.unmanagedvCPUs, - serviceRole: props?.serviceRole?.roleArn - ?? new aws_iam_1.Role(this, 'BatchServiceRole', { - managedPolicies: [ - aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSBatchServiceRole'), - ], - assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), - }).roleArn, - }); - this.computeEnvironmentName = this.getResourceNameAttribute(resource.ref); - this.computeEnvironmentArn = this.getResourceArnAttribute(resource.attrComputeEnvironmentArn, { - service: 'batch', - resource: 'compute-environment', - resourceName: this.physicalName, - }); - } -} -exports.UnmanagedComputeEnvironment = UnmanagedComputeEnvironment; -_a = JSII_RTTI_SYMBOL_1; -UnmanagedComputeEnvironment[_a] = { fqn: "@aws-cdk/aws-batch-alpha.UnmanagedComputeEnvironment", version: "0.0.0" }; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1bm1hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxpREFBNEU7QUFDNUUsMkNBQW9EO0FBRXBELHFEQUE4RDtBQUM5RCx5RUFBa0g7QUFrQ2xIOzs7O0dBSUc7QUFDSCxNQUFhLDJCQUE0QixTQUFRLGlEQUFzQjtJQUNyRTs7T0FFRztJQUNJLE1BQU0sQ0FBQyxrQ0FBa0MsQ0FDOUMsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsOEJBQXNDO1FBRXBFLE1BQU0sS0FBSyxHQUFHLFlBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsTUFBTSxzQkFBc0IsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDLDhCQUE4QixFQUFFLGdCQUFTLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxZQUFhLENBQUM7UUFFM0gsTUFBTSxNQUFPLFNBQVEsaURBQXNCO1lBQTNDOztnQkFDa0IsMEJBQXFCLEdBQUcsOEJBQThCLENBQUM7Z0JBQ3ZELDJCQUFzQixHQUFHLHNCQUFzQixDQUFDO2dCQUNoRCxZQUFPLEdBQUcsSUFBSSxDQUFDO2dCQUNmLHdCQUFtQixHQUFHLEVBQVMsQ0FBQztZQUNsRCxDQUFDO1NBQUE7UUFFRCxPQUFPLElBQUksTUFBTSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztLQUM5QjtJQU1ELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0M7UUFDaEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7Ozs7OzsrQ0F6QmYsMkJBQTJCOzs7O1FBMkJwQyxJQUFJLENBQUMsY0FBYyxHQUFHLEtBQUssRUFBRSxjQUFjLENBQUM7UUFDNUMsTUFBTSxRQUFRLEdBQUcsSUFBSSxpQ0FBcUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQzNELElBQUksRUFBRSxXQUFXO1lBQ2pCLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFVBQVU7WUFDNUMsc0JBQXNCLEVBQUUsS0FBSyxFQUFFLHNCQUFzQjtZQUNyRCxjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7WUFDbkMsV0FBVyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsT0FBTzttQkFDckMsSUFBSSxjQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFO29CQUNwQyxlQUFlLEVBQUU7d0JBQ2YsdUJBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxrQ0FBa0MsQ0FBQztxQkFDM0U7b0JBQ0QsU0FBUyxFQUFFLElBQUksMEJBQWdCLENBQUMscUJBQXFCLENBQUM7aUJBQ3ZELENBQUMsQ0FBQyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLHNCQUFzQixHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUUsSUFBSSxDQUFDLHFCQUFxQixHQUFHLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxRQUFRLENBQUMseUJBQXlCLEVBQUU7WUFDNUYsT0FBTyxFQUFFLE9BQU87WUFDaEIsUUFBUSxFQUFFLHFCQUFxQjtZQUMvQixZQUFZLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDaEMsQ0FBQyxDQUFDO0tBQ0o7O0FBL0NILGtFQWdEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hbmFnZWRQb2xpY3ksIFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IEFybkZvcm1hdCwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYi9jb3JlJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQ2ZuQ29tcHV0ZUVudmlyb25tZW50IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWJhdGNoJztcbmltcG9ydCB7IElDb21wdXRlRW52aXJvbm1lbnQsIENvbXB1dGVFbnZpcm9ubWVudEJhc2UsIENvbXB1dGVFbnZpcm9ubWVudFByb3BzIH0gZnJvbSAnLi9jb21wdXRlLWVudmlyb25tZW50LWJhc2UnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50LiBCYXRjaCB3aWxsIG5vdCBwcm92aXNpb24gaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmXG4gKiBpbiB0aGlzIENvbXB1dGVFdmlyb25tZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQgZXh0ZW5kcyBJQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgLyoqXG4gICAqIFRoZSB2Q1BVcyB0aGlzIENvbXB1dGUgRW52aXJvbm1lbnQgcHJvdmlkZXMuIFVzZWQgb25seSBieSB0aGVcbiAgICogc2NoZWR1bGVyIHRvIHNjaGVkdWxlIGpvYnMgaW4gYFF1ZXVlYHMgdGhhdCB1c2UgYEZhaXJzaGFyZVNjaGVkdWxpbmdQb2xpY3lgcy5cbiAgICpcbiAgICogKipJZiB0aGlzIHBhcmFtZXRlciBpcyBub3QgcHJvdmlkZWQgb24gYSBmYWlyc2hhcmUgcXVldWUsIG5vIGNhcGFjaXR5IGlzIHJlc2VydmVkKio7XG4gICAqIHRoYXQgaXMsIHRoZSBgRmFpcnNoYXJlU2NoZWR1bGluZ1BvbGljeWAgaXMgaWdub3JlZC5cbiAgICovXG4gIHJlYWRvbmx5IHVubWFuYWdlZHZDUFVzPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYW4gVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50LiBCYXRjaCB3aWxsIG5vdCBwcm92aXNpb24gaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmXG4gKiBpbiB0aGlzIENvbXB1dGVFdmlyb25tZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFByb3BzIGV4dGVuZHMgQ29tcHV0ZUVudmlyb25tZW50UHJvcHMge1xuICAvKipcbiAgICogVGhlIHZDUFVzIHRoaXMgQ29tcHV0ZSBFbnZpcm9ubWVudCBwcm92aWRlcy4gVXNlZCBvbmx5IGJ5IHRoZVxuICAgKiBzY2hlZHVsZXIgdG8gc2NoZWR1bGUgam9icyBpbiBgUXVldWVgcyB0aGF0IHVzZSBgRmFpcnNoYXJlU2NoZWR1bGluZ1BvbGljeWBzLlxuICAgKlxuICAgKiAqKklmIHRoaXMgcGFyYW1ldGVyIGlzIG5vdCBwcm92aWRlZCBvbiBhIGZhaXJzaGFyZSBxdWV1ZSwgbm8gY2FwYWNpdHkgaXMgcmVzZXJ2ZWQqKjtcbiAgICogdGhhdCBpcywgdGhlIGBGYWlyc2hhcmVTY2hlZHVsaW5nUG9saWN5YCBpcyBpZ25vcmVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCAwXG4gICAqL1xuICByZWFkb25seSB1bm1hbmFnZWR2Q3B1cz86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBVbm1hbmFnZWQgQ29tcHV0ZUVudmlyb25tZW50cyBkbyBub3QgcHJvdmlzaW9uIG9yIG1hbmFnZSBFQzIgaW5zdGFuY2VzIG9uIHlvdXIgYmVoYWxmLlxuICpcbiAqIEByZXNvdXJjZSBBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnRcbiAqL1xuZXhwb3J0IGNsYXNzIFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudCBleHRlbmRzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgaW1wbGVtZW50cyBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgLyoqXG4gICAqIEltcG9ydCBhbiBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQgYnkgaXRzIGFyblxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBmcm9tVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50QXJuKFxuICAgIHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudEFybjogc3RyaW5nLFxuICApOiBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgICBjb25zdCBzdGFjayA9IFN0YWNrLm9mKHNjb3BlKTtcbiAgICBjb25zdCBjb21wdXRlRW52aXJvbm1lbnROYW1lID0gc3RhY2suc3BsaXRBcm4odW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50QXJuLCBBcm5Gb3JtYXQuU0xBU0hfUkVTT1VSQ0VfTkFNRSkucmVzb3VyY2VOYW1lITtcblxuICAgIGNsYXNzIEltcG9ydCBleHRlbmRzIENvbXB1dGVFbnZpcm9ubWVudEJhc2UgaW1wbGVtZW50cyBJVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IHtcbiAgICAgIHB1YmxpYyByZWFkb25seSBjb21wdXRlRW52aXJvbm1lbnRBcm4gPSB1bm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnRBcm47XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50TmFtZSA9IGNvbXB1dGVFbnZpcm9ubWVudE5hbWU7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgZW5hYmxlZCA9IHRydWU7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgY29udGFpbmVyRGVmaW5pdGlvbiA9IHt9IGFzIGFueTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IEltcG9ydChzY29wZSwgaWQpO1xuICB9XG5cbiAgcHVibGljIHJlYWRvbmx5IHVubWFuYWdlZHZDUFVzPzogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICBwdWJsaWMgcmVhZG9ubHkgY29tcHV0ZUVudmlyb25tZW50QXJuOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBjb21wdXRlRW52aXJvbm1lbnROYW1lOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM/OiBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuXG4gICAgdGhpcy51bm1hbmFnZWR2Q1BVcyA9IHByb3BzPy51bm1hbmFnZWR2Q3B1cztcbiAgICBjb25zdCByZXNvdXJjZSA9IG5ldyBDZm5Db21wdXRlRW52aXJvbm1lbnQodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgdHlwZTogJ3VubWFuYWdlZCcsXG4gICAgICBzdGF0ZTogdGhpcy5lbmFibGVkID8gJ0VOQUJMRUQnIDogJ0RJU0FCTEVEJyxcbiAgICAgIGNvbXB1dGVFbnZpcm9ubWVudE5hbWU6IHByb3BzPy5jb21wdXRlRW52aXJvbm1lbnROYW1lLFxuICAgICAgdW5tYW5hZ2VkdkNwdXM6IHRoaXMudW5tYW5hZ2VkdkNQVXMsXG4gICAgICBzZXJ2aWNlUm9sZTogcHJvcHM/LnNlcnZpY2VSb2xlPy5yb2xlQXJuXG4gICAgICA/PyBuZXcgUm9sZSh0aGlzLCAnQmF0Y2hTZXJ2aWNlUm9sZScsIHtcbiAgICAgICAgbWFuYWdlZFBvbGljaWVzOiBbXG4gICAgICAgICAgTWFuYWdlZFBvbGljeS5mcm9tQXdzTWFuYWdlZFBvbGljeU5hbWUoJ3NlcnZpY2Utcm9sZS9BV1NCYXRjaFNlcnZpY2VSb2xlJyksXG4gICAgICAgIF0sXG4gICAgICAgIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ2JhdGNoLmFtYXpvbmF3cy5jb20nKSxcbiAgICAgIH0pLnJvbGVBcm4sXG4gICAgfSk7XG4gICAgdGhpcy5jb21wdXRlRW52aXJvbm1lbnROYW1lID0gdGhpcy5nZXRSZXNvdXJjZU5hbWVBdHRyaWJ1dGUocmVzb3VyY2UucmVmKTtcbiAgICB0aGlzLmNvbXB1dGVFbnZpcm9ubWVudEFybiA9IHRoaXMuZ2V0UmVzb3VyY2VBcm5BdHRyaWJ1dGUocmVzb3VyY2UuYXR0ckNvbXB1dGVFbnZpcm9ubWVudEFybiwge1xuICAgICAgc2VydmljZTogJ2JhdGNoJyxcbiAgICAgIHJlc291cmNlOiAnY29tcHV0ZS1lbnZpcm9ubWVudCcsXG4gICAgICByZXNvdXJjZU5hbWU6IHRoaXMucGh5c2ljYWxOYW1lLFxuICAgIH0pO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js deleted file mode 100644 index 26f4d2b7fface..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-events-targets/batch.test.js +++ /dev/null @@ -1,294 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const batch = require("../../lib"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const assertions_1 = require("aws-cdk-lib/assertions"); -const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); -const events = require("aws-cdk-lib/aws-events"); -const targets = require("aws-cdk-lib/aws-events-targets"); -const sqs = require("aws-cdk-lib/aws-sqs"); -describe('Batch job event target', () => { - let stack; - let jobQueue; - let jobDefinition; - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - jobQueue = new batch.JobQueue(stack, 'MyQueue', { - computeEnvironments: [ - { - computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'), - order: 1, - }, - ], - }); - jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', { - container: new batch.EcsEc2ContainerDefinition(stack, 'container', { - image: aws_ecs_1.ContainerImage.fromRegistry('test-repo'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - }); - test('use aws batch job as an event rule target', () => { - // GIVEN - const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 min)'), - }); - // WHEN - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition)); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { - ScheduleExpression: 'rate(1 min)', - State: 'ENABLED', - Targets: [ - { - Arn: { - 'Fn::GetAtt': [ - 'MyQueueE6CA6235', - 'JobQueueArn', - ], - }, - Id: 'Target0', - RoleArn: { - 'Fn::GetAtt': [ - 'MyJobEventsRoleCF43C336', - 'Arn', - ], - }, - BatchParameters: { - JobDefinition: { - Ref: 'MyJob8719E923', - }, - JobName: 'Rule', - }, - }, - ], - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [ - { - Action: 'batch:SubmitJob', - Effect: 'Allow', - Resource: [ - { Ref: 'MyJob8719E923' }, - { - 'Fn::GetAtt': [ - 'MyQueueE6CA6235', - 'JobQueueArn', - ], - }, - ], - }, - ], - Version: '2012-10-17', - }, - Roles: [ - { Ref: 'MyJobEventsRoleCF43C336' }, - ], - }); - }); - test('use a Dead Letter Queue for the rule target', () => { - // GIVEN - const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 hour)'), - }); - const queue = new sqs.Queue(stack, 'Queue'); - // WHEN - const eventInput = { - buildspecOverride: 'buildspecs/hourly.yml', - }; - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { - deadLetterQueue: queue, - event: events.RuleTargetInput.fromObject(eventInput), - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { - Targets: [ - { - Arn: { - 'Fn::GetAtt': [ - 'MyQueueE6CA6235', - 'JobQueueArn', - ], - }, - Id: 'Target0', - DeadLetterConfig: { - Arn: { - 'Fn::GetAtt': [ - 'Queue4A7E3555', - 'Arn', - ], - }, - }, - Input: JSON.stringify(eventInput), - RoleArn: { - 'Fn::GetAtt': ['MyJobEventsRoleCF43C336', 'Arn'], - }, - BatchParameters: { - JobDefinition: { - Ref: 'MyJob8719E923', - }, - JobName: 'Rule', - }, - }, - ], - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::SQS::QueuePolicy', { - PolicyDocument: { - Statement: [ - { - Action: 'sqs:SendMessage', - Condition: { - ArnEquals: { - 'aws:SourceArn': { - 'Fn::GetAtt': [ - 'Rule4C995B7F', - 'Arn', - ], - }, - }, - }, - Effect: 'Allow', - Principal: { - Service: 'events.amazonaws.com', - }, - Resource: { - 'Fn::GetAtt': [ - 'Queue4A7E3555', - 'Arn', - ], - }, - Sid: 'AllowEventRuleRule', - }, - ], - Version: '2012-10-17', - }, - Queues: [ - { - Ref: 'Queue4A7E3555', - }, - ], - }); - }); - test('specifying retry policy', () => { - // GIVEN - const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 hour)'), - }); - const queue = new sqs.Queue(stack, 'Queue'); - // WHEN - const eventInput = { - buildspecOverride: 'buildspecs/hourly.yml', - }; - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { - deadLetterQueue: queue, - event: events.RuleTargetInput.fromObject(eventInput), - retryAttempts: 2, - maxEventAge: aws_cdk_lib_1.Duration.hours(2), - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { - ScheduleExpression: 'rate(1 hour)', - State: 'ENABLED', - Targets: [ - { - Arn: { - 'Fn::GetAtt': [ - 'MyQueueE6CA6235', - 'JobQueueArn', - ], - }, - BatchParameters: { - JobDefinition: { - Ref: 'MyJob8719E923', - }, - JobName: 'Rule', - }, - DeadLetterConfig: { - Arn: { - 'Fn::GetAtt': [ - 'Queue4A7E3555', - 'Arn', - ], - }, - }, - Id: 'Target0', - Input: JSON.stringify(eventInput), - RetryPolicy: { - MaximumEventAgeInSeconds: 7200, - MaximumRetryAttempts: 2, - }, - RoleArn: { - 'Fn::GetAtt': [ - 'MyJobEventsRoleCF43C336', - 'Arn', - ], - }, - }, - ], - }); - }); - test('specifying retry policy with 0 retryAttempts', () => { - // GIVEN - const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 hour)'), - }); - // WHEN - const eventInput = { - buildspecOverride: 'buildspecs/hourly.yml', - }; - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { - event: events.RuleTargetInput.fromObject(eventInput), - retryAttempts: 0, - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', { - ScheduleExpression: 'rate(1 hour)', - State: 'ENABLED', - Targets: [ - { - Arn: { - 'Fn::GetAtt': [ - 'MyQueueE6CA6235', - 'JobQueueArn', - ], - }, - BatchParameters: { - JobDefinition: { - Ref: 'MyJob8719E923', - }, - JobName: 'Rule', - }, - Id: 'Target0', - Input: JSON.stringify(eventInput), - RetryPolicy: { - MaximumRetryAttempts: 0, - }, - RoleArn: { - 'Fn::GetAtt': [ - 'MyJobEventsRoleCF43C336', - 'Arn', - ], - }, - }, - ], - }); - }); - test('should validate jobName minimum and maximum length', () => { - const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 min)'), - }); - expect(() => { - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { - jobName: '', - })); - }).toThrowError(/must have length between 1 and 128/); - expect(() => { - rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition, { - jobName: 'a'.repeat(200), - })); - }).toThrowError(/must have length between 1 and 128/); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"batch.test.js","sourceRoot":"","sources":["batch.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as batch from '../../lib';\nimport { Duration, Size, Stack } from 'aws-cdk-lib';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport { ContainerImage } from 'aws-cdk-lib/aws-ecs';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as sqs from 'aws-cdk-lib/aws-sqs';\n\ndescribe('Batch job event target', () => {\n  let stack: Stack;\n  let jobQueue: batch.IJobQueue;\n  let jobDefinition: batch.IJobDefinition;\n\n  beforeEach(() => {\n    stack = new Stack();\n    jobQueue = new batch.JobQueue(stack, 'MyQueue', {\n      computeEnvironments: [\n        {\n          computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'),\n          order: 1,\n        },\n      ],\n    });\n    jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', {\n      container: new batch.EcsEc2ContainerDefinition(stack, 'container', {\n        image: ContainerImage.fromRegistry('test-repo'),\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n      }),\n    });\n  });\n\n  test('use aws batch job as an event rule target', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 min)'),\n    });\n\n    // WHEN\n    rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 min)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          Id: 'Target0',\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n        },\n      ],\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: 'batch:SubmitJob',\n            Effect: 'Allow',\n            Resource: [\n              { Ref: 'MyJob8719E923' },\n              {\n                'Fn::GetAtt': [\n                  'MyQueueE6CA6235',\n                  'JobQueueArn',\n                ],\n              },\n            ],\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      Roles: [\n        { Ref: 'MyJobEventsRoleCF43C336' },\n      ],\n    });\n  });\n\n  test('use a Dead Letter Queue for the rule target', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    const queue = new sqs.Queue(stack, 'Queue');\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        deadLetterQueue: queue,\n        event: events.RuleTargetInput.fromObject(eventInput),\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          Id: 'Target0',\n          DeadLetterConfig: {\n            Arn: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n          },\n          Input: JSON.stringify(eventInput),\n          RoleArn: {\n            'Fn::GetAtt': ['MyJobEventsRoleCF43C336', 'Arn'],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n        },\n      ],\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::SQS::QueuePolicy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: 'sqs:SendMessage',\n            Condition: {\n              ArnEquals: {\n                'aws:SourceArn': {\n                  'Fn::GetAtt': [\n                    'Rule4C995B7F',\n                    'Arn',\n                  ],\n                },\n              },\n            },\n            Effect: 'Allow',\n            Principal: {\n              Service: 'events.amazonaws.com',\n            },\n            Resource: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n            Sid: 'AllowEventRuleRule',\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      Queues: [\n        {\n          Ref: 'Queue4A7E3555',\n        },\n      ],\n    });\n  });\n\n  test('specifying retry policy', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    const queue = new sqs.Queue(stack, 'Queue');\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        deadLetterQueue: queue,\n        event: events.RuleTargetInput.fromObject(eventInput),\n        retryAttempts: 2,\n        maxEventAge: Duration.hours(2),\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 hour)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n          DeadLetterConfig: {\n            Arn: {\n              'Fn::GetAtt': [\n                'Queue4A7E3555',\n                'Arn',\n              ],\n            },\n          },\n          Id: 'Target0',\n          Input: JSON.stringify(eventInput),\n          RetryPolicy: {\n            MaximumEventAgeInSeconds: 7200,\n            MaximumRetryAttempts: 2,\n          },\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n        },\n      ],\n    });\n  });\n\n  test('specifying retry policy with 0 retryAttempts', () => {\n    // GIVEN\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 hour)'),\n    });\n\n    // WHEN\n    const eventInput = {\n      buildspecOverride: 'buildspecs/hourly.yml',\n    };\n\n    rule.addTarget(new targets.BatchJob(\n      jobQueue.jobQueueArn,\n      jobQueue,\n      jobDefinition.jobDefinitionArn,\n      jobDefinition, {\n        event: events.RuleTargetInput.fromObject(eventInput),\n        retryAttempts: 0,\n      },\n    ));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Events::Rule', {\n      ScheduleExpression: 'rate(1 hour)',\n      State: 'ENABLED',\n      Targets: [\n        {\n          Arn: {\n            'Fn::GetAtt': [\n              'MyQueueE6CA6235',\n              'JobQueueArn',\n            ],\n          },\n          BatchParameters: {\n            JobDefinition: {\n              Ref: 'MyJob8719E923',\n            },\n            JobName: 'Rule',\n          },\n          Id: 'Target0',\n          Input: JSON.stringify(eventInput),\n          RetryPolicy: {\n            MaximumRetryAttempts: 0,\n          },\n          RoleArn: {\n            'Fn::GetAtt': [\n              'MyJobEventsRoleCF43C336',\n              'Arn',\n            ],\n          },\n        },\n      ],\n    });\n  });\n\n  test('should validate jobName minimum and maximum length', () => {\n    const rule = new events.Rule(stack, 'Rule', {\n      schedule: events.Schedule.expression('rate(1 min)'),\n    });\n\n    expect(() => {\n      rule.addTarget(\n        new targets.BatchJob(\n          jobQueue.jobQueueArn,\n          jobQueue,\n          jobDefinition.jobDefinitionArn,\n          jobDefinition,\n          {\n            jobName: '',\n          },\n        ),\n      );\n    }).toThrowError(/must have length between 1 and 128/);\n    expect(() => {\n      rule.addTarget(\n        new targets.BatchJob(\n          jobQueue.jobQueueArn,\n          jobQueue,\n          jobDefinition.jobDefinitionArn,\n          jobDefinition,\n          {\n            jobName: 'a'.repeat(200),\n          },\n        ),\n      );\n    }).toThrowError(/must have length between 1 and 128/);\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js deleted file mode 100644 index 0ed0f7a77b1ed..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/run-batch-job.test.js +++ /dev/null @@ -1,286 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const path = require("path"); -const batch = require("../../lib"); -const cdk_build_tools_1 = require("@aws-cdk/cdk-build-tools"); -const cdk = require("aws-cdk-lib"); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const sfn = require("aws-cdk-lib/aws-stepfunctions"); -const tasks = require("aws-cdk-lib/aws-stepfunctions-tasks"); -let stack; -let batchJobDefinition; -let batchJobQueue; -beforeEach(() => { - // GIVEN - stack = new cdk.Stack(); - batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', { - container: new batch.EcsEc2ContainerDefinition(stack, 'Container', { - image: ecs.ContainerImage.fromAsset(path.join(__dirname, '../batchjob-image')), - cpu: 256, - memory: cdk.Size.mebibytes(2048), - }), - }); - batchJobQueue = new batch.JobQueue(stack, 'JobQueue', { - computeEnvironments: [ - { - order: 1, - computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', { - vpc: new ec2.Vpc(stack, 'vpc'), - }), - }, - ], - }); -}); -(0, cdk_build_tools_1.describeDeprecated)('RunBatchJob', () => { - test('Task with only the required parameters', () => { - // WHEN - const task = new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - }), - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, - JobName: 'JobName', - JobQueue: { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - }, - }); - }); - test('Task with all the parameters', () => { - // WHEN - const task = new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 15, - containerOverrides: { - command: ['sudo', 'rm'], - environment: { key: 'value' }, - instanceType: new ec2.InstanceType('MULTI'), - memory: 1024, - gpuCount: 1, - vcpus: 10, - }, - dependsOn: [{ jobId: '1234', type: 'some_type' }], - payload: { - foo: sfn.JsonPath.stringAt('$.bar'), - }, - attempts: 3, - timeout: cdk.Duration.seconds(60), - integrationPattern: sfn.ServiceIntegrationPattern.FIRE_AND_FORGET, - }), - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob', - ], - ], - }, - End: true, - Parameters: { - JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, - JobName: 'JobName', - JobQueue: { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - ArrayProperties: { Size: 15 }, - ContainerOverrides: { - Command: ['sudo', 'rm'], - Environment: [{ Name: 'key', Value: 'value' }], - InstanceType: 'MULTI', - Memory: 1024, - ResourceRequirements: [{ Type: 'GPU', Value: '1' }], - Vcpus: 10, - }, - DependsOn: [{ JobId: '1234', Type: 'some_type' }], - Parameters: { 'foo.$': '$.bar' }, - RetryStrategy: { Attempts: 3 }, - Timeout: { AttemptDurationSeconds: 60 }, - }, - }); - }); - test('supports tokens', () => { - // WHEN - const task = new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobQueueArn: batchJobQueue.jobQueueArn, - jobName: sfn.JsonPath.stringAt('$.jobName'), - arraySize: sfn.JsonPath.numberAt('$.arraySize'), - timeout: cdk.Duration.seconds(sfn.JsonPath.numberAt('$.timeout')), - attempts: sfn.JsonPath.numberAt('$.attempts'), - }), - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, - 'JobName.$': '$.jobName', - 'JobQueue': { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - 'ArrayProperties': { - 'Size.$': '$.arraySize', - }, - 'RetryStrategy': { - 'Attempts.$': '$.attempts', - }, - 'Timeout': { - 'AttemptDurationSeconds.$': '$.timeout', - }, - }, - }); - }); - test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - integrationPattern: sfn.ServiceIntegrationPattern.WAIT_FOR_TASK_TOKEN, - }), - }); - }).toThrow(/Invalid Service Integration Pattern: WAIT_FOR_TASK_TOKEN is not supported to call RunBatchJob./i); - }); - test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - containerOverrides: { - environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' }, - }, - }), - }); - }).toThrow(/Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./i); - }); - test('Task throws if arraySize is out of limits 2-10000', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 1, - }), - }); - }).toThrow(/arraySize must be between 2 and 10,000/); - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 10001, - }), - }); - }).toThrow(/arraySize must be between 2 and 10,000/); - }); - test('Task throws if dependencies exceeds 20', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - dependsOn: [...Array(21).keys()].map(i => ({ - jobId: `${i}`, - type: `some_type-${i}`, - })), - }), - }); - }).toThrow(/dependencies must be 20 or less/); - }); - test('Task throws if attempts is out of limits 1-10', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - attempts: 0, - }), - }); - }).toThrow(/attempts must be between 1 and 10/); - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - attempts: 11, - }), - }); - }).toThrow(/attempts must be between 1 and 10/); - }); - test('Task throws if timeout is less than 60 sec', () => { - expect(() => { - new sfn.Task(stack, 'Task', { - task: new tasks.RunBatchJob({ - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - timeout: cdk.Duration.seconds(59), - }), - }); - }).toThrow(/timeout must be greater than 60 seconds/); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-batch-job.test.js","sourceRoot":"","sources":["run-batch-job.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as batch from '../../lib';\nimport { describeDeprecated } from '@aws-cdk/cdk-build-tools';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\n\nlet stack: cdk.Stack;\nlet batchJobDefinition: batch.IJobDefinition;\nlet batchJobQueue: batch.IJobQueue;\n\nbeforeEach(() => {\n  // GIVEN\n  stack = new cdk.Stack();\n\n  batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', {\n    container: new batch.EcsEc2ContainerDefinition(stack, 'Container', {\n      image: ecs.ContainerImage.fromAsset(\n        path.join(__dirname, '../batchjob-image'),\n      ),\n      cpu: 256,\n      memory: cdk.Size.mebibytes(2048),\n    }),\n  });\n\n  batchJobQueue = new batch.JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [\n      {\n        order: 1,\n        computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', {\n          vpc: new ec2.Vpc(stack, 'vpc'),\n        }),\n      },\n    ],\n  });\n});\n\ndescribeDeprecated('RunBatchJob', () => {\n  test('Task with only the required parameters', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobName: 'JobName',\n        jobQueueArn: batchJobQueue.jobQueueArn,\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob.sync',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n        JobName: 'JobName',\n        JobQueue: {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n      },\n    });\n  });\n\n  test('Task with all the parameters', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobName: 'JobName',\n        jobQueueArn: batchJobQueue.jobQueueArn,\n        arraySize: 15,\n        containerOverrides: {\n          command: ['sudo', 'rm'],\n          environment: { key: 'value' },\n          instanceType: new ec2.InstanceType('MULTI'),\n          memory: 1024,\n          gpuCount: 1,\n          vcpus: 10,\n        },\n        dependsOn: [{ jobId: '1234', type: 'some_type' }],\n        payload: {\n          foo: sfn.JsonPath.stringAt('$.bar'),\n        },\n        attempts: 3,\n        timeout: cdk.Duration.seconds(60),\n        integrationPattern: sfn.ServiceIntegrationPattern.FIRE_AND_FORGET,\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n        JobName: 'JobName',\n        JobQueue: {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n        ArrayProperties: { Size: 15 },\n        ContainerOverrides: {\n          Command: ['sudo', 'rm'],\n          Environment: [{ Name: 'key', Value: 'value' }],\n          InstanceType: 'MULTI',\n          Memory: 1024,\n          ResourceRequirements: [{ Type: 'GPU', Value: '1' }],\n          Vcpus: 10,\n        },\n        DependsOn: [{ JobId: '1234', Type: 'some_type' }],\n        Parameters: { 'foo.$': '$.bar' },\n        RetryStrategy: { Attempts: 3 },\n        Timeout: { AttemptDurationSeconds: 60 },\n      },\n    });\n  });\n\n  test('supports tokens', () => {\n  // WHEN\n    const task = new sfn.Task(stack, 'Task', {\n      task: new tasks.RunBatchJob({\n        jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n        jobQueueArn: batchJobQueue.jobQueueArn,\n        jobName: sfn.JsonPath.stringAt('$.jobName'),\n        arraySize: sfn.JsonPath.numberAt('$.arraySize'),\n        timeout: cdk.Duration.seconds(sfn.JsonPath.numberAt('$.timeout')),\n        attempts: sfn.JsonPath.numberAt('$.attempts'),\n      }),\n    });\n\n    // THEN\n    expect(stack.resolve(task.toStateJson())).toEqual({\n      Type: 'Task',\n      Resource: {\n        'Fn::Join': [\n          '',\n          [\n            'arn:',\n            {\n              Ref: 'AWS::Partition',\n            },\n            ':states:::batch:submitJob.sync',\n          ],\n        ],\n      },\n      End: true,\n      Parameters: {\n        'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n        'JobName.$': '$.jobName',\n        'JobQueue': {\n          'Fn::GetAtt': [\n            'JobQueueEE3AD499',\n            'JobQueueArn',\n          ],\n        },\n        'ArrayProperties': {\n          'Size.$': '$.arraySize',\n        },\n        'RetryStrategy': {\n          'Attempts.$': '$.attempts',\n        },\n        'Timeout': {\n          'AttemptDurationSeconds.$': '$.timeout',\n        },\n      },\n    });\n  });\n\n  test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          integrationPattern: sfn.ServiceIntegrationPattern.WAIT_FOR_TASK_TOKEN,\n        }),\n      });\n    }).toThrow(\n      /Invalid Service Integration Pattern: WAIT_FOR_TASK_TOKEN is not supported to call RunBatchJob./i,\n    );\n  });\n\n  test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          containerOverrides: {\n            environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' },\n          },\n        }),\n      });\n    }).toThrow(\n      /Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./i,\n    );\n  });\n\n  test('Task throws if arraySize is out of limits 2-10000', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          arraySize: 1,\n        }),\n      });\n    }).toThrow(\n      /arraySize must be between 2 and 10,000/,\n    );\n\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          arraySize: 10001,\n        }),\n      });\n    }).toThrow(\n      /arraySize must be between 2 and 10,000/,\n    );\n  });\n\n  test('Task throws if dependencies exceeds 20', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          dependsOn: [...Array(21).keys()].map(i => ({\n            jobId: `${i}`,\n            type: `some_type-${i}`,\n          })),\n        }),\n      });\n    }).toThrow(\n      /dependencies must be 20 or less/,\n    );\n  });\n\n  test('Task throws if attempts is out of limits 1-10', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          attempts: 0,\n        }),\n      });\n    }).toThrow(\n      /attempts must be between 1 and 10/,\n    );\n\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          attempts: 11,\n        }),\n      });\n    }).toThrow(\n      /attempts must be between 1 and 10/,\n    );\n  });\n\n  test('Task throws if timeout is less than 60 sec', () => {\n    expect(() => {\n      new sfn.Task(stack, 'Task', {\n        task: new tasks.RunBatchJob({\n          jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n          jobName: 'JobName',\n          jobQueueArn: batchJobQueue.jobQueueArn,\n          timeout: cdk.Duration.seconds(59),\n        }),\n      });\n    }).toThrow(\n      /timeout must be greater than 60 seconds/,\n    );\n  });\n});"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js b/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js deleted file mode 100644 index 8387351204073..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/aws-stepfunctions-tasks/submit-job.test.js +++ /dev/null @@ -1,401 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const path = require("path"); -const batch = require("../../lib"); -const cdk = require("aws-cdk-lib"); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const sfn = require("aws-cdk-lib/aws-stepfunctions"); -const aws_stepfunctions_tasks_1 = require("aws-cdk-lib/aws-stepfunctions-tasks"); -let stack; -let batchJobDefinition; -let batchJobQueue; -beforeEach(() => { - // GIVEN - stack = new cdk.Stack(); - batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', { - container: new batch.EcsEc2ContainerDefinition(stack, 'Container', { - image: ecs.ContainerImage.fromAsset(path.join(__dirname, '../batchjob-image')), - cpu: 256, - memory: cdk.Size.mebibytes(2048), - }), - }); - batchJobQueue = new batch.JobQueue(stack, 'JobQueue', { - computeEnvironments: [ - { - order: 1, - computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', { - vpc: new ec2.Vpc(stack, 'vpc'), - }), - }, - ], - }); -}); -test('Task with only the required parameters', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, - JobName: 'JobName', - JobQueue: { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - }, - }); -}); -test('Task with all the parameters', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 15, - containerOverrides: { - command: ['sudo', 'rm'], - environment: { key: 'value' }, - instanceType: new ec2.InstanceType('MULTI'), - memory: cdk.Size.mebibytes(1024), - gpuCount: 1, - vcpus: 10, - }, - dependsOn: [{ jobId: '1234', type: 'some_type' }], - payload: sfn.TaskInput.fromObject({ - foo: sfn.JsonPath.stringAt('$.bar'), - }), - attempts: 3, - taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(60)), - integrationPattern: sfn.IntegrationPattern.REQUEST_RESPONSE, - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob', - ], - ], - }, - End: true, - Parameters: { - JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, - JobName: 'JobName', - JobQueue: { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - ArrayProperties: { Size: 15 }, - ContainerOverrides: { - Command: ['sudo', 'rm'], - Environment: [{ Name: 'key', Value: 'value' }], - InstanceType: 'MULTI', - ResourceRequirements: [{ Type: 'GPU', Value: '1' }, { Type: 'MEMORY', Value: '1024' }, { Type: 'VCPU', Value: '10' }], - }, - DependsOn: [{ JobId: '1234', Type: 'some_type' }], - Parameters: { 'foo.$': '$.bar' }, - RetryStrategy: { Attempts: 3 }, - Timeout: { AttemptDurationSeconds: 60 }, - }, - }); -}); -test('supports tokens', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobName: sfn.JsonPath.stringAt('$.jobName'), - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: sfn.JsonPath.numberAt('$.arraySize'), - taskTimeout: sfn.Timeout.at('$.timeout'), - attempts: sfn.JsonPath.numberAt('$.attempts'), - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, - 'JobName.$': '$.jobName', - 'JobQueue': { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - 'ArrayProperties': { - 'Size.$': '$.arraySize', - }, - 'RetryStrategy': { - 'Attempts.$': '$.attempts', - }, - 'Timeout': { - 'AttemptDurationSeconds.$': '$.timeout', - }, - }, - }); -}); -test('container overrides are tokens', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - containerOverrides: { - memory: cdk.Size.mebibytes(sfn.JsonPath.numberAt('$.asdf')), - }, - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':states:::batch:submitJob.sync']] }, - End: true, - Parameters: { - JobDefinition: { Ref: 'JobDefinition24FFE3ED' }, - JobName: 'JobName', - JobQueue: { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - ContainerOverrides: { - ResourceRequirements: [{ 'Type': 'MEMORY', 'Value.$': '$.asdf' }], - }, - }, - }); -}); -test('supports passing task input into payload', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobQueueArn: batchJobQueue.jobQueueArn, - jobName: sfn.JsonPath.stringAt('$.jobName'), - payload: sfn.TaskInput.fromJsonPathAt('$.foo'), - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, - 'JobName.$': '$.jobName', - 'JobQueue': { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - 'Parameters.$': '$.foo', - }, - }); -}); -test('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN, - }); - }).toThrow(/Unsupported service integration pattern. Supported Patterns: REQUEST_RESPONSE,RUN_JOB. Received: WAIT_FOR_TASK_TOKEN/); -}); -test('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - containerOverrides: { - environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' }, - }, - }); - }).toThrow(/Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./); -}); -test('Task throws if arraySize is out of limits 2-10000', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 1, - }); - }).toThrow(/arraySize must be between 2 and 10,000/); - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - arraySize: 10001, - }); - }).toThrow(/arraySize must be between 2 and 10,000/); -}); -test('Task throws if dependencies exceeds 20', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - dependsOn: [...Array(21).keys()].map(i => ({ - jobId: `${i}`, - type: `some_type-${i}`, - })), - }); - }).toThrow(/dependencies must be 20 or less/); -}); -test('Task throws if attempts is out of limits 1-10', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - attempts: 0, - }); - }).toThrow(/attempts must be between 1 and 10/); - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - attempts: 11, - }); - }).toThrow(/attempts must be between 1 and 10/); -}); -test('Task throws if attempt duration is less than 60 sec', () => { - expect(() => { - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(59)), - }); - }).toThrow(/attempt duration must be greater than 60 seconds./); -}); -test('supports passing tags', () => { - // WHEN - const task = new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobQueueArn: batchJobQueue.jobQueueArn, - jobName: sfn.JsonPath.stringAt('$.jobName'), - tags: { - test: 'this is a tag', - }, - }); - // THEN - expect(stack.resolve(task.toStateJson())).toEqual({ - Type: 'Task', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':states:::batch:submitJob.sync', - ], - ], - }, - End: true, - Parameters: { - 'JobDefinition': { Ref: 'JobDefinition24FFE3ED' }, - 'JobName.$': '$.jobName', - 'JobQueue': { - 'Fn::GetAtt': [ - 'JobQueueEE3AD499', - 'JobQueueArn', - ], - }, - 'Tags': { - test: 'this is a tag', - }, - }, - }); -}); -test('throws if tags has invalid value', () => { - expect(() => { - const tags = {}; - for (let i = 0; i < 100; i++) { - tags[i] = 'tag'; - } - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task1', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - tags, - }); - }).toThrow(/Maximum tag number of entries is 50./); - expect(() => { - const keyTooLong = 'k'.repeat(150); - const tags = {}; - tags[keyTooLong] = 'tag'; - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task2', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - tags, - }); - }).toThrow(/Tag key size must be between 1 and 128/); - expect(() => { - const tags = { key: 'k'.repeat(300) }; - new aws_stepfunctions_tasks_1.BatchSubmitJob(stack, 'Task3', { - jobDefinitionArn: batchJobDefinition.jobDefinitionArn, - jobName: 'JobName', - jobQueueArn: batchJobQueue.jobQueueArn, - tags, - }); - }).toThrow(/Tag value maximum size is 256/); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"submit-job.test.js","sourceRoot":"","sources":["submit-job.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as batch from '../../lib';\nimport * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport { BatchSubmitJob } from 'aws-cdk-lib/aws-stepfunctions-tasks';\n\nlet stack: cdk.Stack;\nlet batchJobDefinition: batch.IJobDefinition;\nlet batchJobQueue: batch.IJobQueue;\n\nbeforeEach(() => {\n  // GIVEN\n  stack = new cdk.Stack();\n\n  batchJobDefinition = new batch.EcsJobDefinition(stack, 'JobDefinition', {\n    container: new batch.EcsEc2ContainerDefinition(stack, 'Container', {\n      image: ecs.ContainerImage.fromAsset(\n        path.join(__dirname, '../batchjob-image'),\n      ),\n      cpu: 256,\n      memory: cdk.Size.mebibytes(2048),\n    }),\n  });\n\n  batchJobQueue = new batch.JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [\n      {\n        order: 1,\n        computeEnvironment: new batch.ManagedEc2EcsComputeEnvironment(stack, 'ComputeEnv', {\n          vpc: new ec2.Vpc(stack, 'vpc'),\n        }),\n      },\n    ],\n  });\n});\n\ntest('Task with only the required parameters', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n    },\n  });\n});\n\ntest('Task with all the parameters', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    arraySize: 15,\n    containerOverrides: {\n      command: ['sudo', 'rm'],\n      environment: { key: 'value' },\n      instanceType: new ec2.InstanceType('MULTI'),\n      memory: cdk.Size.mebibytes(1024),\n      gpuCount: 1,\n      vcpus: 10,\n    },\n    dependsOn: [{ jobId: '1234', type: 'some_type' }],\n    payload: sfn.TaskInput.fromObject({\n      foo: sfn.JsonPath.stringAt('$.bar'),\n    }),\n    attempts: 3,\n    taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(60)),\n    integrationPattern: sfn.IntegrationPattern.REQUEST_RESPONSE,\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      ArrayProperties: { Size: 15 },\n      ContainerOverrides: {\n        Command: ['sudo', 'rm'],\n        Environment: [{ Name: 'key', Value: 'value' }],\n        InstanceType: 'MULTI',\n        ResourceRequirements: [{ Type: 'GPU', Value: '1' }, { Type: 'MEMORY', Value: '1024' }, { Type: 'VCPU', Value: '10' }],\n      },\n      DependsOn: [{ JobId: '1234', Type: 'some_type' }],\n      Parameters: { 'foo.$': '$.bar' },\n      RetryStrategy: { Attempts: 3 },\n      Timeout: { AttemptDurationSeconds: 60 },\n    },\n  });\n});\n\ntest('supports tokens', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    arraySize: sfn.JsonPath.numberAt('$.arraySize'),\n    taskTimeout: sfn.Timeout.at('$.timeout'),\n    attempts: sfn.JsonPath.numberAt('$.attempts'),\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'ArrayProperties': {\n        'Size.$': '$.arraySize',\n      },\n      'RetryStrategy': {\n        'Attempts.$': '$.attempts',\n      },\n      'Timeout': {\n        'AttemptDurationSeconds.$': '$.timeout',\n      },\n    },\n  });\n});\n\ntest('container overrides are tokens', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobName: 'JobName',\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    containerOverrides: {\n      memory: cdk.Size.mebibytes(sfn.JsonPath.numberAt('$.asdf')),\n    },\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':states:::batch:submitJob.sync']] },\n    End: true,\n    Parameters: {\n      JobDefinition: { Ref: 'JobDefinition24FFE3ED' },\n      JobName: 'JobName',\n      JobQueue: {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      ContainerOverrides: {\n        ResourceRequirements: [{ 'Type': 'MEMORY', 'Value.$': '$.asdf' }],\n      },\n    },\n  });\n});\n\ntest('supports passing task input into payload', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    payload: sfn.TaskInput.fromJsonPathAt('$.foo'),\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'Parameters.$': '$.foo',\n    },\n  });\n});\n\ntest('Task throws if WAIT_FOR_TASK_TOKEN is supplied as service integration pattern', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN,\n    });\n  }).toThrow(\n    /Unsupported service integration pattern. Supported Patterns: REQUEST_RESPONSE,RUN_JOB. Received: WAIT_FOR_TASK_TOKEN/,\n  );\n});\n\ntest('Task throws if environment in containerOverrides contain env with name starting with AWS_BATCH', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      containerOverrides: {\n        environment: { AWS_BATCH_MY_NAME: 'MY_VALUE' },\n      },\n    });\n  }).toThrow(\n    /Invalid environment variable name: AWS_BATCH_MY_NAME. Environment variable names starting with 'AWS_BATCH' are reserved./,\n  );\n});\n\ntest('Task throws if arraySize is out of limits 2-10000', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      arraySize: 1,\n    });\n  }).toThrow(\n    /arraySize must be between 2 and 10,000/,\n  );\n\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      arraySize: 10001,\n    });\n  }).toThrow(\n    /arraySize must be between 2 and 10,000/,\n  );\n});\n\ntest('Task throws if dependencies exceeds 20', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      dependsOn: [...Array(21).keys()].map(i => ({\n        jobId: `${i}`,\n        type: `some_type-${i}`,\n      })),\n    });\n  }).toThrow(\n    /dependencies must be 20 or less/,\n  );\n});\n\ntest('Task throws if attempts is out of limits 1-10', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      attempts: 0,\n    });\n  }).toThrow(\n    /attempts must be between 1 and 10/,\n  );\n\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      attempts: 11,\n    });\n  }).toThrow(\n    /attempts must be between 1 and 10/,\n  );\n});\n\ntest('Task throws if attempt duration is less than 60 sec', () => {\n  expect(() => {\n    new BatchSubmitJob(stack, 'Task', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      taskTimeout: sfn.Timeout.duration(cdk.Duration.seconds(59)),\n    });\n  }).toThrow(\n    /attempt duration must be greater than 60 seconds./,\n  );\n});\n\ntest('supports passing tags', () => {\n  // WHEN\n  const task = new BatchSubmitJob(stack, 'Task', {\n    jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n    jobQueueArn: batchJobQueue.jobQueueArn,\n    jobName: sfn.JsonPath.stringAt('$.jobName'),\n    tags: {\n      test: 'this is a tag',\n    },\n  });\n\n  // THEN\n  expect(stack.resolve(task.toStateJson())).toEqual({\n    Type: 'Task',\n    Resource: {\n      'Fn::Join': [\n        '',\n        [\n          'arn:',\n          {\n            Ref: 'AWS::Partition',\n          },\n          ':states:::batch:submitJob.sync',\n        ],\n      ],\n    },\n    End: true,\n    Parameters: {\n      'JobDefinition': { Ref: 'JobDefinition24FFE3ED' },\n      'JobName.$': '$.jobName',\n      'JobQueue': {\n        'Fn::GetAtt': [\n          'JobQueueEE3AD499',\n          'JobQueueArn',\n        ],\n      },\n      'Tags': {\n        test: 'this is a tag',\n      },\n    },\n  });\n});\n\ntest('throws if tags has invalid value', () => {\n  expect(() => {\n    const tags: { [key: string]: string } = {};\n    for (let i = 0; i < 100; i++) {\n      tags[i] = 'tag';\n    }\n    new BatchSubmitJob(stack, 'Task1', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Maximum tag number of entries is 50./,\n  );\n\n  expect(() => {\n    const keyTooLong = 'k'.repeat(150);\n    const tags: { [key: string]: string } = {};\n    tags[keyTooLong] = 'tag';\n    new BatchSubmitJob(stack, 'Task2', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Tag key size must be between 1 and 128/,\n  );\n\n  expect(() => {\n    const tags = { key: 'k'.repeat(300) };\n    new BatchSubmitJob(stack, 'Task3', {\n      jobDefinitionArn: batchJobDefinition.jobDefinitionArn,\n      jobName: 'JobName',\n      jobQueueArn: batchJobQueue.jobQueueArn,\n      tags,\n    });\n  }).toThrow(\n    /Tag value maximum size is 256/,\n  );\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js deleted file mode 100644 index d49b37fb9a85a..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/ecs-container-definition.test.js +++ /dev/null @@ -1,998 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const path = require("path"); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const ecr = require("aws-cdk-lib/aws-ecr"); -const efs = require("aws-cdk-lib/aws-efs"); -const ssm = require("aws-cdk-lib/aws-ssm"); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const logs = require("aws-cdk-lib/aws-logs"); -const secretsmanager = require("aws-cdk-lib/aws-secretsmanager"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const cdk = require("aws-cdk-lib"); -const lib_1 = require("../lib"); -const utils_1 = require("./utils"); -const aws_ecr_assets_1 = require("aws-cdk-lib/aws-ecr-assets"); -// GIVEN -const defaultContainerProps = { - cpu: 256, - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - memory: aws_cdk_lib_1.Size.mebibytes(2048), -}; -const defaultExpectedProps = { - type: 'container', - containerProperties: { - image: 'amazon/amazon-ecs-sample', - resourceRequirements: [ - { - type: 'MEMORY', - value: '2048', - }, - { - type: 'VCPU', - value: '256', - }, - ], - }, -}; -let stack; -let pascalCaseExpectedProps; -describe.each([lib_1.EcsEc2ContainerDefinition, lib_1.EcsFargateContainerDefinition])('%p', (ContainerDefinition) => { - // GIVEN - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { - ...defaultExpectedProps, - containerProperties: { - ...defaultExpectedProps.containerProperties, - executionRoleArn: { - 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], - }, - }, - }); - }); - test('ecs container defaults', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ExecutionRoleArn: { - 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], - }, - ...pascalCaseExpectedProps.ContainerProperties, - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - AssumeRolePolicyDocument: { - Statement: [ - { - Action: 'sts:AssumeRole', - Effect: 'Allow', - Principal: { Service: 'ecs-tasks.amazonaws.com' }, - }, - ], - Version: '2012-10-17', - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [ - { - Action: [ - 'logs:CreateLogStream', - 'logs:PutLogEvents', - ], - Effect: 'Allow', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { Ref: 'AWS::Partition' }, - ':logs:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':log-group:/aws/batch/job:*', - ], - ], - }, - }, - ], - Version: '2012-10-17', - }, - PolicyName: 'EcsContainerExecutionRoleDefaultPolicy6F59CD37', - Roles: [{ - Ref: 'EcsContainerExecutionRole3B199293', - }], - }); - }); - test('respects command', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - command: ['echo', 'foo'], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Command: ['echo', 'foo'], - }, - }); - }); - test('respects environment', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - privileged: true, - environment: { - foo: 'bar', - }, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Environment: [{ - Name: 'foo', - Value: 'bar', - }], - }, - }); - }); - test('respects executionRole', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - privileged: true, - executionRole: new aws_iam_1.Role(stack, 'execRole', { - assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:user/user-name'), - }), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ExecutionRoleArn: { - 'Fn::GetAtt': ['execRole623CB63A', 'Arn'], - }, - }, - }); - }); - test('respects jobRole', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - privileged: true, - jobRole: new aws_iam_1.Role(stack, 'jobRole', { - assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:user/user-name'), - }), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - JobRoleArn: { - 'Fn::GetAtt': ['jobRoleA2173686', 'Arn'], - }, - }, - }); - }); - test('respects linuxParameters', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - privileged: true, - linuxParameters: new lib_1.LinuxParameters(stack, 'linuxParameters', { - initProcessEnabled: true, - maxSwap: aws_cdk_lib_1.Size.kibibytes(4096), - sharedMemorySize: aws_cdk_lib_1.Size.mebibytes(256), - swappiness: 30, - }), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - LinuxParameters: { - InitProcessEnabled: true, - MaxSwap: 4, - SharedMemorySize: 256, - Swappiness: 30, - }, - }, - }); - }); - test('respects logging', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - logging: ecs.LogDriver.awsLogs({ - datetimeFormat: 'format', - logRetention: logs.RetentionDays.ONE_MONTH, - multilinePattern: 'pattern', - streamPrefix: 'hello', - }), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ExecutionRoleArn: { - 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], - }, - ...pascalCaseExpectedProps.ContainerProperties, - LogConfiguration: { - Options: { - 'awslogs-datetime-format': 'format', - 'awslogs-group': { Ref: 'EcsContainerLogGroup6C5D5962' }, - 'awslogs-multiline-pattern': 'pattern', - 'awslogs-region': { Ref: 'AWS::Region' }, - 'awslogs-stream-prefix': 'hello', - }, - }, - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - AssumeRolePolicyDocument: { - Statement: [ - { - Action: 'sts:AssumeRole', - Effect: 'Allow', - Principal: { Service: 'ecs-tasks.amazonaws.com' }, - }, - ], - Version: '2012-10-17', - }, - }); - }); - test('respects readonlyRootFilesystem', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - readonlyRootFilesystem: true, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ReadonlyRootFilesystem: true, - }, - }); - }); - test('respects secrets from secrestsmanager', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - secrets: { - envName: lib_1.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'testSecret')), - }, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Secrets: [ - { - Name: 'envName', - ValueFrom: { Ref: 'testSecretB96AD12C' }, - }, - ], - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [ - { - Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], - Effect: 'Allow', - Resource: { - 'Fn::Join': [ - '', [ - 'arn:', - { Ref: 'AWS::Partition' }, - ':logs:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':log-group:/aws/batch/job:*', - ], - ], - }, - }, - { - Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'], - Effect: 'Allow', - Resource: { Ref: 'testSecretB96AD12C' }, - }, - ], - }, - }); - }); - test('respects versioned secrets from secrestsmanager', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - secrets: { - envName: lib_1.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'testSecret'), { - versionId: 'versionID', - versionStage: 'stage', - }), - }, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Secrets: [ - { - Name: 'envName', - ValueFrom: { - 'Fn::Join': [ - '', [ - { Ref: 'testSecretB96AD12C' }, - '::stage:versionID', - ], - ], - }, - }, - ], - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [ - { - Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], - Effect: 'Allow', - Resource: { - 'Fn::Join': [ - '', [ - 'arn:', - { Ref: 'AWS::Partition' }, - ':logs:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':log-group:/aws/batch/job:*', - ], - ], - }, - }, - { - Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'], - Effect: 'Allow', - Resource: { Ref: 'testSecretB96AD12C' }, - }, - ], - }, - }); - }); - test('respects secrets from ssm', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - secrets: { - envName: lib_1.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'myParam', { stringValue: 'super secret' })), - }, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Secrets: [ - { - Name: 'envName', - ValueFrom: { - 'Fn::Join': [ - '', [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':ssm:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':parameter/', - { Ref: 'myParam03610B68' }, - ], - ], - }, - }, - ], - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [ - { - Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], - Effect: 'Allow', - Resource: { - 'Fn::Join': [ - '', [ - 'arn:', - { Ref: 'AWS::Partition' }, - ':logs:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':log-group:/aws/batch/job:*', - ], - ], - }, - }, - { - Action: ['ssm:DescribeParameters', 'ssm:GetParameters', 'ssm:GetParameter', 'ssm:GetParameterHistory'], - Effect: 'Allow', - Resource: { - 'Fn::Join': [ - '', - [ - 'arn:', - { Ref: 'AWS::Partition' }, - ':ssm:', - { Ref: 'AWS::Region' }, - ':', - { Ref: 'AWS::AccountId' }, - ':parameter/', - { Ref: 'myParam03610B68' }, - ], - ], - }, - }, - ], - }, - }); - }); - test('respects user', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - user: 'foo', - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - User: 'foo', - }, - }); - }); - test('respects efs volumes', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - volumes: [ - lib_1.EcsVolume.efs({ - containerPath: '/first/path', - fileSystem: new efs.FileSystem(stack, 'efs', { - vpc: new aws_ec2_1.Vpc(stack, 'vpc'), - }), - name: 'firstEfsVolume', - accessPointId: 'EfsVolumeAccessPointId', - readonly: true, - rootDirectory: 'efsRootDir', - enableTransitEncryption: true, - transitEncryptionPort: 20181, - useJobRole: true, - }), - lib_1.EcsVolume.efs({ - containerPath: '/second/path', - fileSystem: new efs.FileSystem(stack, 'efs2', { - vpc: new aws_ec2_1.Vpc(stack, 'vpc2'), - }), - name: 'secondEfsVolume', - }), - ], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Volumes: [ - { - EfsVolumeConfiguration: { - FileSystemId: { - Ref: 'efs6C17982A', - }, - RootDirectory: 'efsRootDir', - TransitEncryptionPort: 20181, - AuthorizationConfig: { - AccessPointId: 'EfsVolumeAccessPointId', - Iam: 'ENABLED', - }, - }, - Name: 'firstEfsVolume', - }, - { - EfsVolumeConfiguration: { - FileSystemId: { - Ref: 'efs2CB3916C1', - }, - }, - Name: 'secondEfsVolume', - }, - ], - MountPoints: [ - { - ContainerPath: '/first/path', - ReadOnly: true, - SourceVolume: 'firstEfsVolume', - }, - { - ContainerPath: '/second/path', - SourceVolume: 'secondEfsVolume', - }, - ], - }, - }); - }); - test('respects host volumes', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - volumes: [ - lib_1.EcsVolume.host({ - containerPath: '/container/path', - name: 'EcsHostPathVolume', - hostPath: '/host/path', - }), - ], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Volumes: [ - { - Name: 'EcsHostPathVolume', - Host: { - SourcePath: '/host/path', - }, - }, - ], - MountPoints: [ - { - ContainerPath: '/container/path', - SourceVolume: 'EcsHostPathVolume', - }, - ], - }, - }); - }); - test('respects addVolume() with an EfsVolume', () => { - // GIVEN - const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addVolume(lib_1.EcsVolume.efs({ - containerPath: '/container/path', - fileSystem: new efs.FileSystem(stack, 'efs', { - vpc: new aws_ec2_1.Vpc(stack, 'vpc'), - }), - name: 'AddedEfsVolume', - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Volumes: [{ - Name: 'AddedEfsVolume', - EfsVolumeConfiguration: { - FileSystemId: { - Ref: 'efs6C17982A', - }, - }, - }], - MountPoints: [{ - ContainerPath: '/container/path', - SourceVolume: 'AddedEfsVolume', - }], - }, - }); - }); - test('respects addVolume() with a host volume', () => { - // GIVEN - const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addVolume(lib_1.EcsVolume.host({ - containerPath: '/container/path/new', - name: 'hostName', - hostPath: '/host/path', - readonly: false, - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Volumes: [{ - Name: 'hostName', - Host: { - SourcePath: '/host/path', - }, - }], - MountPoints: [{ - ContainerPath: '/container/path/new', - SourceVolume: 'hostName', - }], - }, - }); - }); - test('correctly renders docker images', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - image: ecs.ContainerImage.fromDockerImageAsset(new aws_ecr_assets_1.DockerImageAsset(stack, 'dockerImageAsset', { - directory: path.join(__dirname, 'batchjob-image'), - })), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Image: { - 'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b', - }, - }, - }); - }); - test('correctly renders images from repositories', () => { - // GIVEN - const repo = new ecr.Repository(stack, 'Repo'); - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new ContainerDefinition(stack, 'EcsContainer', { - ...defaultContainerProps, - image: ecs.ContainerImage.fromEcrRepository(repo, 'my-tag'), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Image: { - 'Fn::Join': [ - '', - [ - { - 'Fn::Select': [ - 4, - { - 'Fn::Split': [ - ':', - { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] }, - ], - }, - ], - }, - '.dkr.ecr.', - { - 'Fn::Select': [ - 3, - { - 'Fn::Split': [ - ':', - { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] }, - ], - }, - ], - }, - '.', - { Ref: 'AWS::URLSuffix' }, - '/', - { Ref: 'Repo02AC86CF' }, - ':my-tag', - ], - ], - }, - }, - }); - }); -}); -describe('EC2 containers', () => { - // GIVEN - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { - ...defaultExpectedProps, - containerProperties: { - ...defaultExpectedProps.containerProperties, - executionRoleArn: { - 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'], - }, - }, - }); - }); - test('respects addUlimit()', () => { - // GIVEN - const jobDefn = new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addUlimit({ - hardLimit: 10, - name: lib_1.UlimitName.SIGPENDING, - softLimit: 1, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Ulimits: [{ - HardLimit: 10, - SoftLimit: 1, - Name: 'sigpending', - }], - }, - }); - }); - test('respects ulimits', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - ulimits: [ - { - hardLimit: 100, - name: lib_1.UlimitName.CORE, - softLimit: 10, - }, - ], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Ulimits: [ - { - HardLimit: 100, - Name: 'core', - SoftLimit: 10, - }, - ], - }, - }); - }); - test('respects privileged', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - privileged: true, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Privileged: true, - }, - }); - }); - test('respects gpu', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - privileged: true, - gpu: 12, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ResourceRequirements: [ - { - Type: 'MEMORY', - Value: '2048', - }, - { - Type: 'VCPU', - Value: '256', - }, - { - Type: 'GPU', - Value: '12', - }, - ], - }, - }); - }); - test('can use an assset as a container', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - image: ecs.ContainerImage.fromAsset(path.join(__dirname, 'batchjob-image')), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - Image: { - 'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b', - }, - ExecutionRoleArn: { 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'] }, - }, - }); - }); -}); -describe('Fargate containers', () => { - // GIVEN - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, { - ...defaultExpectedProps, - containerProperties: { - ...defaultExpectedProps.containerProperties, - executionRoleArn: { - 'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'], - }, - }, - }); - }); - test('create executionRole by default', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { - ...defaultContainerProps, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ExecutionRoleArn: { - 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], - }, - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - AssumeRolePolicyDocument: { - Statement: [{ - Action: 'sts:AssumeRole', - Effect: 'Allow', - Principal: { Service: 'ecs-tasks.amazonaws.com' }, - }], - Version: '2012-10-17', - }, - }); - }); - test('can set ephemeralStorageSize', () => { - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { - ...defaultContainerProps, - fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, - ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(100), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ExecutionRoleArn: { - 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], - }, - EphemeralStorage: { - SizeInGiB: aws_cdk_lib_1.Size.gibibytes(100).toGibibytes(), - }, - }, - }); - }); - test('can set ephemeralStorageSize as token', () => { - const ephemeralStorageValue = cdk.Token.asNumber(150); - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { - ...defaultContainerProps, - fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, - ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(ephemeralStorageValue), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - ContainerProperties: { - ...pascalCaseExpectedProps.ContainerProperties, - ExecutionRoleArn: { - 'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'], - }, - EphemeralStorage: { - SizeInGiB: aws_cdk_lib_1.Size.gibibytes(150).toGibibytes(), - }, - }, - }); - }); - test('ephemeralStorageSize throws error when out of range', () => { - expect(() => new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer', { - ...defaultContainerProps, - fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, - ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(19), - }), - })).toThrow("ECS Fargate container 'EcsFargateContainer' specifies 'ephemeralStorageSize' at 19 < 21 GB"); - expect(() => new lib_1.EcsJobDefinition(stack, 'ECSJobDefn2', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsFargateContainer2', { - ...defaultContainerProps, - fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST, - ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(201), - }), - })).toThrow("ECS Fargate container 'EcsFargateContainer2' specifies 'ephemeralStorageSize' at 201 > 200 GB"); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-container-definition.test.js","sourceRoot":"","sources":["ecs-container-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as path from 'path';\nimport { Vpc } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\nimport * as efs from 'aws-cdk-lib/aws-efs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { ArnPrincipal, Role } from 'aws-cdk-lib/aws-iam';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport { EcsContainerDefinitionProps, EcsEc2ContainerDefinition, EcsFargateContainerDefinition, EcsJobDefinition, EcsVolume, IEcsEc2ContainerDefinition, LinuxParameters, Secret, UlimitName } from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\nimport { capitalizePropertyNames } from './utils';\nimport { DockerImageAsset } from 'aws-cdk-lib/aws-ecr-assets';\n\n// GIVEN\nconst defaultContainerProps: EcsContainerDefinitionProps = {\n  cpu: 256,\n  image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n  memory: Size.mebibytes(2048),\n};\n\nconst defaultExpectedProps: CfnJobDefinitionProps = {\n  type: 'container',\n  containerProperties: {\n    image: 'amazon/amazon-ecs-sample',\n    resourceRequirements: [\n      {\n        type: 'MEMORY',\n        value: '2048',\n      },\n      {\n        type: 'VCPU',\n        value: '256',\n      },\n    ],\n  },\n};\n\nlet stack: Stack;\nlet pascalCaseExpectedProps: any;\n\ndescribe.each([EcsEc2ContainerDefinition, EcsFargateContainerDefinition])('%p', (ContainerDefinition) => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('ecs container defaults', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        },\n        ...pascalCaseExpectedProps.ContainerProperties,\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: 'sts:AssumeRole',\n            Effect: 'Allow',\n            Principal: { Service: 'ecs-tasks.amazonaws.com' },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: [\n              'logs:CreateLogStream',\n              'logs:PutLogEvents',\n            ],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '',\n                [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n      PolicyName: 'EcsContainerExecutionRoleDefaultPolicy6F59CD37',\n      Roles: [{\n        Ref: 'EcsContainerExecutionRole3B199293',\n      }],\n    });\n  });\n\n  test('respects command', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        command: ['echo', 'foo'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Command: ['echo', 'foo'],\n      },\n    });\n  });\n\n  test('respects environment', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        environment: {\n          foo: 'bar',\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Environment: [{\n          Name: 'foo',\n          Value: 'bar',\n        }],\n      },\n    });\n  });\n\n  test('respects executionRole', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        executionRole: new Role(stack, 'execRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:user/user-name'),\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['execRole623CB63A', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('respects jobRole', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        jobRole: new Role(stack, 'jobRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:user/user-name'),\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        JobRoleArn: {\n          'Fn::GetAtt': ['jobRoleA2173686', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('respects linuxParameters', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        privileged: true,\n        linuxParameters: new LinuxParameters(stack, 'linuxParameters', {\n          initProcessEnabled: true,\n          maxSwap: Size.kibibytes(4096),\n          sharedMemorySize: Size.mebibytes(256),\n          swappiness: 30,\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        LinuxParameters: {\n          InitProcessEnabled: true,\n          MaxSwap: 4,\n          SharedMemorySize: 256,\n          Swappiness: 30,\n        },\n      },\n    });\n  });\n\n  test('respects logging', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        logging: ecs.LogDriver.awsLogs({\n          datetimeFormat: 'format',\n          logRetention: logs.RetentionDays.ONE_MONTH,\n          multilinePattern: 'pattern',\n          streamPrefix: 'hello',\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        },\n        ...pascalCaseExpectedProps.ContainerProperties,\n        LogConfiguration: {\n          Options: {\n            'awslogs-datetime-format': 'format',\n            'awslogs-group': { Ref: 'EcsContainerLogGroup6C5D5962' },\n            'awslogs-multiline-pattern': 'pattern',\n            'awslogs-region': { Ref: 'AWS::Region' },\n            'awslogs-stream-prefix': 'hello',\n          },\n        },\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: 'sts:AssumeRole',\n            Effect: 'Allow',\n            Principal: { Service: 'ecs-tasks.amazonaws.com' },\n          },\n        ],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('respects readonlyRootFilesystem', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        readonlyRootFilesystem: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ReadonlyRootFilesystem: true,\n      },\n    });\n  });\n\n  test('respects secrets from secrestsmanager', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'testSecret')),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'],\n            Effect: 'Allow',\n            Resource: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects versioned secrets from secrestsmanager', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'testSecret'), {\n            versionId: 'versionID',\n            versionStage: 'stage',\n          }),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: {\n              'Fn::Join': [\n                '', [\n                  { Ref: 'testSecretB96AD12C' },\n                  '::stage:versionID',\n                ],\n              ],\n            },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['secretsmanager:GetSecretValue', 'secretsmanager:DescribeSecret'],\n            Effect: 'Allow',\n            Resource: { Ref: 'testSecretB96AD12C' },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects secrets from ssm', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        secrets: {\n          envName: Secret.fromSsmParameter(new ssm.StringParameter(stack, 'myParam', { stringValue: 'super secret' })),\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Secrets: [\n          {\n            Name: 'envName',\n            ValueFrom: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  {\n                    Ref: 'AWS::Partition',\n                  },\n                  ':ssm:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':parameter/',\n                  { Ref: 'myParam03610B68' },\n                ],\n              ],\n            },\n          },\n        ],\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n      PolicyDocument: {\n        Statement: [\n          {\n            Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '', [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':logs:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':log-group:/aws/batch/job:*',\n                ],\n              ],\n            },\n          },\n          {\n            Action: ['ssm:DescribeParameters', 'ssm:GetParameters', 'ssm:GetParameter', 'ssm:GetParameterHistory'],\n            Effect: 'Allow',\n            Resource: {\n              'Fn::Join': [\n                '',\n                [\n                  'arn:',\n                  { Ref: 'AWS::Partition' },\n                  ':ssm:',\n                  { Ref: 'AWS::Region' },\n                  ':',\n                  { Ref: 'AWS::AccountId' },\n                  ':parameter/',\n                  { Ref: 'myParam03610B68' },\n                ],\n\n              ],\n            },\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects user', () => {\n  // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        user: 'foo',\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        User: 'foo',\n      },\n    });\n  });\n\n  test('respects efs volumes', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        volumes: [\n          EcsVolume.efs({\n            containerPath: '/first/path',\n            fileSystem: new efs.FileSystem(stack, 'efs', {\n              vpc: new Vpc(stack, 'vpc'),\n            }),\n            name: 'firstEfsVolume',\n            accessPointId: 'EfsVolumeAccessPointId',\n            readonly: true,\n            rootDirectory: 'efsRootDir',\n            enableTransitEncryption: true,\n            transitEncryptionPort: 20181,\n            useJobRole: true,\n          }),\n          EcsVolume.efs({\n            containerPath: '/second/path',\n            fileSystem: new efs.FileSystem(stack, 'efs2', {\n              vpc: new Vpc(stack, 'vpc2'),\n            }),\n            name: 'secondEfsVolume',\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [\n          {\n            EfsVolumeConfiguration: {\n              FileSystemId: {\n                Ref: 'efs6C17982A',\n              },\n              RootDirectory: 'efsRootDir',\n              TransitEncryptionPort: 20181,\n              AuthorizationConfig: {\n                AccessPointId: 'EfsVolumeAccessPointId',\n                Iam: 'ENABLED',\n              },\n            },\n            Name: 'firstEfsVolume',\n          },\n          {\n            EfsVolumeConfiguration: {\n              FileSystemId: {\n                Ref: 'efs2CB3916C1',\n              },\n            },\n            Name: 'secondEfsVolume',\n          },\n        ],\n        MountPoints: [\n          {\n            ContainerPath: '/first/path',\n            ReadOnly: true,\n            SourceVolume: 'firstEfsVolume',\n          },\n          {\n            ContainerPath: '/second/path',\n            SourceVolume: 'secondEfsVolume',\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects host volumes', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        volumes: [\n          EcsVolume.host({\n            containerPath: '/container/path',\n            name: 'EcsHostPathVolume',\n            hostPath: '/host/path',\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [\n          {\n            Name: 'EcsHostPathVolume',\n            Host: {\n              SourcePath: '/host/path',\n            },\n          },\n        ],\n        MountPoints: [\n          {\n            ContainerPath: '/container/path',\n            SourceVolume: 'EcsHostPathVolume',\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects addVolume() with an EfsVolume', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EcsVolume.efs({\n      containerPath: '/container/path',\n      fileSystem: new efs.FileSystem(stack, 'efs', {\n        vpc: new Vpc(stack, 'vpc'),\n      }),\n      name: 'AddedEfsVolume',\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [{\n          Name: 'AddedEfsVolume',\n          EfsVolumeConfiguration: {\n            FileSystemId: {\n              Ref: 'efs6C17982A',\n            },\n          },\n        }],\n        MountPoints: [{\n          ContainerPath: '/container/path',\n          SourceVolume: 'AddedEfsVolume',\n        }],\n      },\n    });\n  });\n\n  test('respects addVolume() with a host volume', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EcsVolume.host({\n      containerPath: '/container/path/new',\n      name: 'hostName',\n      hostPath: '/host/path',\n      readonly: false,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Volumes: [{\n          Name: 'hostName',\n          Host: {\n            SourcePath: '/host/path',\n          },\n        }],\n        MountPoints: [{\n          ContainerPath: '/container/path/new',\n          SourceVolume: 'hostName',\n        }],\n      },\n    });\n  });\n\n  test('correctly renders docker images', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromDockerImageAsset(new DockerImageAsset(stack, 'dockerImageAsset', {\n          directory: path.join(__dirname, 'batchjob-image'),\n        })),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b',\n        },\n      },\n    });\n  });\n\n  test('correctly renders images from repositories', () => {\n    // GIVEN\n    const repo = new ecr.Repository(stack, 'Repo');\n\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new ContainerDefinition(stack, 'EcsContainer', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromEcrRepository(repo, 'my-tag'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Join': [\n            '',\n            [\n              {\n                'Fn::Select': [\n                  4,\n                  {\n                    'Fn::Split': [\n                      ':',\n                      { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] },\n                    ],\n                  },\n                ],\n              },\n              '.dkr.ecr.',\n              {\n                'Fn::Select': [\n                  3,\n                  {\n                    'Fn::Split': [\n                      ':',\n                      { 'Fn::GetAtt': ['Repo02AC86CF', 'Arn'] },\n                    ],\n                  },\n                ],\n              },\n              '.',\n              { Ref: 'AWS::URLSuffix' },\n              '/',\n              { Ref: 'Repo02AC86CF' },\n              ':my-tag',\n            ],\n          ],\n        },\n      },\n    });\n  });\n});\n\ndescribe('EC2 containers', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('respects addUlimit()', () => {\n    // GIVEN\n    const jobDefn = new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    (jobDefn.container as IEcsEc2ContainerDefinition).addUlimit({\n      hardLimit: 10,\n      name: UlimitName.SIGPENDING,\n      softLimit: 1,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Ulimits: [{\n          HardLimit: 10,\n          SoftLimit: 1,\n          Name: 'sigpending',\n        }],\n      },\n    });\n  });\n\n  test('respects ulimits', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        ulimits: [\n          {\n            hardLimit: 100,\n            name: UlimitName.CORE,\n            softLimit: 10,\n          },\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Ulimits: [\n          {\n            HardLimit: 100,\n            Name: 'core',\n            SoftLimit: 10,\n          },\n        ],\n      },\n    });\n  });\n\n  test('respects privileged', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Privileged: true,\n      },\n    });\n  });\n\n  test('respects gpu', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n        gpu: 12,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ResourceRequirements: [\n          {\n            Type: 'MEMORY',\n            Value: '2048',\n          },\n          {\n            Type: 'VCPU',\n            Value: '256',\n          },\n          {\n            Type: 'GPU',\n            Value: '12',\n          },\n        ],\n      },\n    });\n  });\n\n  test('can use an assset as a container', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsEc2ContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        image: ecs.ContainerImage.fromAsset(\n          path.join(__dirname, 'batchjob-image'),\n        ),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        Image: {\n          'Fn::Sub': '${AWS::AccountId}.dkr.ecr.${AWS::Region}.${AWS::URLSuffix}/cdk-hnb659fds-container-assets-${AWS::AccountId}-${AWS::Region}:8b518243ecbfcfd08b4734069e7e74ff97b7889dfde0a60d16e7bdc96e6c593b',\n        },\n        ExecutionRoleArn: { 'Fn::GetAtt': ['EcsEc2ContainerExecutionRole90E18680', 'Arn'] },\n      },\n    });\n  });\n});\n\ndescribe('Fargate containers', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, {\n      ...defaultExpectedProps,\n      containerProperties: {\n        ...defaultExpectedProps.containerProperties,\n        executionRoleArn: {\n          'Fn::GetAtt': ['EcsContainerExecutionRole3B199293', 'Arn'],\n        } as any,\n      },\n    });\n  });\n\n  test('create executionRole by default', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n      },\n    });\n\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'ecs-tasks.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('can set ephemeralStorageSize', () => {\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(100),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n        EphemeralStorage: {\n          SizeInGiB: Size.gibibytes(100).toGibibytes(),\n        },\n      },\n    });\n  });\n\n  test('can set ephemeralStorageSize as token', () => {\n    const ephemeralStorageValue: number = cdk.Token.asNumber(150);\n\n    // WHEN\n    new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(ephemeralStorageValue),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      ContainerProperties: {\n        ...pascalCaseExpectedProps.ContainerProperties,\n        ExecutionRoleArn: {\n          'Fn::GetAtt': ['EcsFargateContainerExecutionRole3286EAFE', 'Arn'],\n        },\n        EphemeralStorage: {\n          SizeInGiB: Size.gibibytes(150).toGibibytes(),\n        },\n      },\n    });\n  });\n\n  test('ephemeralStorageSize throws error when out of range', () => {\n    expect(() => new EcsJobDefinition(stack, 'ECSJobDefn', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(19),\n      }),\n    })).toThrow(\"ECS Fargate container 'EcsFargateContainer' specifies 'ephemeralStorageSize' at 19 < 21 GB\");\n\n    expect(() => new EcsJobDefinition(stack, 'ECSJobDefn2', {\n      container: new EcsFargateContainerDefinition(stack, 'EcsFargateContainer2', {\n        ...defaultContainerProps,\n        fargatePlatformVersion: ecs.FargatePlatformVersion.LATEST,\n        ephemeralStorageSize: Size.gibibytes(201),\n      }),\n    })).toThrow(\"ECS Fargate container 'EcsFargateContainer2' specifies 'ephemeralStorageSize' at 201 > 200 GB\");\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js deleted file mode 100644 index 0eb741964ca54..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/ecs-job-definition.test.js +++ /dev/null @@ -1,147 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const iam = require("aws-cdk-lib/aws-iam"); -const lib_1 = require("../lib"); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -test('EcsJobDefinition respects propagateTags', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EcsJobDefinition(stack, 'JobDefn', { - propagateTags: true, - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - PropagateTags: true, - }); -}); -test('EcsJobDefinition uses Compatibility.EC2 for EC2 containers', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - PlatformCapabilities: [lib_1.Compatibility.EC2], - }); -}); -test('EcsJobDefinition uses Compatibility.FARGATE for Fargate containers', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - PlatformCapabilities: [lib_1.Compatibility.FARGATE], - }); -}); -test('can be imported from ARN', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - const importedJob = lib_1.EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); - // THEN - expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); -}); -test('JobDefinitionName is parsed from arn', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - const jobDefinition = new lib_1.EcsJobDefinition(stack, 'JobDefn', { - propagateTags: true, - container: new lib_1.EcsEc2ContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - expect(aws_cdk_lib_1.Tokenization.resolve(jobDefinition.jobDefinitionName, { - scope: stack, - resolver: new aws_cdk_lib_1.DefaultTokenResolver(new aws_cdk_lib_1.StringConcat()), - })).toEqual({ - 'Fn::Select': [ - 1, - { - 'Fn::Split': [ - '/', - { - 'Fn::Select': [ - 5, - { - 'Fn::Split': [ - ':', - { - Ref: 'JobDefnA747EE6E', - }, - ], - }, - ], - }, - ], - }, - ], - }); -}); -test('JobDefinitionName is parsed from arn in imported job', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - const importedJob = lib_1.EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); - // THEN - expect(importedJob.jobDefinitionName).toEqual('job-def-name'); -}); -test('grantSubmitJob() grants the job role the correct actions', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const ecsJob = new lib_1.EcsJobDefinition(stack, 'ECSJob', { - container: new lib_1.EcsFargateContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'), - }), - }); - const queue = new lib_1.JobQueue(stack, 'queue'); - queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'env', { - vpc: new aws_ec2_1.Vpc(stack, 'VPC'), - }), 1); - const user = new iam.User(stack, 'MyUser'); - // WHEN - ecsJob.grantSubmitJob(user, queue); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', { - PolicyDocument: { - Statement: [{ - Action: 'batch:SubmitJob', - Effect: 'Allow', - Resource: [ - { Ref: 'ECSJobFFFEA569' }, - { 'Fn::GetAtt': ['queue276F7297', 'JobQueueArn'] }, - ], - }], - Version: '2012-10-17', - }, - PolicyName: 'MyUserDefaultPolicy7B897426', - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs-job-definition.test.js","sourceRoot":"","sources":["ecs-job-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { DefaultTokenResolver, Size, StringConcat, Stack, Tokenization } from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Compatibility, EcsEc2ContainerDefinition, EcsFargateContainerDefinition, EcsJobDefinition, JobQueue, ManagedEc2EcsComputeEnvironment } from '../lib';\nimport { Vpc } from 'aws-cdk-lib/aws-ec2';\n\ntest('EcsJobDefinition respects propagateTags', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'JobDefn', {\n    propagateTags: true,\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PropagateTags: true,\n  });\n});\n\ntest('EcsJobDefinition uses Compatibility.EC2 for EC2 containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'ECSJobDefn', {\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('EcsJobDefinition uses Compatibility.FARGATE for Fargate containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new EcsJobDefinition(stack, 'ECSJobDefn', {\n    container: new EcsFargateContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PlatformCapabilities: [Compatibility.FARGATE],\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const importedJob = EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition',\n    'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n\n  // THEN\n  expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n});\n\ntest('JobDefinitionName is parsed from arn', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const jobDefinition = new EcsJobDefinition(stack, 'JobDefn', {\n    propagateTags: true,\n    container: new EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      memory: Size.mebibytes(2048),\n    }),\n  });\n\n  // THEN\n  expect(Tokenization.resolve(jobDefinition.jobDefinitionName, {\n    scope: stack,\n    resolver: new DefaultTokenResolver(new StringConcat()),\n  })).toEqual({\n    'Fn::Select': [\n      1,\n      {\n        'Fn::Split': [\n          '/',\n          {\n            'Fn::Select': [\n              5,\n              {\n                'Fn::Split': [\n                  ':',\n                  {\n                    Ref: 'JobDefnA747EE6E',\n                  },\n                ],\n              },\n            ],\n          },\n        ],\n      },\n    ],\n  });\n});\n\ntest('JobDefinitionName is parsed from arn in imported job', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const importedJob = EcsJobDefinition.fromJobDefinitionArn(stack, 'importedJobDefinition',\n    'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1');\n\n  // THEN\n  expect(importedJob.jobDefinitionName).toEqual('job-def-name');\n});\n\ntest('grantSubmitJob() grants the job role the correct actions', () => {\n  // GIVEN\n  const stack = new Stack();\n  const ecsJob = new EcsJobDefinition(stack, 'ECSJob', {\n    container: new EcsFargateContainerDefinition(stack, 'EcsContainer', {\n      cpu: 256,\n      memory: Size.mebibytes(2048),\n      image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'),\n    }),\n  });\n  const queue = new JobQueue(stack, 'queue');\n\n  queue.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'env', {\n      vpc: new Vpc(stack, 'VPC'),\n    }),\n    1,\n  );\n\n  const user = new iam.User(stack, 'MyUser');\n\n  // WHEN\n  ecsJob.grantSubmitJob(user, queue);\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::IAM::Policy', {\n    PolicyDocument: {\n      Statement: [{\n        Action: 'batch:SubmitJob',\n        Effect: 'Allow',\n        Resource: [\n          { Ref: 'ECSJobFFFEA569' },\n          { 'Fn::GetAtt': ['queue276F7297', 'JobQueueArn'] },\n        ],\n      }],\n      Version: '2012-10-17',\n    },\n    PolicyName: 'MyUserDefaultPolicy7B897426',\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js deleted file mode 100644 index 3230501ab97c5..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/eks-container-definition.test.js +++ /dev/null @@ -1,712 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const utils_1 = require("./utils"); -const lib_1 = require("../lib"); -// GIVEN -const defaultContainerProps = { - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), -}; -const defaultExpectedProps = { - type: 'container', - eksProperties: { - podProperties: { - containers: [{ - image: 'amazon/amazon-ecs-sample', - }], - }, - }, -}; -let stack; -let pascalCaseExpectedProps; -describe('eks container', () => { - // GIVEN - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedProps); - }); - test('eks container defaults', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - }); - }); - test('respects args', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - args: ['arg1', 'arg2'], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Args: ['arg1', 'arg2'], - }], - }, - }, - }); - }); - test('respects command', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - command: ['echo', 'bar'], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Command: ['echo', 'bar'], - }], - }, - }, - }); - }); - test('respects cpuLimit', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - cpuLimit: 256, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Limits: { - cpu: 256, - }, - }, - }], - }, - }, - }); - }); - test('respects cpuReservation', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - cpuReservation: 256, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Requests: { - cpu: 256, - }, - }, - }], - }, - }, - }); - }); - test('respects memoryLimitMiB', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - memoryLimit: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Limits: { - memory: '2048Mi', - }, - }, - }], - }, - }, - }); - }); - test('respects memoryReservation', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - memoryReservation: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Requests: { - memory: '2048Mi', - }, - }, - }], - }, - }, - }); - }); - test('respects gpuLimit', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - gpuLimit: 20, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Limits: { - 'nvidia.com/gpu': 20, - }, - }, - }], - }, - }, - }); - }); - test('respects gpuReservation', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - gpuReservation: 20, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Requests: { - 'nvidia.com/gpu': 20, - }, - }, - }], - }, - }, - }); - }); - test('respects resource requests and limits', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - cpuLimit: 256, - cpuReservation: 128, - memoryLimit: aws_cdk_lib_1.Size.mebibytes(2048), - memoryReservation: aws_cdk_lib_1.Size.mebibytes(2048), - gpuLimit: 20, - gpuReservation: 10, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Resources: { - Limits: { - 'cpu': 256, - 'memory': '2048Mi', - 'nvidia.com/gpu': 20, - }, - Requests: { - 'cpu': 128, - 'memory': '2048Mi', - 'nvidia.com/gpu': 10, - }, - }, - }], - }, - }, - }); - }); - test('respects env', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - env: { - var: 'val', - boo: 'bah', - }, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Env: [ - { - Name: 'var', - Value: 'val', - }, - { - Name: 'boo', - Value: 'bah', - }, - ], - }], - }, - }, - }); - }); - test('respects imagePullPolicy', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - imagePullPolicy: lib_1.ImagePullPolicy.NEVER, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - ImagePullPolicy: 'Never', - }], - }, - }, - }); - }); - test('respects name', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - name: 'myContainerName', - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - Name: 'myContainerName', - }], - }, - }, - }); - }); - test('respects privileged', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - privileged: true, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - SecurityContext: { - Privileged: true, - }, - }], - }, - }, - }); - }); - test('respects readonlyFileSystem', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - readonlyRootFilesystem: true, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - SecurityContext: { - ReadOnlyRootFilesystem: true, - }, - }], - }, - }, - }); - }); - test('respects runAsGroup', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - runAsGroup: 1, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - SecurityContext: { - RunAsGroup: 1, - }, - }], - }, - }, - }); - }); - test('respects runAsRoot', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefEksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - runAsRoot: true, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - SecurityContext: { - RunAsNonRoot: false, - }, - }], - }, - }, - }); - }); - test('respects runAsUser', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - runAsUser: 90, - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - SecurityContext: { - RunAsUser: 90, - }, - }], - }, - }, - }); - }); - test('respects emptyDir volumes', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - volumes: [ - lib_1.EksVolume.emptyDir({ - name: 'emptyDirName', - medium: lib_1.EmptyDirMediumType.DISK, - mountPath: '/mount/path', - readonly: false, - sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), - }), - ], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - Name: 'emptyDirName', - ReadOnly: false, - }], - }], - Volumes: [{ - Name: 'emptyDirName', - EmptyDir: { - Medium: '', - SizeLimit: '2048Mi', - }, - }], - }, - }, - }); - }); - test('respects hostPath volumes', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - volumes: [lib_1.EksVolume.hostPath({ - name: 'hostPathName', - hostPath: 'hostPathPath', - mountPath: '/mount/path', - readonly: true, - })], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - Name: 'hostPathName', - ReadOnly: true, - }], - }], - Volumes: [{ - Name: 'hostPathName', - HostPath: { - Path: 'hostPathPath', - }, - }], - }, - }, - }); - }); - test('respects secret volumes, and ensures optional defaults to true', () => { - // WHEN - new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - volumes: [lib_1.EksVolume.secret({ - name: 'secretVolumeName', - secretName: 'myKubeSecret', - mountPath: '/mount/path', - readonly: true, - })], - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - ReadOnly: true, - }], - }], - Volumes: [{ - Name: 'secretVolumeName', - Secret: { - SecretName: 'myKubeSecret', - Optional: true, - }, - }], - }, - }, - }); - }); - test('respects addVolume() with emptyDir volume', () => { - // GIVEN - const jobDefn = new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addVolume(lib_1.EksVolume.emptyDir({ - name: 'emptyDirName', - medium: lib_1.EmptyDirMediumType.DISK, - mountPath: '/mount/path', - readonly: false, - sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - Name: 'emptyDirName', - ReadOnly: false, - }], - }], - Volumes: [{ - Name: 'emptyDirName', - EmptyDir: { - Medium: '', - SizeLimit: '2048Mi', - }, - }], - }, - }, - }); - }); - test('respects addVolume() with hostPath volume', () => { - // GIVEN - const jobDefn = new lib_1.EksJobDefinition(stack, 'EksJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addVolume(lib_1.EksVolume.hostPath({ - name: 'hostPathName', - hostPath: 'hostPathPath', - mountPath: '/mount/path', - readonly: true, - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - Name: 'hostPathName', - ReadOnly: true, - }], - }], - Volumes: [{ - Name: 'hostPathName', - HostPath: { - Path: 'hostPathPath', - }, - }], - }, - }, - }); - }); - test('respects addVolume() with secret volume (optional: false)', () => { - // GIVEN - const jobDefn = new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EcsEc2Container', { - ...defaultContainerProps, - }), - }); - // WHEN - jobDefn.container.addVolume(lib_1.EksVolume.secret({ - name: 'secretVolumeName', - secretName: 'secretName', - optional: false, - mountPath: '/mount/path', - readonly: true, - })); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...pascalCaseExpectedProps, - EksProperties: { - PodProperties: { - ...pascalCaseExpectedProps.EksProperties.PodProperties, - Containers: [{ - ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0], - VolumeMounts: [{ - MountPath: '/mount/path', - Name: 'secretVolumeName', - ReadOnly: true, - }], - }], - Volumes: [{ - Name: 'secretVolumeName', - Secret: { - SecretName: 'secretName', - Optional: false, - }, - }], - }, - }, - }); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eks-container-definition.test.js","sourceRoot":"","sources":["eks-container-definition.test.ts"],"names":[],"mappings":";;AAAA,uDAAkD;AAClD,2CAA2C;AAC3C,6CAA0C;AAC1C,mCAAkD;AAClD,gCAA+I;AAG/I,QAAQ;AACR,MAAM,qBAAqB,GAAgC;IACzD,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,0BAA0B,CAAC;CACnE,CAAC;AAEF,MAAM,oBAAoB,GAA0B;IAClD,IAAI,EAAE,WAAW;IACjB,aAAa,EAAE;QACb,aAAa,EAAE;YACb,UAAU,EAAE,CAAC;oBACX,KAAK,EAAE,0BAA0B;iBAClC,CAAC;SACH;KACF;CACF,CAAC;AAEF,IAAI,KAAY,CAAC;AACjB,IAAI,uBAA4B,CAAC;AAEjC,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,QAAQ;IACR,UAAU,CAAC,GAAG,EAAE;QACd,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;QACpB,uBAAuB,GAAG,IAAA,+BAAuB,EAAC,KAAK,EAAE,oBAAoB,CAAC,CAAC;IACjF,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAClC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;aACzB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;SAC3B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE;QACzB,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;aACvB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;yBACvB,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC5B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,OAAO,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC;aACzB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,OAAO,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC;yBACzB,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC7B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,QAAQ,EAAE,GAAG;aACd,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,MAAM,EAAE;oCACN,GAAG,EAAE,GAAG;iCACT;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACnC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,cAAc,EAAE,GAAG;aACpB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,QAAQ,EAAE;oCACR,GAAG,EAAE,GAAG;iCACT;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACnC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,WAAW,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;aAClC,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,MAAM,EAAE;oCACN,MAAM,EAAE,QAAQ;iCACjB;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACtC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,iBAAiB,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;aACxC,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,QAAQ,EAAE;oCACR,MAAM,EAAE,QAAQ;iCACjB;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC7B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,QAAQ,EAAE,EAAE;aACb,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,MAAM,EAAE;oCACN,gBAAgB,EAAE,EAAE;iCACrB;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACnC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,cAAc,EAAE,EAAE;aACnB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,QAAQ,EAAE;oCACR,gBAAgB,EAAE,EAAE;iCACrB;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,uCAAuC,EAAE,GAAG,EAAE;QACjD,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,QAAQ,EAAE,GAAG;gBACb,cAAc,EAAE,GAAG;gBACnB,WAAW,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;gBACjC,iBAAiB,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;gBACvC,QAAQ,EAAE,EAAE;gBACZ,cAAc,EAAE,EAAE;aACnB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,SAAS,EAAE;gCACT,MAAM,EAAE;oCACN,KAAK,EAAE,GAAG;oCACV,QAAQ,EAAE,QAAQ;oCAClB,gBAAgB,EAAE,EAAE;iCACrB;gCACD,QAAQ,EAAE;oCACR,KAAK,EAAE,GAAG;oCACV,QAAQ,EAAE,QAAQ;oCAClB,gBAAgB,EAAE,EAAE;iCACrB;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE;QACxB,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,GAAG,EAAE;oBACH,GAAG,EAAE,KAAK;oBACV,GAAG,EAAE,KAAK;iBACX;aACF,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,GAAG,EAAE;gCACH;oCACE,IAAI,EAAE,KAAK;oCACX,KAAK,EAAE,KAAK;iCACb;gCACD;oCACE,IAAI,EAAE,KAAK;oCACX,KAAK,EAAE,KAAK;iCACb;6BACF;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACpC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,eAAe,EAAE,qBAAe,CAAC,KAAK;aACvC,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE,OAAO;yBACzB,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE;QACzB,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,IAAI,EAAE,iBAAiB;aACxB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,IAAI,EAAE,iBAAiB;yBACxB,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE;QAC/B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,UAAU,EAAE,IAAI;aACjB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE;gCACf,UAAU,EAAE,IAAI;6BACjB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACvC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,sBAAsB,EAAE,IAAI;aAC7B,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE;gCACf,sBAAsB,EAAE,IAAI;6BAC7B;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE;QAC/B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,UAAU,EAAE,CAAC;aACd,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE;gCACf,UAAU,EAAE,CAAC;6BACd;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAC9B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,qBAAqB,EAAE;YACjD,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,SAAS,EAAE,IAAI;aAChB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE;gCACf,YAAY,EAAE,KAAK;6BACpB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAC9B,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,SAAS,EAAE,EAAE;aACd,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,eAAe,EAAE;gCACf,SAAS,EAAE,EAAE;6BACd;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACrC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,OAAO,EAAE;oBACP,eAAS,CAAC,QAAQ,CAAC;wBACjB,IAAI,EAAE,cAAc;wBACpB,MAAM,EAAE,wBAAkB,CAAC,IAAI;wBAC/B,SAAS,EAAE,aAAa;wBACxB,QAAQ,EAAE,KAAK;wBACf,SAAS,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;qBAChC,CAAC;iBACH;aACF,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,IAAI,EAAE,cAAc;oCACpB,QAAQ,EAAE,KAAK;iCAChB,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,cAAc;4BACpB,QAAQ,EAAE;gCACR,MAAM,EAAE,EAAE;gCACV,SAAS,EAAE,QAAQ;6BACpB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACrC,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,OAAO,EAAE,CAAC,eAAS,CAAC,QAAQ,CAAC;wBAC3B,IAAI,EAAE,cAAc;wBACpB,QAAQ,EAAE,cAAc;wBACxB,SAAS,EAAE,aAAa;wBACxB,QAAQ,EAAE,IAAI;qBACf,CAAC,CAAC;aACJ,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,IAAI,EAAE,cAAc;oCACpB,QAAQ,EAAE,IAAI;iCACf,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,cAAc;4BACpB,QAAQ,EAAE;gCACR,IAAI,EAAE,cAAc;6BACrB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gEAAgE,EAAE,GAAG,EAAE;QAC1E,OAAO;QACP,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxC,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;gBACxB,OAAO,EAAE,CAAC,eAAS,CAAC,MAAM,CAAC;wBACzB,IAAI,EAAE,kBAAkB;wBACxB,UAAU,EAAE,cAAc;wBAC1B,SAAS,EAAE,aAAa;wBACxB,QAAQ,EAAE,IAAI;qBACf,CAAC,CAAC;aACJ,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,QAAQ,EAAE,IAAI;iCACf,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,kBAAkB;4BACxB,MAAM,EAAE;gCACN,UAAU,EAAE,cAAc;gCAC1B,QAAQ,EAAE,IAAI;6BACf;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACrD,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxD,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;aACzB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,eAAS,CAAC,QAAQ,CAAC;YAC7C,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,wBAAkB,CAAC,IAAI;YAC/B,SAAS,EAAE,aAAa;YACxB,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAChC,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,IAAI,EAAE,cAAc;oCACpB,QAAQ,EAAE,KAAK;iCAChB,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,cAAc;4BACpB,QAAQ,EAAE;gCACR,MAAM,EAAE,EAAE;gCACV,SAAS,EAAE,QAAQ;6BACpB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACrD,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxD,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;aACzB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,eAAS,CAAC,QAAQ,CAAC;YAC7C,IAAI,EAAE,cAAc;YACpB,QAAQ,EAAE,cAAc;YACxB,SAAS,EAAE,aAAa;YACxB,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,IAAI,EAAE,cAAc;oCACpB,QAAQ,EAAE,IAAI;iCACf,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,cAAc;4BACpB,QAAQ,EAAE;gCACR,IAAI,EAAE,cAAc;6BACrB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACrE,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,sBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;YACxD,SAAS,EAAE,IAAI,4BAAsB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBAC9D,GAAG,qBAAqB;aACzB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;QACP,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,eAAS,CAAC,MAAM,CAAC;YAC3C,IAAI,EAAE,kBAAkB;YACxB,UAAU,EAAE,YAAY;YACxB,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,aAAa;YACxB,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;QAEJ,OAAO;QACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,2BAA2B,EAAE;YAC3E,GAAG,uBAAuB;YAC1B,aAAa,EAAE;gBACb,aAAa,EAAE;oBACb,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa;oBACtD,UAAU,EAAE,CAAC;4BACX,GAAG,uBAAuB,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;4BACpE,YAAY,EAAE,CAAC;oCACb,SAAS,EAAE,aAAa;oCACxB,IAAI,EAAE,kBAAkB;oCACxB,QAAQ,EAAE,IAAI;iCACf,CAAC;yBACH,CAAC;oBACF,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,kBAAkB;4BACxB,MAAM,EAAE;gCACN,UAAU,EAAE,YAAY;gCACxB,QAAQ,EAAE,KAAK;6BAChB;yBACF,CAAC;iBACH;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport { EksContainerDefinitionProps, EksContainerDefinition, EksJobDefinition, ImagePullPolicy, EksVolume, EmptyDirMediumType } from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\n// GIVEN\nconst defaultContainerProps: EksContainerDefinitionProps = {\n  image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n};\n\nconst defaultExpectedProps: CfnJobDefinitionProps = {\n  type: 'container',\n  eksProperties: {\n    podProperties: {\n      containers: [{\n        image: 'amazon/amazon-ecs-sample',\n      }],\n    },\n  },\n};\n\nlet stack: Stack;\nlet pascalCaseExpectedProps: any;\n\ndescribe('eks container', () => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n    pascalCaseExpectedProps = capitalizePropertyNames(stack, defaultExpectedProps);\n  });\n\n  test('eks container defaults', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n    });\n  });\n\n  test('respects args', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        args: ['arg1', 'arg2'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Args: ['arg1', 'arg2'],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects command', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        command: ['echo', 'bar'],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Command: ['echo', 'bar'],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects cpuLimit', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuLimit: 256,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                cpu: 256,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects cpuReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuReservation: 256,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                cpu: 256,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects memoryLimitMiB', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        memoryLimit: Size.mebibytes(2048),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                memory: '2048Mi',\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects memoryReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        memoryReservation: Size.mebibytes(2048),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                memory: '2048Mi',\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects gpuLimit', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        gpuLimit: 20,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                'nvidia.com/gpu': 20,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects gpuReservation', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        gpuReservation: 20,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Requests: {\n                'nvidia.com/gpu': 20,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects resource requests and limits', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        cpuLimit: 256,\n        cpuReservation: 128,\n        memoryLimit: Size.mebibytes(2048),\n        memoryReservation: Size.mebibytes(2048),\n        gpuLimit: 20,\n        gpuReservation: 10,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Resources: {\n              Limits: {\n                'cpu': 256,\n                'memory': '2048Mi',\n                'nvidia.com/gpu': 20,\n              },\n              Requests: {\n                'cpu': 128,\n                'memory': '2048Mi',\n                'nvidia.com/gpu': 10,\n              },\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects env', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        env: {\n          var: 'val',\n          boo: 'bah',\n        },\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Env: [\n              {\n                Name: 'var',\n                Value: 'val',\n              },\n              {\n                Name: 'boo',\n                Value: 'bah',\n              },\n            ],\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects imagePullPolicy', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        imagePullPolicy: ImagePullPolicy.NEVER,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            ImagePullPolicy: 'Never',\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        name: 'myContainerName',\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            Name: 'myContainerName',\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects privileged', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        privileged: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              Privileged: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects readonlyFileSystem', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        readonlyRootFilesystem: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              ReadOnlyRootFilesystem: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsGroup', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsGroup: 1,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsGroup: 1,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsRoot', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefEksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsRoot: true,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsNonRoot: false,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects runAsUser', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        runAsUser: 90,\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            SecurityContext: {\n              RunAsUser: 90,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects emptyDir volumes', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [\n          EksVolume.emptyDir({\n            name: 'emptyDirName',\n            medium: EmptyDirMediumType.DISK,\n            mountPath: '/mount/path',\n            readonly: false,\n            sizeLimit: Size.mebibytes(2048),\n          }),\n        ],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'emptyDirName',\n              ReadOnly: false,\n            }],\n          }],\n          Volumes: [{\n            Name: 'emptyDirName',\n            EmptyDir: {\n              Medium: '',\n              SizeLimit: '2048Mi',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects hostPath volumes', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [EksVolume.hostPath({\n          name: 'hostPathName',\n          hostPath: 'hostPathPath',\n          mountPath: '/mount/path',\n          readonly: true,\n        })],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'hostPathName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'hostPathName',\n            HostPath: {\n              Path: 'hostPathPath',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects secret volumes, and ensures optional defaults to true', () => {\n    // WHEN\n    new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n        volumes: [EksVolume.secret({\n          name: 'secretVolumeName',\n          secretName: 'myKubeSecret',\n          mountPath: '/mount/path',\n          readonly: true,\n        })],\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'secretVolumeName',\n            Secret: {\n              SecretName: 'myKubeSecret',\n              Optional: true,\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with emptyDir volume', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.emptyDir({\n      name: 'emptyDirName',\n      medium: EmptyDirMediumType.DISK,\n      mountPath: '/mount/path',\n      readonly: false,\n      sizeLimit: Size.mebibytes(2048),\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'emptyDirName',\n              ReadOnly: false,\n            }],\n          }],\n          Volumes: [{\n            Name: 'emptyDirName',\n            EmptyDir: {\n              Medium: '',\n              SizeLimit: '2048Mi',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with hostPath volume', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EksJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.hostPath({\n      name: 'hostPathName',\n      hostPath: 'hostPathPath',\n      mountPath: '/mount/path',\n      readonly: true,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'hostPathName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'hostPathName',\n            HostPath: {\n              Path: 'hostPathPath',\n            },\n          }],\n        },\n      },\n    });\n  });\n\n  test('respects addVolume() with secret volume (optional: false)', () => {\n    // GIVEN\n    const jobDefn = new EksJobDefinition(stack, 'EKSJobDefn', {\n      container: new EksContainerDefinition(stack, 'EcsEc2Container', {\n        ...defaultContainerProps,\n      }),\n    });\n\n    // WHEN\n    jobDefn.container.addVolume(EksVolume.secret({\n      name: 'secretVolumeName',\n      secretName: 'secretName',\n      optional: false,\n      mountPath: '/mount/path',\n      readonly: true,\n    }));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...pascalCaseExpectedProps,\n      EksProperties: {\n        PodProperties: {\n          ...pascalCaseExpectedProps.EksProperties.PodProperties,\n          Containers: [{\n            ...pascalCaseExpectedProps.EksProperties.PodProperties.Containers[0],\n            VolumeMounts: [{\n              MountPath: '/mount/path',\n              Name: 'secretVolumeName',\n              ReadOnly: true,\n            }],\n          }],\n          Volumes: [{\n            Name: 'secretVolumeName',\n            Secret: {\n              SecretName: 'secretName',\n              Optional: false,\n            },\n          }],\n        },\n      },\n    });\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js deleted file mode 100644 index 6a75c414d26d2..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/eks-job-definition.test.js +++ /dev/null @@ -1,72 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const lib_1 = require("../lib"); -test('EcsJobDefinition respects dnsPolicy', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - dnsPolicy: lib_1.DnsPolicy.CLUSTER_FIRST, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - EksProperties: { - PodProperties: { - DnsPolicy: lib_1.DnsPolicy.CLUSTER_FIRST, - }, - }, - }); -}); -test('EcsJobDefinition respects useHostNetwork', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - useHostNetwork: true, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - EksProperties: { - PodProperties: { - HostNetwork: true, - }, - }, - }); -}); -test('EcsJobDefinition respects serviceAccount', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.EksJobDefinition(stack, 'EKSJobDefn', { - container: new lib_1.EksContainerDefinition(stack, 'EksContainer', { - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - serviceAccount: 'my-service-account', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - EksProperties: { - PodProperties: { - ServiceAccountName: 'my-service-account', - }, - }, - }); -}); -test('can be imported from ARN', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - const importedJob = lib_1.EksJobDefinition.fromEksJobDefinitionArn(stack, 'importedJobDefinition', 'arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); - // THEN - expect(importedJob.jobDefinitionArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-definition/job-def-name:1'); -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWtzLWpvYi1kZWZpbml0aW9uLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJla3Mtam9iLWRlZmluaXRpb24udGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHVEQUFrRDtBQUNsRCwyQ0FBMkM7QUFDM0MsNkNBQW9DO0FBQ3BDLGdDQUE2RTtBQUU3RSxJQUFJLENBQUMscUNBQXFDLEVBQUUsR0FBRyxFQUFFO0lBQy9DLFFBQVE7SUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLEVBQUUsQ0FBQztJQUUxQixPQUFPO0lBQ1AsSUFBSSxzQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1FBQ3hDLFNBQVMsRUFBRSxJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7WUFDM0QsS0FBSyxFQUFFLEdBQUcsQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO1NBQ25FLENBQUM7UUFDRixTQUFTLEVBQUUsZUFBUyxDQUFDLGFBQWE7S0FDbkMsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLDJCQUEyQixFQUFFO1FBQzNFLGFBQWEsRUFBRTtZQUNiLGFBQWEsRUFBRTtnQkFDYixTQUFTLEVBQUUsZUFBUyxDQUFDLGFBQWE7YUFDbkM7U0FDRjtLQUNGLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDO0FBRUgsSUFBSSxDQUFDLDBDQUEwQyxFQUFFLEdBQUcsRUFBRTtJQUNwRCxRQUFRO0lBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxFQUFFLENBQUM7SUFFMUIsT0FBTztJQUNQLElBQUksc0JBQWdCLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtRQUN4QyxTQUFTLEVBQUUsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFO1lBQzNELEtBQUssRUFBRSxHQUFHLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztTQUNuRSxDQUFDO1FBQ0YsY0FBYyxFQUFFLElBQUk7S0FDckIsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLDJCQUEyQixFQUFFO1FBQzNFLGFBQWEsRUFBRTtZQUNiLGFBQWEsRUFBRTtnQkFDYixXQUFXLEVBQUUsSUFBSTthQUNsQjtTQUNGO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLENBQUMsMENBQTBDLEVBQUUsR0FBRyxFQUFFO0lBQ3BELFFBQVE7SUFDUixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLEVBQUUsQ0FBQztJQUUxQixPQUFPO0lBQ1AsSUFBSSxzQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO1FBQ3hDLFNBQVMsRUFBRSxJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7WUFDM0QsS0FBSyxFQUFFLEdBQUcsQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO1NBQ25FLENBQUM7UUFDRixjQUFjLEVBQUUsb0JBQW9CO0tBQ3JDLENBQUMsQ0FBQztJQUVILE9BQU87SUFDUCxxQkFBUSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQywyQkFBMkIsRUFBRTtRQUMzRSxhQUFhLEVBQUU7WUFDYixhQUFhLEVBQUU7Z0JBQ2Isa0JBQWtCLEVBQUUsb0JBQW9CO2FBQ3pDO1NBQ0Y7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQywwQkFBMEIsRUFBRSxHQUFHLEVBQUU7SUFDcEMsUUFBUTtJQUNSLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssRUFBRSxDQUFDO0lBRTFCLE9BQU87SUFDUCxNQUFNLFdBQVcsR0FBRyxzQkFBZ0IsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLEVBQUUsdUJBQXVCLEVBQ3pGLG9FQUFvRSxDQUFDLENBQUM7SUFFeEUsT0FBTztJQUNQLE1BQU0sQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxPQUFPLENBQUMsb0VBQW9FLENBQUMsQ0FBQztBQUNySCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSAnYXdzLWNkay1saWIvYXNzZXJ0aW9ucyc7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjcyc7XG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IERuc1BvbGljeSwgRWtzQ29udGFpbmVyRGVmaW5pdGlvbiwgRWtzSm9iRGVmaW5pdGlvbiB9IGZyb20gJy4uL2xpYic7XG5cbnRlc3QoJ0Vjc0pvYkRlZmluaXRpb24gcmVzcGVjdHMgZG5zUG9saWN5JywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IEVrc0pvYkRlZmluaXRpb24oc3RhY2ssICdFS1NKb2JEZWZuJywge1xuICAgIGNvbnRhaW5lcjogbmV3IEVrc0NvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdFa3NDb250YWluZXInLCB7XG4gICAgICBpbWFnZTogZWNzLkNvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgfSksXG4gICAgZG5zUG9saWN5OiBEbnNQb2xpY3kuQ0xVU1RFUl9GSVJTVCxcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Sm9iRGVmaW5pdGlvbicsIHtcbiAgICBFa3NQcm9wZXJ0aWVzOiB7XG4gICAgICBQb2RQcm9wZXJ0aWVzOiB7XG4gICAgICAgIERuc1BvbGljeTogRG5zUG9saWN5LkNMVVNURVJfRklSU1QsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pO1xufSk7XG5cbnRlc3QoJ0Vjc0pvYkRlZmluaXRpb24gcmVzcGVjdHMgdXNlSG9zdE5ldHdvcmsnLCAoKSA9PiB7XG4gIC8vIEdJVkVOXG4gIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKCk7XG5cbiAgLy8gV0hFTlxuICBuZXcgRWtzSm9iRGVmaW5pdGlvbihzdGFjaywgJ0VLU0pvYkRlZm4nLCB7XG4gICAgY29udGFpbmVyOiBuZXcgRWtzQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vrc0NvbnRhaW5lcicsIHtcbiAgICAgIGltYWdlOiBlY3MuQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICB9KSxcbiAgICB1c2VIb3N0TmV0d29yazogdHJ1ZSxcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Sm9iRGVmaW5pdGlvbicsIHtcbiAgICBFa3NQcm9wZXJ0aWVzOiB7XG4gICAgICBQb2RQcm9wZXJ0aWVzOiB7XG4gICAgICAgIEhvc3ROZXR3b3JrOiB0cnVlLFxuICAgICAgfSxcbiAgICB9LFxuICB9KTtcbn0pO1xuXG50ZXN0KCdFY3NKb2JEZWZpbml0aW9uIHJlc3BlY3RzIHNlcnZpY2VBY2NvdW50JywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IEVrc0pvYkRlZmluaXRpb24oc3RhY2ssICdFS1NKb2JEZWZuJywge1xuICAgIGNvbnRhaW5lcjogbmV3IEVrc0NvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdFa3NDb250YWluZXInLCB7XG4gICAgICBpbWFnZTogZWNzLkNvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgfSksXG4gICAgc2VydmljZUFjY291bnQ6ICdteS1zZXJ2aWNlLWFjY291bnQnLFxuICB9KTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpKb2JEZWZpbml0aW9uJywge1xuICAgIEVrc1Byb3BlcnRpZXM6IHtcbiAgICAgIFBvZFByb3BlcnRpZXM6IHtcbiAgICAgICAgU2VydmljZUFjY291bnROYW1lOiAnbXktc2VydmljZS1hY2NvdW50JyxcbiAgICAgIH0sXG4gICAgfSxcbiAgfSk7XG59KTtcblxudGVzdCgnY2FuIGJlIGltcG9ydGVkIGZyb20gQVJOJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgY29uc3QgaW1wb3J0ZWRKb2IgPSBFa3NKb2JEZWZpbml0aW9uLmZyb21Fa3NKb2JEZWZpbml0aW9uQXJuKHN0YWNrLCAnaW1wb3J0ZWRKb2JEZWZpbml0aW9uJyxcbiAgICAnYXJuOmF3czpiYXRjaDp1cy1lYXN0LTE6MTIzNDU2Nzg5MDEyOmpvYi1kZWZpbml0aW9uL2pvYi1kZWYtbmFtZToxJyk7XG5cbiAgLy8gVEhFTlxuICBleHBlY3QoaW1wb3J0ZWRKb2Iuam9iRGVmaW5pdGlvbkFybikudG9FcXVhbCgnYXJuOmF3czpiYXRjaDp1cy1lYXN0LTE6MTIzNDU2Nzg5MDEyOmpvYi1kZWZpbml0aW9uL2pvYi1kZWYtbmFtZToxJyk7XG59KTtcblxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js deleted file mode 100644 index 5d9e85af3e008..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.batch-unique-name.js +++ /dev/null @@ -1,34 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const events = require("aws-cdk-lib/aws-events"); -const targets = require("aws-cdk-lib/aws-events-targets"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const batch = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -const jobQueue = new batch.JobQueue(stack, 'MyQueue', { - computeEnvironments: [ - { - computeEnvironment: new batch.UnmanagedComputeEnvironment(stack, 'ComputeEnvironment'), - order: 1, - }, - ], -}); -const jobDefinition = new batch.EcsJobDefinition(stack, 'MyJob', { - container: new batch.EcsEc2ContainerDefinition(stack, 'container', { - image: aws_ecs_1.ContainerImage.fromRegistry('test-repo'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), -}); -const rule = new events.Rule(stack, 'Rule', { - schedule: events.Schedule.expression('rate(1 minute)'), -}); -rule.addTarget(new targets.BatchJob(jobQueue.jobQueueArn, jobQueue, jobDefinition.jobDefinitionArn, jobDefinition)); -new integ.IntegTest(app, 'BatchUniqueNameTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYmF0Y2gtdW5pcXVlLW5hbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5iYXRjaC11bmlxdWUtbmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUFxRDtBQUNyRCw2Q0FBK0M7QUFDL0MsaURBQWlEO0FBQ2pELDBEQUEwRDtBQUMxRCxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBRWhDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdEMsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxTQUFTLEVBQUU7SUFDcEQsbUJBQW1CLEVBQUU7UUFDbkI7WUFDRSxrQkFBa0IsRUFBRSxJQUFJLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxLQUFLLEVBQUUsb0JBQW9CLENBQUM7WUFDdEYsS0FBSyxFQUFFLENBQUM7U0FDVDtLQUNGO0NBQ0YsQ0FBQyxDQUFDO0FBQ0gsTUFBTSxhQUFhLEdBQUcsSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtJQUMvRCxTQUFTLEVBQUUsSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsS0FBSyxFQUFFLFdBQVcsRUFBRTtRQUNqRSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDO1FBQy9DLEdBQUcsRUFBRSxHQUFHO1FBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztLQUM3QixDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsTUFBTSxJQUFJLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7SUFDMUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDO0NBQ3ZELENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUNqQyxRQUFRLENBQUMsV0FBVyxFQUNwQixRQUFRLEVBQ1IsYUFBYSxDQUFDLGdCQUFnQixFQUM5QixhQUFhLENBQ2QsQ0FBQyxDQUFDO0FBRUgsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxxQkFBcUIsRUFBRTtJQUM5QyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGFpbmVySW1hZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IEFwcCwgU2l6ZSwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBldmVudHMgZnJvbSAnYXdzLWNkay1saWIvYXdzLWV2ZW50cyc7XG5pbXBvcnQgKiBhcyB0YXJnZXRzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1ldmVudHMtdGFyZ2V0cyc7XG5pbXBvcnQgKiBhcyBpbnRlZyBmcm9tICdAYXdzLWNkay9pbnRlZy10ZXN0cy1hbHBoYSc7XG5pbXBvcnQgKiBhcyBiYXRjaCBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3Qgam9iUXVldWUgPSBuZXcgYmF0Y2guSm9iUXVldWUoc3RhY2ssICdNeVF1ZXVlJywge1xuICBjb21wdXRlRW52aXJvbm1lbnRzOiBbXG4gICAge1xuICAgICAgY29tcHV0ZUVudmlyb25tZW50OiBuZXcgYmF0Y2guVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnQ29tcHV0ZUVudmlyb25tZW50JyksXG4gICAgICBvcmRlcjogMSxcbiAgICB9LFxuICBdLFxufSk7XG5jb25zdCBqb2JEZWZpbml0aW9uID0gbmV3IGJhdGNoLkVjc0pvYkRlZmluaXRpb24oc3RhY2ssICdNeUpvYicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ2NvbnRhaW5lcicsIHtcbiAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCd0ZXN0LXJlcG8nKSxcbiAgICBjcHU6IDI1NixcbiAgICBtZW1vcnk6IFNpemUubWViaWJ5dGVzKDIwNDgpLFxuICB9KSxcbn0pO1xuXG5jb25zdCBydWxlID0gbmV3IGV2ZW50cy5SdWxlKHN0YWNrLCAnUnVsZScsIHtcbiAgc2NoZWR1bGU6IGV2ZW50cy5TY2hlZHVsZS5leHByZXNzaW9uKCdyYXRlKDEgbWludXRlKScpLFxufSk7XG5cbnJ1bGUuYWRkVGFyZ2V0KG5ldyB0YXJnZXRzLkJhdGNoSm9iKFxuICBqb2JRdWV1ZS5qb2JRdWV1ZUFybixcbiAgam9iUXVldWUsXG4gIGpvYkRlZmluaXRpb24uam9iRGVmaW5pdGlvbkFybixcbiAgam9iRGVmaW5pdGlvbixcbikpO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoVW5pcXVlTmFtZVRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js deleted file mode 100644 index acacc540d2191..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.ecs-job-definition.js +++ /dev/null @@ -1,94 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); -const efs = require("aws-cdk-lib/aws-efs"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const ssm = require("aws-cdk-lib/aws-ssm"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const batch = require("../lib"); -const aws_ecr_assets_1 = require("aws-cdk-lib/aws-ecr-assets"); -const path = require("path"); -const secretsmanager = require("aws-cdk-lib/aws-secretsmanager"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); -new batch.EcsJobDefinition(stack, 'ECSJobDefn', { - container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - environment: { - foo: 'bar', - }, - gpu: 12, - volumes: [ - batch.EcsVolume.host({ - name: 'volumeName', - hostPath: '/foo/bar', - containerPath: 'ahhh', - }), - batch.EcsVolume.efs({ - fileSystem: new efs.FileSystem(stack, 'myFileSystem', { - vpc, - }), - name: 'efsVolume', - containerPath: '/my/path', - }), - ], - ulimits: [{ - hardLimit: 50, - name: batch.UlimitName.CORE, - softLimit: 10, - }], - secrets: { - MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'mySecret')), - ANOTHER_ONE: batch.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'anotherSecret'), { - versionId: 'foo', - versionStage: 'bar', - }), - SSM_TIME: batch.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'ssm', { stringValue: 'myString' })), - }, - }), -}); -new batch.EcsJobDefinition(stack, 'ECSFargateJobDefn', { - container: new batch.EcsFargateContainerDefinition(stack, 'myFargateContainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - cpu: 16, - memory: aws_cdk_lib_1.Size.mebibytes(32768), - ephemeralStorageSize: aws_cdk_lib_1.Size.gibibytes(100), - fargatePlatformVersion: aws_ecs_1.FargatePlatformVersion.LATEST, - }), - jobDefinitionName: 'foofoo', - parameters: { - foo: 'bar', - }, - propagateTags: true, - retryAttempts: 5, - retryStrategies: [ - new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER), - new batch.RetryStrategy(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE), - new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.custom({ - onExitCode: '40*', - onReason: 'reason', - onStatusReason: 'statusreason', - })), - ], - schedulingPriority: 10, - timeout: aws_cdk_lib_1.Duration.minutes(10), -}); -new batch.EcsJobDefinition(stack, 'ECSDockerJobDefn', { - container: new batch.EcsEc2ContainerDefinition(stack, 'EcsDockerContainer', { - cpu: 16, - memory: aws_cdk_lib_1.Size.mebibytes(32768), - image: ecs.ContainerImage.fromDockerImageAsset(new aws_ecr_assets_1.DockerImageAsset(stack, 'dockerImageAsset', { - directory: path.join(__dirname, 'batchjob-image'), - })), - }), -}); -new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ.ecs-job-definition.js","sourceRoot":"","sources":["integ.ecs-job-definition.ts"],"names":[],"mappings":";;AAAA,iDAA0C;AAC1C,iDAA6E;AAC7E,2CAA2C;AAC3C,2CAA2C;AAC3C,2CAA2C;AAC3C,6CAAyD;AACzD,oDAAoD;AACpD,gCAAgC;AAChC,+DAA8D;AAC9D,6BAA6B;AAC7B,iEAAiE;AAEjE,MAAM,GAAG,GAAG,IAAI,iBAAG,EAAE,CAAC;AACtB,MAAM,KAAK,GAAG,IAAI,mBAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;AACtC,MAAM,GAAG,GAAG,IAAI,aAAG,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,4BAA4B,EAAE,KAAK,EAAE,CAAC,CAAC;AAE3E,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;IAC9C,SAAS,EAAE,IAAI,KAAK,CAAC,yBAAyB,CAAC,KAAK,EAAE,aAAa,EAAE;QACnE,KAAK,EAAE,wBAAc,CAAC,YAAY,CAAC,0BAA0B,CAAC;QAC9D,GAAG,EAAE,GAAG;QACR,MAAM,EAAE,kBAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QAC5B,WAAW,EAAE;YACX,GAAG,EAAE,KAAK;SACX;QACD,GAAG,EAAE,EAAE;QACP,OAAO,EAAE;YACP,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC;gBACnB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,UAAU;gBACpB,aAAa,EAAE,MAAM;aACtB,CAAC;YACF,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC;gBAClB,UAAU,EAAE,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,EAAE,cAAc,EAAE;oBACpD,GAAG;iBACJ,CAAC;gBACF,IAAI,EAAE,WAAW;gBACjB,aAAa,EAAE,UAAU;aAC1B,CAAC;SACH;QACD,OAAO,EAAE,CAAC;gBACR,SAAS,EAAE,EAAE;gBACb,IAAI,EAAE,KAAK,CAAC,UAAU,CAAC,IAAI;gBAC3B,SAAS,EAAE,EAAE;aACd,CAAC;QACF,OAAO,EAAE;YACP,iBAAiB,EAAE,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,IAAI,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;YAChG,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,yBAAyB,CAAC,IAAI,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE;gBACrG,SAAS,EAAE,KAAK;gBAChB,YAAY,EAAE,KAAK;aACpB,CAAC;YACF,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC,CAAC;SAC5G;KACF,CAAC;CACH,CAAC,CAAC;AAEH,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,EAAE,mBAAmB,EAAE;IACrD,SAAS,EAAE,IAAI,KAAK,CAAC,6BAA6B,CAAC,KAAK,EAAE,oBAAoB,EAAE;QAC9E,KAAK,EAAE,wBAAc,CAAC,YAAY,CAAC,0BAA0B,CAAC;QAC9D,GAAG,EAAE,EAAE;QACP,MAAM,EAAE,kBAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QAC7B,oBAAoB,EAAE,kBAAI,CAAC,SAAS,CAAC,GAAG,CAAC;QACzC,sBAAsB,EAAE,gCAAsB,CAAC,MAAM;KACtD,CAAC;IACF,iBAAiB,EAAE,QAAQ;IAC3B,UAAU,EAAE;QACV,GAAG,EAAE,KAAK;KACX;IACD,aAAa,EAAE,IAAI;IACnB,aAAa,EAAE,CAAC;IAChB,eAAe,EAAE;QACf,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,qBAAqB,CAAC;QAC9E,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC;QAC5E,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;YAC7D,UAAU,EAAE,KAAK;YACjB,QAAQ,EAAE,QAAQ;YAClB,cAAc,EAAE,cAAc;SAC/B,CAAC,CAAC;KACJ;IACD,kBAAkB,EAAE,EAAE;IACtB,OAAO,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;CAC9B,CAAC,CAAC;AAEH,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,EAAE,kBAAkB,EAAE;IACpD,SAAS,EAAE,IAAI,KAAK,CAAC,yBAAyB,CAAC,KAAK,EAAE,oBAAoB,EAAE;QAC1E,GAAG,EAAE,EAAE;QACP,MAAM,EAAE,kBAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QAC7B,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,oBAAoB,CAAC,IAAI,iCAAgB,CAAC,KAAK,EAAE,kBAAkB,EAAE;YAC7F,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC;SAClD,CAAC,CAAC;KACJ,CAAC;CACH,CAAC,CAAC;AAEH,IAAI,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE,2BAA2B,EAAE;IACpD,SAAS,EAAE,CAAC,KAAK,CAAC;CACnB,CAAC,CAAC;AAEH,GAAG,CAAC,KAAK,EAAE,CAAC","sourcesContent":["import { Vpc } from 'aws-cdk-lib/aws-ec2';\nimport { ContainerImage, FargatePlatformVersion } from 'aws-cdk-lib/aws-ecs';\nimport * as efs from 'aws-cdk-lib/aws-efs';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { App, Duration, Size, Stack } from 'aws-cdk-lib';\nimport * as integ from '@aws-cdk/integ-tests-alpha';\nimport * as batch from '../lib';\nimport { DockerImageAsset } from 'aws-cdk-lib/aws-ecr-assets';\nimport * as path from 'path';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\n\nconst app = new App();\nconst stack = new Stack(app, 'stack');\nconst vpc = new Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false });\n\nnew batch.EcsJobDefinition(stack, 'ECSJobDefn', {\n  container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', {\n    image: ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n    cpu: 256,\n    memory: Size.mebibytes(2048),\n    environment: {\n      foo: 'bar',\n    },\n    gpu: 12,\n    volumes: [\n      batch.EcsVolume.host({\n        name: 'volumeName',\n        hostPath: '/foo/bar',\n        containerPath: 'ahhh',\n      }),\n      batch.EcsVolume.efs({\n        fileSystem: new efs.FileSystem(stack, 'myFileSystem', {\n          vpc,\n        }),\n        name: 'efsVolume',\n        containerPath: '/my/path',\n      }),\n    ],\n    ulimits: [{\n      hardLimit: 50,\n      name: batch.UlimitName.CORE,\n      softLimit: 10,\n    }],\n    secrets: {\n      MY_SECRET_ENV_VAR: batch.Secret.fromSecretsManager(new secretsmanager.Secret(stack, 'mySecret')),\n      ANOTHER_ONE: batch.Secret.fromSecretsManagerVersion(new secretsmanager.Secret(stack, 'anotherSecret'), {\n        versionId: 'foo',\n        versionStage: 'bar',\n      }),\n      SSM_TIME: batch.Secret.fromSsmParameter(new ssm.StringParameter(stack, 'ssm', { stringValue: 'myString' })),\n    },\n  }),\n});\n\nnew batch.EcsJobDefinition(stack, 'ECSFargateJobDefn', {\n  container: new batch.EcsFargateContainerDefinition(stack, 'myFargateContainer', {\n    image: ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n    cpu: 16,\n    memory: Size.mebibytes(32768),\n    ephemeralStorageSize: Size.gibibytes(100),\n    fargatePlatformVersion: FargatePlatformVersion.LATEST,\n  }),\n  jobDefinitionName: 'foofoo',\n  parameters: {\n    foo: 'bar',\n  },\n  propagateTags: true,\n  retryAttempts: 5,\n  retryStrategies: [\n    new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n    new batch.RetryStrategy(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE),\n    new batch.RetryStrategy(batch.Action.EXIT, batch.Reason.custom({\n      onExitCode: '40*',\n      onReason: 'reason',\n      onStatusReason: 'statusreason',\n    })),\n  ],\n  schedulingPriority: 10,\n  timeout: Duration.minutes(10),\n});\n\nnew batch.EcsJobDefinition(stack, 'ECSDockerJobDefn', {\n  container: new batch.EcsEc2ContainerDefinition(stack, 'EcsDockerContainer', {\n    cpu: 16,\n    memory: Size.mebibytes(32768),\n    image: ecs.ContainerImage.fromDockerImageAsset(new DockerImageAsset(stack, 'dockerImageAsset', {\n      directory: path.join(__dirname, 'batchjob-image'),\n    })),\n  }),\n});\n\nnew integ.IntegTest(app, 'BatchEcsJobDefinitionTest', {\n  testCases: [stack],\n});\n\napp.synth();\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js deleted file mode 100644 index ec09421f64761..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.eks-job-definition.js +++ /dev/null @@ -1,59 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const batch = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -new batch.EksJobDefinition(stack, 'EksJobDefn', { - container: new batch.EksContainerDefinition(stack, 'EksContainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - args: ['foo'], - command: ['echo foo'], - env: { foo: 'bar' }, - cpuLimit: 8, - cpuReservation: 4, - memoryLimit: aws_cdk_lib_1.Size.mebibytes(8192), - memoryReservation: aws_cdk_lib_1.Size.mebibytes(8192), - gpuLimit: 12, - gpuReservation: 12, - imagePullPolicy: batch.ImagePullPolicy.ALWAYS, - name: 'myBigCoolVolume', - privileged: true, - readonlyRootFilesystem: false, - runAsGroup: 1, - runAsRoot: false, - runAsUser: 20, - volumes: [ - batch.EksVolume.emptyDir({ - name: 'woah', - mountPath: '/mount/path', - medium: batch.EmptyDirMediumType.MEMORY, - readonly: true, - sizeLimit: aws_cdk_lib_1.Size.mebibytes(2048), - }), - batch.EksVolume.secret({ - name: 'secretVolumeName', - secretName: 'secretName', - mountPath: '/secret/path', - optional: false, - }), - batch.EksVolume.secret({ - name: 'defaultOptionalSettingSecretVolume', - secretName: 'NewSecretName', - mountPath: '/secret/path2', - }), - batch.EksVolume.hostPath({ - name: 'hostPath', - hostPath: '/foo/bar', - mountPath: '/fooasdfadfs', - }), - ], - }), -}); -new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZWtzLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZWtzLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQXFEO0FBQ3JELDZDQUErQztBQUMvQyxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBRWhDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFFdEMsSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtJQUM5QyxTQUFTLEVBQUUsSUFBSSxLQUFLLENBQUMsc0JBQXNCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtRQUNqRSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsMEJBQTBCLENBQUM7UUFDOUQsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDO1FBQ2IsT0FBTyxFQUFFLENBQUMsVUFBVSxDQUFDO1FBQ3JCLEdBQUcsRUFBRSxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUU7UUFDbkIsUUFBUSxFQUFFLENBQUM7UUFDWCxjQUFjLEVBQUUsQ0FBQztRQUNqQixXQUFXLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO1FBQ2pDLGlCQUFpQixFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztRQUN2QyxRQUFRLEVBQUUsRUFBRTtRQUNaLGNBQWMsRUFBRSxFQUFFO1FBQ2xCLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLE1BQU07UUFDN0MsSUFBSSxFQUFFLGlCQUFpQjtRQUN2QixVQUFVLEVBQUUsSUFBSTtRQUNoQixzQkFBc0IsRUFBRSxLQUFLO1FBQzdCLFVBQVUsRUFBRSxDQUFDO1FBQ2IsU0FBUyxFQUFFLEtBQUs7UUFDaEIsU0FBUyxFQUFFLEVBQUU7UUFDYixPQUFPLEVBQUU7WUFDUCxLQUFLLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQztnQkFDdkIsSUFBSSxFQUFFLE1BQU07Z0JBQ1osU0FBUyxFQUFFLGFBQWE7Z0JBQ3hCLE1BQU0sRUFBRSxLQUFLLENBQUMsa0JBQWtCLENBQUMsTUFBTTtnQkFDdkMsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsU0FBUyxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQzthQUNoQyxDQUFDO1lBQ0YsS0FBSyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7Z0JBQ3JCLElBQUksRUFBRSxrQkFBa0I7Z0JBQ3hCLFVBQVUsRUFBRSxZQUFZO2dCQUN4QixTQUFTLEVBQUUsY0FBYztnQkFDekIsUUFBUSxFQUFFLEtBQUs7YUFDaEIsQ0FBQztZQUNGLEtBQUssQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO2dCQUNyQixJQUFJLEVBQUUsb0NBQW9DO2dCQUMxQyxVQUFVLEVBQUUsZUFBZTtnQkFDM0IsU0FBUyxFQUFFLGVBQWU7YUFDM0IsQ0FBQztZQUNGLEtBQUssQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO2dCQUN2QixJQUFJLEVBQUUsVUFBVTtnQkFDaEIsUUFBUSxFQUFFLFVBQVU7Z0JBQ3BCLFNBQVMsRUFBRSxjQUFjO2FBQzFCLENBQUM7U0FDSDtLQUNGLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLDJCQUEyQixFQUFFO0lBQ3BELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250YWluZXJJbWFnZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lY3MnO1xuaW1wb3J0IHsgQXBwLCBTdGFjaywgU2l6ZSB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCAqIGFzIGJhdGNoIGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ3N0YWNrJyk7XG5cbm5ldyBiYXRjaC5Fa3NKb2JEZWZpbml0aW9uKHN0YWNrLCAnRWtzSm9iRGVmbicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWtzQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vrc0NvbnRhaW5lcicsIHtcbiAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICBhcmdzOiBbJ2ZvbyddLFxuICAgIGNvbW1hbmQ6IFsnZWNobyBmb28nXSxcbiAgICBlbnY6IHsgZm9vOiAnYmFyJyB9LFxuICAgIGNwdUxpbWl0OiA4LFxuICAgIGNwdVJlc2VydmF0aW9uOiA0LFxuICAgIG1lbW9yeUxpbWl0OiBTaXplLm1lYmlieXRlcyg4MTkyKSxcbiAgICBtZW1vcnlSZXNlcnZhdGlvbjogU2l6ZS5tZWJpYnl0ZXMoODE5MiksXG4gICAgZ3B1TGltaXQ6IDEyLFxuICAgIGdwdVJlc2VydmF0aW9uOiAxMixcbiAgICBpbWFnZVB1bGxQb2xpY3k6IGJhdGNoLkltYWdlUHVsbFBvbGljeS5BTFdBWVMsXG4gICAgbmFtZTogJ215QmlnQ29vbFZvbHVtZScsXG4gICAgcHJpdmlsZWdlZDogdHJ1ZSxcbiAgICByZWFkb25seVJvb3RGaWxlc3lzdGVtOiBmYWxzZSxcbiAgICBydW5Bc0dyb3VwOiAxLFxuICAgIHJ1bkFzUm9vdDogZmFsc2UsXG4gICAgcnVuQXNVc2VyOiAyMCxcbiAgICB2b2x1bWVzOiBbXG4gICAgICBiYXRjaC5Fa3NWb2x1bWUuZW1wdHlEaXIoe1xuICAgICAgICBuYW1lOiAnd29haCcsXG4gICAgICAgIG1vdW50UGF0aDogJy9tb3VudC9wYXRoJyxcbiAgICAgICAgbWVkaXVtOiBiYXRjaC5FbXB0eURpck1lZGl1bVR5cGUuTUVNT1JZLFxuICAgICAgICByZWFkb25seTogdHJ1ZSxcbiAgICAgICAgc2l6ZUxpbWl0OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgICAgIH0pLFxuICAgICAgYmF0Y2guRWtzVm9sdW1lLnNlY3JldCh7XG4gICAgICAgIG5hbWU6ICdzZWNyZXRWb2x1bWVOYW1lJyxcbiAgICAgICAgc2VjcmV0TmFtZTogJ3NlY3JldE5hbWUnLFxuICAgICAgICBtb3VudFBhdGg6ICcvc2VjcmV0L3BhdGgnLFxuICAgICAgICBvcHRpb25hbDogZmFsc2UsXG4gICAgICB9KSxcbiAgICAgIGJhdGNoLkVrc1ZvbHVtZS5zZWNyZXQoe1xuICAgICAgICBuYW1lOiAnZGVmYXVsdE9wdGlvbmFsU2V0dGluZ1NlY3JldFZvbHVtZScsXG4gICAgICAgIHNlY3JldE5hbWU6ICdOZXdTZWNyZXROYW1lJyxcbiAgICAgICAgbW91bnRQYXRoOiAnL3NlY3JldC9wYXRoMicsXG4gICAgICB9KSxcbiAgICAgIGJhdGNoLkVrc1ZvbHVtZS5ob3N0UGF0aCh7XG4gICAgICAgIG5hbWU6ICdob3N0UGF0aCcsXG4gICAgICAgIGhvc3RQYXRoOiAnL2Zvby9iYXInLFxuICAgICAgICBtb3VudFBhdGg6ICcvZm9vYXNkZmFkZnMnLFxuICAgICAgfSksXG4gICAgXSxcbiAgfSksXG59KTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaEVjc0pvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js deleted file mode 100644 index 96eab371eb46c..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.grants.js +++ /dev/null @@ -1,35 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const iam = require("aws-cdk-lib/aws-iam"); -const batch = require("../lib"); -const lib_1 = require("../lib"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); -const queue = new batch.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'managedEc2CE', { - vpc, - }), - order: 1, - }], - priority: 10, -}); -const ecsJob = new batch.EcsJobDefinition(stack, 'ECSJob', { - container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('foorepo/fooimage'), - }), -}); -const user = new iam.User(stack, 'MyUser'); -ecsJob.grantSubmitJob(user, queue); -new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZ3JhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZ3JhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQTBDO0FBQzFDLDZDQUErQztBQUMvQyxvREFBb0Q7QUFDcEQsMkNBQTJDO0FBQzNDLGdDQUFnQztBQUNoQyxnQ0FBeUQ7QUFDekQsMkNBQTJDO0FBRTNDLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxhQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLDRCQUE0QixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFFM0UsTUFBTSxLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7SUFDL0MsbUJBQW1CLEVBQUUsQ0FBQztZQUNwQixrQkFBa0IsRUFBRSxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUU7Z0JBQzdFLEdBQUc7YUFDSixDQUFDO1lBQ0YsS0FBSyxFQUFFLENBQUM7U0FDVCxDQUFDO0lBQ0YsUUFBUSxFQUFFLEVBQUU7Q0FDYixDQUFDLENBQUM7QUFFSCxNQUFNLE1BQU0sR0FBRyxJQUFJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsUUFBUSxFQUFFO0lBQ3pELFNBQVMsRUFBRSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFO1FBQ3BFLEdBQUcsRUFBRSxHQUFHO1FBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztRQUM1QixLQUFLLEVBQUUsR0FBRyxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsa0JBQWtCLENBQUM7S0FDM0QsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVILE1BQU0sSUFBSSxHQUFHLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7QUFDM0MsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFbkMsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSwyQkFBMkIsRUFBRTtJQUNwRCxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVnBjIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XG5pbXBvcnQgeyBBcHAsIFN0YWNrLCBTaXplIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgaW50ZWcgZnJvbSAnQGF3cy1jZGsvaW50ZWctdGVzdHMtYWxwaGEnO1xuaW1wb3J0ICogYXMgaWFtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0ICogYXMgYmF0Y2ggZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQgfSBmcm9tICcuLi9saWInO1xuaW1wb3J0ICogYXMgZWNzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lY3MnO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3QgdnBjID0gbmV3IFZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbmNvbnN0IHF1ZXVlID0gbmV3IGJhdGNoLkpvYlF1ZXVlKHN0YWNrLCAnam9CQlEnLCB7XG4gIGNvbXB1dGVFbnZpcm9ubWVudHM6IFt7XG4gICAgY29tcHV0ZUVudmlyb25tZW50OiBuZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21hbmFnZWRFYzJDRScsIHtcbiAgICAgIHZwYyxcbiAgICB9KSxcbiAgICBvcmRlcjogMSxcbiAgfV0sXG4gIHByaW9yaXR5OiAxMCxcbn0pO1xuXG5jb25zdCBlY3NKb2IgPSBuZXcgYmF0Y2guRWNzSm9iRGVmaW5pdGlvbihzdGFjaywgJ0VDU0pvYicsIHtcbiAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ0Vjc0NvbnRhaW5lcicsIHtcbiAgICBjcHU6IDI1NixcbiAgICBtZW1vcnk6IFNpemUubWViaWJ5dGVzKDIwNDgpLFxuICAgIGltYWdlOiBlY3MuQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdmb29yZXBvL2Zvb2ltYWdlJyksXG4gIH0pLFxufSk7XG5cbmNvbnN0IHVzZXIgPSBuZXcgaWFtLlVzZXIoc3RhY2ssICdNeVVzZXInKTtcbmVjc0pvYi5ncmFudFN1Ym1pdEpvYih1c2VyLCBxdWV1ZSk7XG5cbm5ldyBpbnRlZy5JbnRlZ1Rlc3QoYXBwLCAnQmF0Y2hFY3NKb2JEZWZpbml0aW9uVGVzdCcsIHtcbiAgdGVzdENhc2VzOiBbc3RhY2tdLFxufSk7XG5cbmFwcC5zeW50aCgpO1xuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js deleted file mode 100644 index 5798e3b70f7e9..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.job-queue.js +++ /dev/null @@ -1,41 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const batch = require("../lib"); -const lib_1 = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -const vpc = new aws_ec2_1.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); -const fairsharePolicy = new batch.FairshareSchedulingPolicy(stack, 'fairshare', { - computeReservation: 75, - schedulingPolicyName: 'joBBQFairsharePolicy', - shareDecay: aws_cdk_lib_1.Duration.hours(1), - shares: [{ - shareIdentifier: 'shareA', - weightFactor: 0.5, - }], -}); -const queue = new batch.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'managedEc2CE', { - vpc, - }), - order: 1, - }], - priority: 10, - schedulingPolicy: fairsharePolicy, -}); -fairsharePolicy.addShare({ - shareIdentifier: 'shareB', - weightFactor: 7, -}); -queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'newManagedEc2CE', { - vpc, -}), 2); -new integ.IntegTest(app, 'BatchEcsJobDefinitionTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuam9iLXF1ZXVlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuam9iLXF1ZXVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQTBDO0FBQzFDLDZDQUFtRDtBQUNuRCxvREFBb0Q7QUFDcEQsZ0NBQWdDO0FBQ2hDLGdDQUF5RDtBQUV6RCxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ3RDLE1BQU0sR0FBRyxHQUFHLElBQUksYUFBRyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSw0QkFBNEIsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0FBRTNFLE1BQU0sZUFBZSxHQUFHLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxXQUFXLEVBQUU7SUFDOUUsa0JBQWtCLEVBQUUsRUFBRTtJQUN0QixvQkFBb0IsRUFBRSxzQkFBc0I7SUFDNUMsVUFBVSxFQUFFLHNCQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUM3QixNQUFNLEVBQUUsQ0FBQztZQUNQLGVBQWUsRUFBRSxRQUFRO1lBQ3pCLFlBQVksRUFBRSxHQUFHO1NBQ2xCLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtJQUMvQyxtQkFBbUIsRUFBRSxDQUFDO1lBQ3BCLGtCQUFrQixFQUFFLElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtnQkFDN0UsR0FBRzthQUNKLENBQUM7WUFDRixLQUFLLEVBQUUsQ0FBQztTQUNULENBQUM7SUFDRixRQUFRLEVBQUUsRUFBRTtJQUNaLGdCQUFnQixFQUFFLGVBQWU7Q0FDbEMsQ0FBQyxDQUFDO0FBRUgsZUFBZSxDQUFDLFFBQVEsQ0FBQztJQUN2QixlQUFlLEVBQUUsUUFBUTtJQUN6QixZQUFZLEVBQUUsQ0FBQztDQUNoQixDQUFDLENBQUM7QUFFSCxLQUFLLENBQUMscUJBQXFCLENBQ3pCLElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGlCQUFpQixFQUFFO0lBQzVELEdBQUc7Q0FDSixDQUFDLEVBQ0YsQ0FBQyxDQUNGLENBQUM7QUFFRixJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLDJCQUEyQixFQUFFO0lBQ3BELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWcGMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IEFwcCwgU3RhY2ssIER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgaW50ZWcgZnJvbSAnQGF3cy1jZGsvaW50ZWctdGVzdHMtYWxwaGEnO1xuaW1wb3J0ICogYXMgYmF0Y2ggZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQgfSBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuY29uc3QgdnBjID0gbmV3IFZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbmNvbnN0IGZhaXJzaGFyZVBvbGljeSA9IG5ldyBiYXRjaC5GYWlyc2hhcmVTY2hlZHVsaW5nUG9saWN5KHN0YWNrLCAnZmFpcnNoYXJlJywge1xuICBjb21wdXRlUmVzZXJ2YXRpb246IDc1LFxuICBzY2hlZHVsaW5nUG9saWN5TmFtZTogJ2pvQkJRRmFpcnNoYXJlUG9saWN5JyxcbiAgc2hhcmVEZWNheTogRHVyYXRpb24uaG91cnMoMSksXG4gIHNoYXJlczogW3tcbiAgICBzaGFyZUlkZW50aWZpZXI6ICdzaGFyZUEnLFxuICAgIHdlaWdodEZhY3RvcjogMC41LFxuICB9XSxcbn0pO1xuXG5jb25zdCBxdWV1ZSA9IG5ldyBiYXRjaC5Kb2JRdWV1ZShzdGFjaywgJ2pvQkJRJywge1xuICBjb21wdXRlRW52aXJvbm1lbnRzOiBbe1xuICAgIGNvbXB1dGVFbnZpcm9ubWVudDogbmV3IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdtYW5hZ2VkRWMyQ0UnLCB7XG4gICAgICB2cGMsXG4gICAgfSksXG4gICAgb3JkZXI6IDEsXG4gIH1dLFxuICBwcmlvcml0eTogMTAsXG4gIHNjaGVkdWxpbmdQb2xpY3k6IGZhaXJzaGFyZVBvbGljeSxcbn0pO1xuXG5mYWlyc2hhcmVQb2xpY3kuYWRkU2hhcmUoe1xuICBzaGFyZUlkZW50aWZpZXI6ICdzaGFyZUInLFxuICB3ZWlnaHRGYWN0b3I6IDcsXG59KTtcblxucXVldWUuYWRkQ29tcHV0ZUVudmlyb25tZW50KFxuICBuZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ25ld01hbmFnZWRFYzJDRScsIHtcbiAgICB2cGMsXG4gIH0pLFxuICAyLFxuKTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaEVjc0pvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js deleted file mode 100644 index 29a0fed0681b9..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.managed-compute-environment.js +++ /dev/null @@ -1,78 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const lib_1 = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'batch-stack'); -const vpc = new ec2.Vpc(stack, 'vpc', { restrictDefaultSecurityGroup: false }); -new lib_1.FargateComputeEnvironment(stack, 'minimalPropsFargate', { - vpc, - maxvCpus: 512, -}); -new lib_1.FargateComputeEnvironment(stack, 'maximalPropsFargate', { - vpc, - maxvCpus: 512, - computeEnvironmentName: 'maxPropsFargateCE', - replaceComputeEnvironment: true, - spot: true, - terminateOnUpdate: true, - updateTimeout: aws_cdk_lib_1.Duration.minutes(30), - updateToLatestImageVersion: false, -}); -new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'minimalPropsEc2', { - vpc, - images: [{ - image: new ec2.AmazonLinuxImage(), - }], -}); -new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'LaunchTemplate', { - vpc, - images: [{ - image: new ec2.AmazonLinuxImage(), - }], - allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, - minvCpus: 256, - maxvCpus: 512, - replaceComputeEnvironment: true, - terminateOnUpdate: false, - placementGroup: new ec2.PlacementGroup(stack, 'placementGroup'), - updateTimeout: aws_cdk_lib_1.Duration.hours(1), - launchTemplate: new aws_ec2_1.LaunchTemplate(stack, 'launchTemplate'), -}); -new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SpotEc2', { - vpc, - images: [{ - image: new ec2.AmazonLinuxImage(), - }], - spot: true, - spotBidPercentage: 95, - spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { - assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), - }), -}); -new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'AllocationStrategySPOT_CAPACITY', { - vpc, - images: [{ - image: new ec2.AmazonLinuxImage(), - }], - spot: true, - spotBidPercentage: 95, - allocationStrategy: lib_1.AllocationStrategy.SPOT_CAPACITY_OPTIMIZED, -}); -const taggedEc2Ecs = new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'taggedCE', { - vpc, - images: [{ - image: new ec2.AmazonLinuxImage(), - }], -}); -aws_cdk_lib_1.Tags.of(taggedEc2Ecs).add('foo', 'bar'); -aws_cdk_lib_1.Tags.of(taggedEc2Ecs).add('super', 'salamander'); -new integ.IntegTest(app, 'BatchManagedComputeEnvironmentTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsMkNBQTJDO0FBQzNDLGlEQUFxRDtBQUNyRCxpREFBNkQ7QUFDN0QsNkNBQXlEO0FBQ3pELG9EQUFvRDtBQUNwRCxnQ0FBd0c7QUFFeEcsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSxhQUFhLENBQUMsQ0FBQztBQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLDRCQUE0QixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFFL0UsSUFBSSwrQkFBeUIsQ0FBQyxLQUFLLEVBQUUscUJBQXFCLEVBQUU7SUFDMUQsR0FBRztJQUNILFFBQVEsRUFBRSxHQUFHO0NBQ2QsQ0FBQyxDQUFDO0FBRUgsSUFBSSwrQkFBeUIsQ0FBQyxLQUFLLEVBQUUscUJBQXFCLEVBQUU7SUFDMUQsR0FBRztJQUNILFFBQVEsRUFBRSxHQUFHO0lBQ2Isc0JBQXNCLEVBQUUsbUJBQW1CO0lBQzNDLHlCQUF5QixFQUFFLElBQUk7SUFDL0IsSUFBSSxFQUFFLElBQUk7SUFDVixpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLGFBQWEsRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7SUFDbkMsMEJBQTBCLEVBQUUsS0FBSztDQUNsQyxDQUFDLENBQUM7QUFFSCxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxpQkFBaUIsRUFBRTtJQUM1RCxHQUFHO0lBQ0gsTUFBTSxFQUFFLENBQUM7WUFDUCxLQUFLLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLEVBQUU7U0FDbEMsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVILElBQUkscUNBQStCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixFQUFFO0lBQzNELEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0lBQ0Ysa0JBQWtCLEVBQUUsd0JBQWtCLENBQUMsUUFBUTtJQUMvQyxRQUFRLEVBQUUsR0FBRztJQUNiLFFBQVEsRUFBRSxHQUFHO0lBQ2IseUJBQXlCLEVBQUUsSUFBSTtJQUMvQixpQkFBaUIsRUFBRSxLQUFLO0lBQ3hCLGNBQWMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDO0lBQy9ELGFBQWEsRUFBRSxzQkFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDaEMsY0FBYyxFQUFFLElBQUksd0JBQWMsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUM7Q0FDNUQsQ0FBQyxDQUFDO0FBRUgsSUFBSSxxQ0FBK0IsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO0lBQ3BELEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0lBQ0YsSUFBSSxFQUFFLElBQUk7SUFDVixpQkFBaUIsRUFBRSxFQUFFO0lBQ3JCLGFBQWEsRUFBRSxJQUFJLGNBQUksQ0FBQyxLQUFLLEVBQUUsZUFBZSxFQUFFO1FBQzlDLFNBQVMsRUFBRSxJQUFJLDBCQUFnQixDQUFDLHFCQUFxQixDQUFDO0tBQ3ZELENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLHFDQUErQixDQUFDLEtBQUssRUFBRSxpQ0FBaUMsRUFBRTtJQUM1RSxHQUFHO0lBQ0gsTUFBTSxFQUFFLENBQUM7WUFDUCxLQUFLLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLEVBQUU7U0FDbEMsQ0FBQztJQUNGLElBQUksRUFBRSxJQUFJO0lBQ1YsaUJBQWlCLEVBQUUsRUFBRTtJQUNyQixrQkFBa0IsRUFBRSx3QkFBa0IsQ0FBQyx1QkFBdUI7Q0FDL0QsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSxxQ0FBK0IsQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFO0lBQzFFLEdBQUc7SUFDSCxNQUFNLEVBQUUsQ0FBQztZQUNQLEtBQUssRUFBRSxJQUFJLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRTtTQUNsQyxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsa0JBQUksQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUN4QyxrQkFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDO0FBRWpELElBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsb0NBQW9DLEVBQUU7SUFDN0QsU0FBUyxFQUFFLENBQUMsS0FBSyxDQUFDO0NBQ25CLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCB7IExhdW5jaFRlbXBsYXRlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjMic7XG5pbXBvcnQgeyBSb2xlLCBTZXJ2aWNlUHJpbmNpcGFsIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWlhbSc7XG5pbXBvcnQgeyBBcHAsIER1cmF0aW9uLCBTdGFjaywgVGFncyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCB7IEFsbG9jYXRpb25TdHJhdGVneSwgRmFyZ2F0ZUNvbXB1dGVFbnZpcm9ubWVudCwgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudCB9IGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ2JhdGNoLXN0YWNrJyk7XG5jb25zdCB2cGMgPSBuZXcgZWMyLlZwYyhzdGFjaywgJ3ZwYycsIHsgcmVzdHJpY3REZWZhdWx0U2VjdXJpdHlHcm91cDogZmFsc2UgfSk7XG5cbm5ldyBGYXJnYXRlQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnbWluaW1hbFByb3BzRmFyZ2F0ZScsIHtcbiAgdnBjLFxuICBtYXh2Q3B1czogNTEyLFxufSk7XG5cbm5ldyBGYXJnYXRlQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAnbWF4aW1hbFByb3BzRmFyZ2F0ZScsIHtcbiAgdnBjLFxuICBtYXh2Q3B1czogNTEyLFxuICBjb21wdXRlRW52aXJvbm1lbnROYW1lOiAnbWF4UHJvcHNGYXJnYXRlQ0UnLFxuICByZXBsYWNlQ29tcHV0ZUVudmlyb25tZW50OiB0cnVlLFxuICBzcG90OiB0cnVlLFxuICB0ZXJtaW5hdGVPblVwZGF0ZTogdHJ1ZSxcbiAgdXBkYXRlVGltZW91dDogRHVyYXRpb24ubWludXRlcygzMCksXG4gIHVwZGF0ZVRvTGF0ZXN0SW1hZ2VWZXJzaW9uOiBmYWxzZSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21pbmltYWxQcm9wc0VjMicsIHtcbiAgdnBjLFxuICBpbWFnZXM6IFt7XG4gICAgaW1hZ2U6IG5ldyBlYzIuQW1hem9uTGludXhJbWFnZSgpLFxuICB9XSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ0xhdW5jaFRlbXBsYXRlJywge1xuICB2cGMsXG4gIGltYWdlczogW3tcbiAgICBpbWFnZTogbmV3IGVjMi5BbWF6b25MaW51eEltYWdlKCksXG4gIH1dLFxuICBhbGxvY2F0aW9uU3RyYXRlZ3k6IEFsbG9jYXRpb25TdHJhdGVneS5CRVNUX0ZJVCxcbiAgbWludkNwdXM6IDI1NixcbiAgbWF4dkNwdXM6IDUxMixcbiAgcmVwbGFjZUNvbXB1dGVFbnZpcm9ubWVudDogdHJ1ZSxcbiAgdGVybWluYXRlT25VcGRhdGU6IGZhbHNlLFxuICBwbGFjZW1lbnRHcm91cDogbmV3IGVjMi5QbGFjZW1lbnRHcm91cChzdGFjaywgJ3BsYWNlbWVudEdyb3VwJyksXG4gIHVwZGF0ZVRpbWVvdXQ6IER1cmF0aW9uLmhvdXJzKDEpLFxuICBsYXVuY2hUZW1wbGF0ZTogbmV3IExhdW5jaFRlbXBsYXRlKHN0YWNrLCAnbGF1bmNoVGVtcGxhdGUnKSxcbn0pO1xuXG5uZXcgTWFuYWdlZEVjMkVjc0NvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ1Nwb3RFYzInLCB7XG4gIHZwYyxcbiAgaW1hZ2VzOiBbe1xuICAgIGltYWdlOiBuZXcgZWMyLkFtYXpvbkxpbnV4SW1hZ2UoKSxcbiAgfV0sXG4gIHNwb3Q6IHRydWUsXG4gIHNwb3RCaWRQZXJjZW50YWdlOiA5NSxcbiAgc3BvdEZsZWV0Um9sZTogbmV3IFJvbGUoc3RhY2ssICdTcG90RmxlZXRSb2xlJywge1xuICAgIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ2JhdGNoLmFtYXpvbmF3cy5jb20nKSxcbiAgfSksXG59KTtcblxubmV3IE1hbmFnZWRFYzJFY3NDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdBbGxvY2F0aW9uU3RyYXRlZ3lTUE9UX0NBUEFDSVRZJywge1xuICB2cGMsXG4gIGltYWdlczogW3tcbiAgICBpbWFnZTogbmV3IGVjMi5BbWF6b25MaW51eEltYWdlKCksXG4gIH1dLFxuICBzcG90OiB0cnVlLFxuICBzcG90QmlkUGVyY2VudGFnZTogOTUsXG4gIGFsbG9jYXRpb25TdHJhdGVneTogQWxsb2NhdGlvblN0cmF0ZWd5LlNQT1RfQ0FQQUNJVFlfT1BUSU1JWkVELFxufSk7XG5cbmNvbnN0IHRhZ2dlZEVjMkVjcyA9IG5ldyBNYW5hZ2VkRWMyRWNzQ29tcHV0ZUVudmlyb25tZW50KHN0YWNrLCAndGFnZ2VkQ0UnLCB7XG4gIHZwYyxcbiAgaW1hZ2VzOiBbe1xuICAgIGltYWdlOiBuZXcgZWMyLkFtYXpvbkxpbnV4SW1hZ2UoKSxcbiAgfV0sXG59KTtcblxuVGFncy5vZih0YWdnZWRFYzJFY3MpLmFkZCgnZm9vJywgJ2JhcicpO1xuVGFncy5vZih0YWdnZWRFYzJFY3MpLmFkZCgnc3VwZXInLCAnc2FsYW1hbmRlcicpO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoTWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js deleted file mode 100644 index 5c3d60fee788b..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.multinode-job-definition.js +++ /dev/null @@ -1,48 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const aws_ecs_1 = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const batch = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'stack'); -new batch.MultiNodeJobDefinition(stack, 'SingleContainerMultiNodeJob', { - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - containers: [{ - startNode: 0, - endNode: 10, - container: new batch.EcsEc2ContainerDefinition(stack, 'myContainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }], - propagateTags: true, -}); -const multinodeJob = new batch.MultiNodeJobDefinition(stack, 'MultiContainerMultiNodeJob', { - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - containers: [{ - startNode: 0, - endNode: 10, - container: new batch.EcsEc2ContainerDefinition(stack, 'multinodecontainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), - }], -}); -multinodeJob.addContainer({ - startNode: 11, - endNode: 20, - container: new batch.EcsEc2ContainerDefinition(stack, 'multiContainer', { - image: aws_ecs_1.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - }), -}); -new integ.IntegTest(app, 'BatchMultiNodeJobDefinitionTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcubXVsdGlub2RlLWpvYi1kZWZpbml0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcubXVsdGlub2RlLWpvYi1kZWZpbml0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQWdGO0FBQ2hGLGlEQUFxRDtBQUNyRCw2Q0FBK0M7QUFDL0Msb0RBQW9EO0FBQ3BELGdDQUFnQztBQUVoQyxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBRXRDLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSw2QkFBNkIsRUFBRTtJQUNyRSxZQUFZLEVBQUUsc0JBQVksQ0FBQyxFQUFFLENBQUMsdUJBQWEsQ0FBQyxFQUFFLEVBQUUsc0JBQVksQ0FBQyxLQUFLLENBQUM7SUFDbkUsVUFBVSxFQUFFLENBQUM7WUFDWCxTQUFTLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxFQUFFO1lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxhQUFhLEVBQUU7Z0JBQ25FLEtBQUssRUFBRSx3QkFBYyxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztnQkFDOUQsR0FBRyxFQUFFLEdBQUc7Z0JBQ1IsTUFBTSxFQUFFLGtCQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQzthQUM3QixDQUFDO1NBQ0gsQ0FBQztJQUNGLGFBQWEsRUFBRSxJQUFJO0NBQ3BCLENBQUMsQ0FBQztBQUVILE1BQU0sWUFBWSxHQUFHLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSw0QkFBNEIsRUFBRTtJQUN6RixZQUFZLEVBQUUsc0JBQVksQ0FBQyxFQUFFLENBQUMsdUJBQWEsQ0FBQyxFQUFFLEVBQUUsc0JBQVksQ0FBQyxLQUFLLENBQUM7SUFDbkUsVUFBVSxFQUFFLENBQUM7WUFDWCxTQUFTLEVBQUUsQ0FBQztZQUNaLE9BQU8sRUFBRSxFQUFFO1lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxvQkFBb0IsRUFBRTtnQkFDMUUsS0FBSyxFQUFFLHdCQUFjLENBQUMsWUFBWSxDQUFDLDBCQUEwQixDQUFDO2dCQUM5RCxHQUFHLEVBQUUsR0FBRztnQkFDUixNQUFNLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO2FBQzdCLENBQUM7U0FDSCxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsWUFBWSxDQUFDLFlBQVksQ0FBQztJQUN4QixTQUFTLEVBQUUsRUFBRTtJQUNiLE9BQU8sRUFBRSxFQUFFO0lBQ1gsU0FBUyxFQUFFLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsRUFBRTtRQUN0RSxLQUFLLEVBQUUsd0JBQWMsQ0FBQyxZQUFZLENBQUMsMEJBQTBCLENBQUM7UUFDOUQsR0FBRyxFQUFFLEdBQUc7UUFDUixNQUFNLEVBQUUsa0JBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0tBQzdCLENBQUM7Q0FDSCxDQUFDLENBQUM7QUFFSCxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLGlDQUFpQyxFQUFFO0lBQzFELFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuQixDQUFDLENBQUM7QUFFSCxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnN0YW5jZUNsYXNzLCBJbnN0YW5jZVNpemUsIEluc3RhbmNlVHlwZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1lYzInO1xuaW1wb3J0IHsgQ29udGFpbmVySW1hZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IEFwcCwgU2l6ZSwgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBpbnRlZyBmcm9tICdAYXdzLWNkay9pbnRlZy10ZXN0cy1hbHBoYSc7XG5pbXBvcnQgKiBhcyBiYXRjaCBmcm9tICcuLi9saWInO1xuXG5jb25zdCBhcHAgPSBuZXcgQXBwKCk7XG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuXG5uZXcgYmF0Y2guTXVsdGlOb2RlSm9iRGVmaW5pdGlvbihzdGFjaywgJ1NpbmdsZUNvbnRhaW5lck11bHRpTm9kZUpvYicsIHtcbiAgaW5zdGFuY2VUeXBlOiBJbnN0YW5jZVR5cGUub2YoSW5zdGFuY2VDbGFzcy5SNCwgSW5zdGFuY2VTaXplLkxBUkdFKSxcbiAgY29udGFpbmVyczogW3tcbiAgICBzdGFydE5vZGU6IDAsXG4gICAgZW5kTm9kZTogMTAsXG4gICAgY29udGFpbmVyOiBuZXcgYmF0Y2guRWNzRWMyQ29udGFpbmVyRGVmaW5pdGlvbihzdGFjaywgJ215Q29udGFpbmVyJywge1xuICAgICAgaW1hZ2U6IENvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgICBjcHU6IDI1NixcbiAgICAgIG1lbW9yeTogU2l6ZS5tZWJpYnl0ZXMoMjA0OCksXG4gICAgfSksXG4gIH1dLFxuICBwcm9wYWdhdGVUYWdzOiB0cnVlLFxufSk7XG5cbmNvbnN0IG11bHRpbm9kZUpvYiA9IG5ldyBiYXRjaC5NdWx0aU5vZGVKb2JEZWZpbml0aW9uKHN0YWNrLCAnTXVsdGlDb250YWluZXJNdWx0aU5vZGVKb2InLCB7XG4gIGluc3RhbmNlVHlwZTogSW5zdGFuY2VUeXBlLm9mKEluc3RhbmNlQ2xhc3MuUjQsIEluc3RhbmNlU2l6ZS5MQVJHRSksXG4gIGNvbnRhaW5lcnM6IFt7XG4gICAgc3RhcnROb2RlOiAwLFxuICAgIGVuZE5vZGU6IDEwLFxuICAgIGNvbnRhaW5lcjogbmV3IGJhdGNoLkVjc0VjMkNvbnRhaW5lckRlZmluaXRpb24oc3RhY2ssICdtdWx0aW5vZGVjb250YWluZXInLCB7XG4gICAgICBpbWFnZTogQ29udGFpbmVySW1hZ2UuZnJvbVJlZ2lzdHJ5KCdhbWF6b24vYW1hem9uLWVjcy1zYW1wbGUnKSxcbiAgICAgIGNwdTogMjU2LFxuICAgICAgbWVtb3J5OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgICB9KSxcbiAgfV0sXG59KTtcblxubXVsdGlub2RlSm9iLmFkZENvbnRhaW5lcih7XG4gIHN0YXJ0Tm9kZTogMTEsXG4gIGVuZE5vZGU6IDIwLFxuICBjb250YWluZXI6IG5ldyBiYXRjaC5FY3NFYzJDb250YWluZXJEZWZpbml0aW9uKHN0YWNrLCAnbXVsdGlDb250YWluZXInLCB7XG4gICAgaW1hZ2U6IENvbnRhaW5lckltYWdlLmZyb21SZWdpc3RyeSgnYW1hem9uL2FtYXpvbi1lY3Mtc2FtcGxlJyksXG4gICAgY3B1OiAyNTYsXG4gICAgbWVtb3J5OiBTaXplLm1lYmlieXRlcygyMDQ4KSxcbiAgfSksXG59KTtcblxubmV3IGludGVnLkludGVnVGVzdChhcHAsICdCYXRjaE11bHRpTm9kZUpvYkRlZmluaXRpb25UZXN0Jywge1xuICB0ZXN0Q2FzZXM6IFtzdGFja10sXG59KTtcblxuYXBwLnN5bnRoKCk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js b/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js deleted file mode 100644 index 55a17c9cfbbe7..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/integ.unmanaged-compute-environment.js +++ /dev/null @@ -1,25 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const integ = require("@aws-cdk/integ-tests-alpha"); -const lib_1 = require("../lib"); -const app = new aws_cdk_lib_1.App(); -const stack = new aws_cdk_lib_1.Stack(app, 'batch-stack'); -new lib_1.UnmanagedComputeEnvironment(stack, 'minimalProps'); -new lib_1.UnmanagedComputeEnvironment(stack, 'maximalProps', { - computeEnvironmentName: 'unmanagedIntegTestCE', - enabled: true, - unmanagedvCpus: 256, - serviceRole: new aws_iam_1.Role(stack, 'IntegServiceRole', { - managedPolicies: [ - aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSBatchServiceRole'), - ], - assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), - }), -}); -new integ.IntegTest(app, 'BatchManagedComputeEnvironmentTest', { - testCases: [stack], -}); -app.synth(); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcudW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy51bm1hbmFnZWQtY29tcHV0ZS1lbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlEQUE0RTtBQUM1RSw2Q0FBeUM7QUFDekMsb0RBQW9EO0FBQ3BELGdDQUFxRDtBQUVyRCxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0FBRTVDLElBQUksaUNBQTJCLENBQUMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0FBRXZELElBQUksaUNBQTJCLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtJQUNyRCxzQkFBc0IsRUFBRSxzQkFBc0I7SUFDOUMsT0FBTyxFQUFFLElBQUk7SUFDYixjQUFjLEVBQUUsR0FBRztJQUNuQixXQUFXLEVBQUUsSUFBSSxjQUFJLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFO1FBQy9DLGVBQWUsRUFBRTtZQUNmLHVCQUFhLENBQUMsd0JBQXdCLENBQUMsa0NBQWtDLENBQUM7U0FDM0U7UUFDRCxTQUFTLEVBQUUsSUFBSSwwQkFBZ0IsQ0FBQyxxQkFBcUIsQ0FBQztLQUN2RCxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUgsSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxvQ0FBb0MsRUFBRTtJQUM3RCxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUM7Q0FDbkIsQ0FBQyxDQUFDO0FBRUgsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWFuYWdlZFBvbGljeSwgUm9sZSwgU2VydmljZVByaW5jaXBhbCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgQXBwLCBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGludGVnIGZyb20gJ0Bhd3MtY2RrL2ludGVnLXRlc3RzLWFscGhhJztcbmltcG9ydCB7IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudCB9IGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ2JhdGNoLXN0YWNrJyk7XG5cbm5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdtaW5pbWFsUHJvcHMnKTtcblxubmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ21heGltYWxQcm9wcycsIHtcbiAgY29tcHV0ZUVudmlyb25tZW50TmFtZTogJ3VubWFuYWdlZEludGVnVGVzdENFJyxcbiAgZW5hYmxlZDogdHJ1ZSxcbiAgdW5tYW5hZ2VkdkNwdXM6IDI1NixcbiAgc2VydmljZVJvbGU6IG5ldyBSb2xlKHN0YWNrLCAnSW50ZWdTZXJ2aWNlUm9sZScsIHtcbiAgICBtYW5hZ2VkUG9saWNpZXM6IFtcbiAgICAgIE1hbmFnZWRQb2xpY3kuZnJvbUF3c01hbmFnZWRQb2xpY3lOYW1lKCdzZXJ2aWNlLXJvbGUvQVdTQmF0Y2hTZXJ2aWNlUm9sZScpLFxuICAgIF0sXG4gICAgYXNzdW1lZEJ5OiBuZXcgU2VydmljZVByaW5jaXBhbCgnYmF0Y2guYW1hem9uYXdzLmNvbScpLFxuICB9KSxcbn0pO1xuXG5uZXcgaW50ZWcuSW50ZWdUZXN0KGFwcCwgJ0JhdGNoTWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudFRlc3QnLCB7XG4gIHRlc3RDYXNlczogW3N0YWNrXSxcbn0pO1xuXG5hcHAuc3ludGgoKTtcbiJdfQ== \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js b/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js deleted file mode 100644 index 5a3ad995469b0..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/job-definition-base.test.js +++ /dev/null @@ -1,205 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const utils_1 = require("./utils"); -const batch = require("../lib"); -const defaultExpectedEcsProps = { - type: 'container', - platformCapabilities: [batch.Compatibility.EC2], -}; -const defaultExpectedEksProps = { - type: 'container', -}; -const defaultExpectedMultiNodeProps = { - type: 'multinode', -}; -let stack; -let pascalCaseExpectedEcsProps; -let pascalCaseExpectedEksProps; -let pascalCaseExpectedMultiNodeProps; -let defaultEcsProps; -let defaultEksProps; -let defaultMultiNodeProps; -let expectedProps; -let defaultProps; -describe.each([batch.EcsJobDefinition, batch.EksJobDefinition, batch.MultiNodeJobDefinition])('%p type JobDefinition', (JobDefinition) => { - // GIVEN - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); - pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); - pascalCaseExpectedMultiNodeProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedMultiNodeProps); - defaultEcsProps = { - container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - }; - defaultEksProps = { - container: new batch.EksContainerDefinition(stack, 'EksContainer', { - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - }; - defaultMultiNodeProps = { - containers: [{ - container: new batch.EcsEc2ContainerDefinition(stack, 'MultinodeEcsContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 0, - endNode: 10, - }], - mainNode: 0, - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - }; - switch (JobDefinition) { - case batch.EcsJobDefinition: - expectedProps = pascalCaseExpectedEcsProps; - defaultProps = defaultEcsProps; - break; - case batch.EksJobDefinition: - expectedProps = pascalCaseExpectedEksProps; - defaultProps = defaultEksProps; - break; - case batch.MultiNodeJobDefinition: - expectedProps = pascalCaseExpectedMultiNodeProps; - defaultProps = defaultMultiNodeProps; - break; - } - }); - test('JobDefinition respects name', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - jobDefinitionName: 'myEcsJob', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - JobDefinitionName: 'myEcsJob', - }); - }); - test('JobDefinition respects parameters', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - parameters: { - foo: 'bar', - }, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - Parameters: { - foo: 'bar', - }, - }); - }); - test('JobDefinition respects retryAttempts', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - retryAttempts: 8, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - RetryStrategy: { - Attempts: 8, - }, - }); - }); - test('JobDefinition respects retryStrategies', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - retryStrategies: [ - batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER), - batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE), - batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED), - batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.custom({ - onExitCode: '40*', - onReason: 'reason*', - onStatusReason: 'statusReason', - })), - ], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - RetryStrategy: { - EvaluateOnExit: [ - { - Action: 'EXIT', - OnReason: 'CannotPullContainerError:*', - }, - { - Action: 'RETRY', - OnExitCode: '*', - }, - { - Action: 'RETRY', - OnStatusReason: 'Host EC2*', - }, - { - Action: 'RETRY', - OnExitCode: '40*', - OnReason: 'reason*', - OnStatusReason: 'statusReason', - }, - ], - }, - }); - }); - test('JobDefinition respects schedulingPriority', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - schedulingPriority: 10, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - SchedulingPriority: 10, - }); - }); - test('JobDefinition respects schedulingPriority', () => { - // WHEN - new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - timeout: aws_cdk_lib_1.Duration.minutes(10), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - Timeout: { - AttemptDurationSeconds: 600, - }, - }); - }); - test('JobDefinition respects addRetryStrategy()', () => { - // WHEN - const jobDefn = new JobDefinition(stack, 'JobDefn', { - ...defaultProps, - }); - jobDefn.addRetryStrategy(batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED)); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - ...expectedProps, - RetryStrategy: { - EvaluateOnExit: [ - { - Action: 'RETRY', - OnStatusReason: 'Host EC2*', - }, - ], - }, - }); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-definition-base.test.js","sourceRoot":"","sources":["job-definition-base.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { /*Aws,*/ Duration, Size, Stack } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport * as batch from '../lib';\nimport { CfnJobDefinitionProps } from 'aws-cdk-lib/aws-batch';\n\nconst defaultExpectedEcsProps: CfnJobDefinitionProps = {\n  type: 'container',\n  platformCapabilities: [batch.Compatibility.EC2],\n};\nconst defaultExpectedEksProps: CfnJobDefinitionProps = {\n  type: 'container',\n};\nconst defaultExpectedMultiNodeProps: CfnJobDefinitionProps = {\n  type: 'multinode',\n};\n\nlet stack: Stack;\n\nlet pascalCaseExpectedEcsProps: any;\nlet pascalCaseExpectedEksProps: any;\nlet pascalCaseExpectedMultiNodeProps: any;\n\nlet defaultEcsProps: batch.EcsJobDefinitionProps;\nlet defaultEksProps: batch.EksJobDefinitionProps;\nlet defaultMultiNodeProps: batch.MultiNodeJobDefinitionProps;\n\nlet expectedProps: any;\nlet defaultProps: any;\n\ndescribe.each([batch.EcsJobDefinition, batch.EksJobDefinition, batch.MultiNodeJobDefinition])('%p type JobDefinition', (JobDefinition) => {\n  // GIVEN\n  beforeEach(() => {\n    stack = new Stack();\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    pascalCaseExpectedMultiNodeProps = capitalizePropertyNames(stack, defaultExpectedMultiNodeProps);\n\n    defaultEcsProps = {\n      container: new batch.EcsEc2ContainerDefinition(stack, 'EcsContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n    };\n    defaultEksProps = {\n      container: new batch.EksContainerDefinition(stack, 'EksContainer', {\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n    };\n    defaultMultiNodeProps = {\n      containers: [{\n        container: new batch.EcsEc2ContainerDefinition(stack, 'MultinodeEcsContainer', {\n          cpu: 256,\n          memory: Size.mebibytes(2048),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 0,\n        endNode: 10,\n      }],\n      mainNode: 0,\n      instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n    };\n    switch (JobDefinition) {\n      case batch.EcsJobDefinition:\n        expectedProps = pascalCaseExpectedEcsProps;\n        defaultProps = defaultEcsProps;\n        break;\n      case batch.EksJobDefinition:\n        expectedProps = pascalCaseExpectedEksProps;\n        defaultProps = defaultEksProps;\n        break;\n      case batch.MultiNodeJobDefinition:\n        expectedProps = pascalCaseExpectedMultiNodeProps;\n        defaultProps = defaultMultiNodeProps;\n        break;\n    }\n  });\n\n  test('JobDefinition respects name', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      jobDefinitionName: 'myEcsJob',\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      JobDefinitionName: 'myEcsJob',\n    });\n  });\n\n  test('JobDefinition respects parameters', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      parameters: {\n        foo: 'bar',\n      },\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      Parameters: {\n        foo: 'bar',\n      },\n    });\n  });\n\n  test('JobDefinition respects retryAttempts', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      retryAttempts: 8,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        Attempts: 8,\n      },\n    });\n  });\n\n  test('JobDefinition respects retryStrategies', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      retryStrategies: [\n        batch.RetryStrategy.of(batch.Action.EXIT, batch.Reason.CANNOT_PULL_CONTAINER),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.NON_ZERO_EXIT_CODE),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED),\n        batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.custom({\n          onExitCode: '40*',\n          onReason: 'reason*',\n          onStatusReason: 'statusReason',\n        })),\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        EvaluateOnExit: [\n          {\n            Action: 'EXIT',\n            OnReason: 'CannotPullContainerError:*',\n          },\n          {\n            Action: 'RETRY',\n            OnExitCode: '*',\n          },\n          {\n            Action: 'RETRY',\n            OnStatusReason: 'Host EC2*',\n          },\n          {\n            Action: 'RETRY',\n            OnExitCode: '40*',\n            OnReason: 'reason*',\n            OnStatusReason: 'statusReason',\n          },\n        ],\n      },\n    });\n  });\n\n  test('JobDefinition respects schedulingPriority', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      schedulingPriority: 10,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      SchedulingPriority: 10,\n    });\n  });\n\n  test('JobDefinition respects schedulingPriority', () => {\n    // WHEN\n    new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n      timeout: Duration.minutes(10),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      Timeout: {\n        AttemptDurationSeconds: 600,\n      },\n    });\n  });\n\n  test('JobDefinition respects addRetryStrategy()', () => {\n    // WHEN\n    const jobDefn = new JobDefinition(stack, 'JobDefn', {\n      ...defaultProps,\n    });\n\n    jobDefn.addRetryStrategy(batch.RetryStrategy.of(batch.Action.RETRY, batch.Reason.SPOT_INSTANCE_RECLAIMED));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n      ...expectedProps,\n      RetryStrategy: {\n        EvaluateOnExit: [\n          {\n            Action: 'RETRY',\n            OnStatusReason: 'Host EC2*',\n          },\n        ],\n      },\n    });\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js b/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js deleted file mode 100644 index b15482f2d3cc1..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/job-queue.test.js +++ /dev/null @@ -1,228 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const lib_1 = require("../lib"); -test('JobQueue respects computeEnvironments', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - new lib_1.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { - vpc, - }), - order: 1, - }], - priority: 10, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { - ComputeEnvironmentOrder: [{ - ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, - Order: 1, - }], - Priority: 10, - State: 'ENABLED', - }); -}); -test('JobQueue respects enabled', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - new lib_1.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { - vpc, - }), - order: 1, - }], - priority: 10, - enabled: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { - ComputeEnvironmentOrder: [{ - ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, - Order: 1, - }], - Priority: 10, - State: 'DISABLED', - }); -}); -test('JobQueue respects name', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - new lib_1.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { - vpc, - }), - order: 1, - }], - priority: 10, - jobQueueName: 'JoBBQ', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { - ComputeEnvironmentOrder: [{ - ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, - Order: 1, - }], - Priority: 10, - JobQueueName: 'JoBBQ', - }); -}); -test('JobQueue name is parsed from arn', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - const queue = new lib_1.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { - vpc, - }), - order: 1, - }], - priority: 10, - jobQueueName: 'JoBBQ', - }); - // THEN - expect(aws_cdk_lib_1.Tokenization.resolve(queue.jobQueueName, { - scope: stack, - resolver: new aws_cdk_lib_1.DefaultTokenResolver(new aws_cdk_lib_1.StringConcat()), - })).toEqual({ - 'Fn::Select': [ - 1, - { - 'Fn::Split': [ - '/', - { - 'Fn::Select': [ - 5, - { - 'Fn::Split': [ - ':', - { - 'Fn::GetAtt': [ - 'joBBQ9FD52DAF', - 'JobQueueArn', - ], - }, - ], - }, - ], - }, - ], - }, - ], - }); -}); -test('JobQueue respects schedulingPolicy', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - new lib_1.JobQueue(stack, 'JobQueue', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'CE', { - vpc, - }), - order: 1, - }], - priority: 10, - schedulingPolicy: new lib_1.FairshareSchedulingPolicy(stack, 'FairsharePolicy'), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { - ComputeEnvironmentOrder: [{ - ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] }, - Order: 1, - }], - Priority: 10, - SchedulingPolicyArn: { - 'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'], - }, - }); -}); -test('JobQueue respects addComputeEnvironment', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - const queue = new lib_1.JobQueue(stack, 'JobQueue', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', { - vpc, - }), - order: 1, - }], - priority: 10, - schedulingPolicy: new lib_1.FairshareSchedulingPolicy(stack, 'FairsharePolicy'), - }); - queue.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', { - vpc, - }), 2); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', { - ComputeEnvironmentOrder: [ - { - ComputeEnvironment: { 'Fn::GetAtt': ['FirstCEAD3794AD', 'ComputeEnvironmentArn'] }, - Order: 1, - }, - { - ComputeEnvironment: { 'Fn::GetAtt': ['SecondCEEBA93938', 'ComputeEnvironmentArn'] }, - Order: 2, - }, - ], - Priority: 10, - SchedulingPolicyArn: { - 'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'], - }, - }); -}); -test('can be imported from ARN', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - const queue = lib_1.JobQueue.fromJobQueueArn(stack, 'importedJobQueue', 'arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue'); - // THEN - expect(queue.jobQueueArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue'); -}); -test('JobQueue throws when the same order is assigned to multiple ComputeEnvironments', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - const vpc = new ec2.Vpc(stack, 'vpc'); - // WHEN - const joBBQ = new lib_1.JobQueue(stack, 'joBBQ', { - computeEnvironments: [{ - computeEnvironment: new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', { - vpc, - }), - order: 1, - }], - priority: 10, - }); - joBBQ.addComputeEnvironment(new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', { - vpc, - }), 1); - expect(() => { - assertions_1.Template.fromStack(stack); - }).toThrow(/assigns the same order to different ComputeEnvironments/); -}); -test('JobQueue throws when there are no linked ComputeEnvironments', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.JobQueue(stack, 'joBBQ'); - expect(() => { - assertions_1.Template.fromStack(stack); - }).toThrow(/This JobQueue does not link any ComputeEnvironments/); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"job-queue.test.js","sourceRoot":"","sources":["job-queue.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { DefaultTokenResolver, Stack, StringConcat, Tokenization } from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport { FairshareSchedulingPolicy, JobQueue, ManagedEc2EcsComputeEnvironment } from '../lib';\n\ntest('JobQueue respects computeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    State: 'ENABLED',\n  });\n});\n\ntest('JobQueue respects enabled', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    enabled: false,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    State: 'DISABLED',\n  });\n});\n\ntest('JobQueue respects name', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    jobQueueName: 'JoBBQ',\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    JobQueueName: 'JoBBQ',\n  });\n});\n\ntest('JobQueue name is parsed from arn', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const queue = new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    jobQueueName: 'JoBBQ',\n  });\n\n  // THEN\n  expect(Tokenization.resolve(queue.jobQueueName, {\n    scope: stack,\n    resolver: new DefaultTokenResolver(new StringConcat()),\n  })).toEqual({\n    'Fn::Select': [\n      1,\n      {\n        'Fn::Split': [\n          '/',\n          {\n            'Fn::Select': [\n              5,\n              {\n                'Fn::Split': [\n                  ':',\n                  {\n                    'Fn::GetAtt': [\n                      'joBBQ9FD52DAF',\n                      'JobQueueArn',\n                    ],\n                  },\n                ],\n              },\n            ],\n          },\n        ],\n      },\n    ],\n  });\n});\n\ntest('JobQueue respects schedulingPolicy', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  new JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'CE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    schedulingPolicy: new FairshareSchedulingPolicy(stack, 'FairsharePolicy'),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [{\n      ComputeEnvironment: { 'Fn::GetAtt': ['CE1BFE03A1', 'ComputeEnvironmentArn'] },\n      Order: 1,\n    }],\n    Priority: 10,\n    SchedulingPolicyArn: {\n      'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'],\n    },\n  });\n});\n\ntest('JobQueue respects addComputeEnvironment', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const queue = new JobQueue(stack, 'JobQueue', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n    schedulingPolicy: new FairshareSchedulingPolicy(stack, 'FairsharePolicy'),\n  });\n\n  queue.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', {\n      vpc,\n    }),\n    2,\n  );\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobQueue', {\n    ComputeEnvironmentOrder: [\n      {\n        ComputeEnvironment: { 'Fn::GetAtt': ['FirstCEAD3794AD', 'ComputeEnvironmentArn'] },\n        Order: 1,\n      },\n      {\n        ComputeEnvironment: { 'Fn::GetAtt': ['SecondCEEBA93938', 'ComputeEnvironmentArn'] },\n        Order: 2,\n      },\n    ],\n    Priority: 10,\n    SchedulingPolicyArn: {\n      'Fn::GetAtt': ['FairsharePolicyA0C549BE', 'Arn'],\n    },\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const queue = JobQueue.fromJobQueueArn(stack, 'importedJobQueue',\n    'arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue');\n\n  // THEN\n  expect(queue.jobQueueArn).toEqual('arn:aws:batch:us-east-1:123456789012:job-queue/importedJobQueue');\n});\n\ntest('JobQueue throws when the same order is assigned to multiple ComputeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n  const vpc = new ec2.Vpc(stack, 'vpc');\n\n  // WHEN\n  const joBBQ = new JobQueue(stack, 'joBBQ', {\n    computeEnvironments: [{\n      computeEnvironment: new ManagedEc2EcsComputeEnvironment(stack, 'FirstCE', {\n        vpc,\n      }),\n      order: 1,\n    }],\n    priority: 10,\n  });\n\n  joBBQ.addComputeEnvironment(\n    new ManagedEc2EcsComputeEnvironment(stack, 'SecondCE', {\n      vpc,\n    }),\n    1,\n  );\n\n  expect(() => {\n    Template.fromStack(stack);\n  }).toThrow(/assigns the same order to different ComputeEnvironments/);\n});\n\ntest('JobQueue throws when there are no linked ComputeEnvironments', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new JobQueue(stack, 'joBBQ');\n\n  expect(() => {\n    Template.fromStack(stack);\n  }).toThrow(/This JobQueue does not link any ComputeEnvironments/);\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js b/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js deleted file mode 100644 index 012dc0b22f7ed..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/managed-compute-environment.test.js +++ /dev/null @@ -1,860 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const ec2 = require("aws-cdk-lib/aws-ec2"); -const eks = require("aws-cdk-lib/aws-eks"); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const utils_1 = require("./utils"); -const batch = require("../lib"); -const lib_1 = require("../lib"); -const defaultExpectedEcsProps = { - type: 'managed', - computeEnvironmentName: undefined, - serviceRole: undefined, - state: 'ENABLED', - eksConfiguration: undefined, - computeResources: { - allocationStrategy: lib_1.AllocationStrategy.BEST_FIT_PROGRESSIVE, - bidPercentage: undefined, - desiredvCpus: undefined, - maxvCpus: 256, - type: 'EC2', - ec2Configuration: undefined, - minvCpus: 0, - subnets: [ - { Ref: 'vpcPrivateSubnet1Subnet934893E8' }, - { Ref: 'vpcPrivateSubnet2Subnet7031C2BA' }, - ], - ec2KeyPair: undefined, - imageId: undefined, - instanceRole: { 'Fn::GetAtt': ['MyCEInstanceProfile6D69963F', 'Arn'] }, - instanceTypes: ['optimal'], - launchTemplate: undefined, - placementGroup: undefined, - securityGroupIds: [{ - 'Fn::GetAtt': ['MyCESecurityGroup81DCAA06', 'GroupId'], - }], - spotIamFleetRole: undefined, - updateToLatestImageVersion: true, - }, - replaceComputeEnvironment: false, -}; -const defaultExpectedEksProps = { - ...defaultExpectedEcsProps, - eksConfiguration: { - eksClusterArn: { - 'Fn::GetAtt': ['eksTestCluster1B416C0E', 'Arn'], - }, - kubernetesNamespace: 'cdk-test-namespace', - }, -}; -let stack; -let vpc; -let pascalCaseExpectedEcsProps; -let pascalCaseExpectedEksProps; -let defaultComputeResources; -let defaultEcsProps; -let defaultEksProps; -let expectedProps; -let defaultProps; -describe.each([lib_1.ManagedEc2EcsComputeEnvironment, lib_1.ManagedEc2EksComputeEnvironment])('%p type ComputeEnvironment', (ComputeEnvironment) => { - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - vpc = new ec2.Vpc(stack, 'vpc'); - pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); - pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); - defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; - defaultEcsProps = { - vpc, - }; - defaultEksProps = { - vpc, - kubernetesNamespace: 'cdk-test-namespace', - eksCluster: new eks.Cluster(stack, 'eksTestCluster', { - version: eks.KubernetesVersion.V1_24, - }), - }; - expectedProps = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment - ? pascalCaseExpectedEcsProps - : pascalCaseExpectedEksProps; - defaultProps = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment - ? defaultEcsProps - : defaultEksProps; - }); - test('default props', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', { - Roles: [{ Ref: 'MyCEInstanceProfileRole895D248D' }], - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - AssumeRolePolicyDocument: { - Statement: [{ - Action: 'sts:AssumeRole', - Effect: 'Allow', - Principal: { Service: 'ec2.amazonaws.com' }, - }], - Version: '2012-10-17', - }, - }); - }); - test('can specify maxvCpus', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - maxvCpus: 512, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - MaxvCpus: 512, - }, - }); - }); - test('can specify minvCpus', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - minvCpus: 8, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - MinvCpus: 8, - }, - }); - }); - test('can be disabled', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - enabled: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - State: 'DISABLED', - }); - }); - test('spot => AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spot: true, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - Type: 'SPOT', - AllocationStrategy: 'SPOT_PRICE_CAPACITY_OPTIMIZED', - }, - }); - }); - test('images are correctly rendered as EC2ConfigurationObjects', () => { - const expectedImageType = ComputeEnvironment === lib_1.ManagedEc2EcsComputeEnvironment - ? batch.EcsMachineImageType.ECS_AL2 - : batch.EksMachineImageType.EKS_AL2; - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - images: [ - { - image: ec2.MachineImage.latestAmazonLinux2(), - }, - ], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - Ec2Configuration: [ - { - ImageIdOverride: { Ref: 'SsmParameterValueawsserviceamiamazonlinuxlatestamzn2amikernel510hvmx8664gp2C96584B6F00A464EAD1953AFF4B05118Parameter' }, - ImageType: expectedImageType, - }, - ], - }, - }); - }); - test('instance classes are correctly rendered', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - instanceClasses: [ec2.InstanceClass.R4], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - InstanceTypes: [ - 'r4', - 'optimal', - ], - }, - }); - }); - test('instance types are correctly rendered', () => { - // WHEN - const ce = new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE)], - }); - ce.addInstanceClass(ec2.InstanceClass.M4); - ce.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.LARGE)); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - InstanceTypes: [ - 'r4.large', - 'c4.large', - 'm4', - 'optimal', - ], - }, - }); - }); - test('respects useOptimalInstanceClasses: false', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - useOptimalInstanceClasses: false, - instanceClasses: [ec2.InstanceClass.R4], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - InstanceTypes: [ - 'r4', - ], - }, - }); - }); - test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceClass()', () => { - // WHEN - const myCE = new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - useOptimalInstanceClasses: false, - }); - myCE.addInstanceClass(ec2.InstanceClass.C4); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - InstanceTypes: [ - 'c4', - ], - }, - }); - }); - test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceType()', () => { - // WHEN - const myCE = new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - useOptimalInstanceClasses: false, - }); - myCE.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.XLARGE112)); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - InstanceTypes: [ - 'c4.112xlarge', - ], - }, - }); - }); - test('creates and uses instanceProfile, even when instanceRole is specified', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - instanceRole: new aws_iam_1.Role(stack, 'myRole', { - assumedBy: new aws_iam_1.ServicePrincipal('foo.amazonaws.com', { - region: 'bermuda-triangle-1337', - }), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - // instanceRole is unchanged from default - }, - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', { - Roles: [{ Ref: 'myRoleE60D68E8' }], - }); - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - AssumeRolePolicyDocument: { - Statement: [{ - Action: 'sts:AssumeRole', - Effect: 'Allow', - Principal: { Service: 'foo.amazonaws.com' }, - }], - Version: '2012-10-17', - }, - }); - }); - test('respects launch template', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - launchTemplate: new ec2.LaunchTemplate(stack, 'launchTemplate'), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - LaunchTemplate: { - LaunchTemplateId: { Ref: 'launchTemplateDEE5742D' }, - }, - }, - }); - }); - test('respects name', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - computeEnvironmentName: 'NamedCE', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeEnvironmentName: 'NamedCE', - ComputeResources: { - ...defaultComputeResources, - }, - }); - }); - test('respects placement group', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - placementGroup: new ec2.PlacementGroup(stack, 'myPlacementGroup'), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - PlacementGroup: { - 'Fn::GetAtt': ['myPlacementGroup2E94D14E', 'GroupName'], - }, - }, - }); - }); - test('respects replaceComputeEnvironment', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - replaceComputeEnvironment: true, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - }, - ReplaceComputeEnvironment: true, - }); - }); - test('respects security groups', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - securityGroups: [new ec2.SecurityGroup(stack, 'TestSG', { - vpc, - allowAllOutbound: false, - })], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - SecurityGroupIds: [{ - 'Fn::GetAtt': ['TestSG581D3391', 'GroupId'], - }], - }, - }); - }); - test('respects service role', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - serviceRole: new aws_iam_1.Role(stack, 'TestSLR', { - assumedBy: new aws_iam_1.ServicePrincipal('cdk.amazonaws.com'), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ServiceRole: { - 'Fn::GetAtt': ['TestSLR05974C22', 'Arn'], - }, - ComputeResources: { - ...defaultComputeResources, - }, - }); - }); - test('respects vpcSubnets', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpcSubnets: { - subnets: [new ec2.Subnet(stack, 'testSubnet', { - availabilityZone: 'az-3', - cidrBlock: '10.0.0.0/32', - vpcId: new ec2.Vpc(stack, 'subnetVpc').vpcId, - })], - }, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - Subnets: [ - { Ref: 'testSubnet42F0FA0C' }, - ], - }, - }); - }); - test('respects updateTimeout', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - updateTimeout: aws_cdk_lib_1.Duration.minutes(1), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - }, - UpdatePolicy: { - JobExecutionTimeoutMinutes: 1, - }, - }); - }); - test('respects terminateOnUpdate', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - terminateOnUpdate: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - }, - UpdatePolicy: { - TerminateJobsOnUpdate: false, - }, - }); - }); - test('respects updateToLatestImageVersion', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - updateToLatestImageVersion: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - UpdateToLatestImageVersion: false, - }, - }); - }); - test('respects tags', () => { - // WHEN - const ce = new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - }); - aws_cdk_lib_1.Tags.of(ce).add('superfood', 'acai'); - aws_cdk_lib_1.Tags.of(ce).add('super', 'salamander'); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...expectedProps, - ComputeResources: { - ...defaultComputeResources, - Tags: { - superfood: 'acai', - super: 'salamander', - }, - }, - }); - }); - test('can be imported from arn', () => { - // WHEN - const ce = lib_1.ManagedEc2EcsComputeEnvironment.fromManagedEc2EcsComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); - // THEN - expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); - }); - test('attach necessary managed policy to instance role', () => { - // WHEN - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', { - ManagedPolicyArns: [ - { - 'Fn::Join': [ - '', - [ - 'arn:', - { - Ref: 'AWS::Partition', - }, - ':iam::aws:policy/service-role/AmazonEC2ContainerServiceforEC2Role', - ], - ], - }, - ], - }); - }); - test('throws when no instance types are provided', () => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - useOptimalInstanceClasses: false, - vpc, - }); - expect(() => { - assertions_1.Template.fromStack(stack); - }).toThrow(/Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes/); - }); - test('throws error when AllocationStrategy.SPOT_CAPACITY_OPTIMIZED is used without specfiying spot', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - allocationStrategy: lib_1.AllocationStrategy.SPOT_CAPACITY_OPTIMIZED, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances/); - }); - test('throws error when AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED is used without specfiying spot', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - allocationStrategy: lib_1.AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances/); - }); - test('throws error when spotBidPercentage is specified without spot', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spotBidPercentage: 80, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/); - }); - test('throws error when spotBidPercentage is specified and spot is false', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spotBidPercentage: 80, - spot: false, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/); - }); - test('throws error when spotBidPercentage > 100', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spotBidPercentage: 120, - spot: true, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' > 100/); - }); - test('throws error when spotBidPercentage < 0', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spotBidPercentage: -120, - spot: true, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' < 0/); - }); - test('throws error when minvCpus > maxvCpus', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - maxvCpus: 512, - minvCpus: 1024, - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = 1024 > 'maxvCpus' = 512; 'minvCpus' cannot be greater than 'maxvCpus'/); - }); - test('throws error when minvCpus < 0', () => { - // THEN - expect(() => { - new ComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - minvCpus: -256, - }); - }).toThrowError(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = -256 < 0; 'minvCpus' cannot be less than zero/); - }); -}); -describe('ManagedEc2EcsComputeEnvironment', () => { - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - vpc = new ec2.Vpc(stack, 'vpc'); - pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); - pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); - defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; - defaultEcsProps = { - vpc, - }; - defaultEksProps = { - vpc, - kubernetesNamespace: 'cdk-test-namespace', - eksCluster: new eks.Cluster(stack, 'eksTestCluster', { - version: eks.KubernetesVersion.V1_24, - }), - }; - }); - test('respects spotFleetRole', () => { - // WHEN - new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { - ...defaultEcsProps, - spot: true, - spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { - assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEcsProps, - ComputeResources: { - ...defaultComputeResources, - AllocationStrategy: lib_1.AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED, - Type: 'SPOT', - SpotIamFleetRole: { - 'Fn::GetAtt': ['SpotFleetRole6D4F7558', 'Arn'], - }, - }, - }); - }); - test('image types are correctly rendered as EC2ConfigurationObjects', () => { - // WHEN - new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { - ...defaultEcsProps, - vpc, - images: [ - { - imageType: batch.EcsMachineImageType.ECS_AL2_NVIDIA, - }, - ], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEcsProps, - ComputeResources: { - ...defaultComputeResources, - Ec2Configuration: [ - { - ImageType: 'ECS_AL2_NVIDIA', - }, - ], - }, - }); - }); - test('can use non-default allocation strategy', () => { - // WHEN - new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEcsProps, - ComputeResources: { - ...defaultComputeResources, - AllocationStrategy: 'BEST_FIT', - }, - }); - }); - test('spot and AllocationStrategy.BEST_FIT => a default spot fleet role is created', () => { - // WHEN - new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - vpc, - spot: true, - allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEcsProps, - ComputeResources: { - ...defaultComputeResources, - Type: 'SPOT', - AllocationStrategy: 'BEST_FIT', - SpotIamFleetRole: { 'Fn::GetAtt': ['MyCESpotFleetRole70BE30A0', 'Arn'] }, - }, - }); - }); - test('throws when spotFleetRole is specified without spot', () => { - // WHEN - expect(() => { - new lib_1.ManagedEc2EcsComputeEnvironment(stack, 'MyCE', { - ...defaultEcsProps, - spotFleetRole: new aws_iam_1.Role(stack, 'SpotFleetRole', { - assumedBy: new aws_iam_1.ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'), - }), - }); - }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotFleetRole' without specifying 'spot'/); - }); -}); -describe('ManagedEc2EksComputeEnvironment', () => { - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - vpc = new ec2.Vpc(stack, 'vpc'); - pascalCaseExpectedEcsProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEcsProps); - pascalCaseExpectedEksProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedEksProps); - defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources; - defaultEcsProps = { - vpc, - }; - defaultEksProps = { - vpc, - kubernetesNamespace: 'cdk-test-namespace', - eksCluster: new eks.Cluster(stack, 'eksTestCluster', { - version: eks.KubernetesVersion.V1_24, - }), - }; - }); - test('default props', () => { - // WHEN - new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { - ...defaultEksProps, - vpc, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEksProps, - ComputeResources: { - ...defaultComputeResources, - }, - }); - }); - test('throws error when AllocationStrategy.BEST_FIT is used', () => { - // THEN - expect(() => { - new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { - ...defaultProps, - allocationStrategy: lib_1.AllocationStrategy.BEST_FIT, - }); - }).toThrow(/ManagedEc2EksComputeEnvironment 'MyCE' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'/); - }); - test('image types are correctly rendered as EC2ConfigurationObjects', () => { - // WHEN - new lib_1.ManagedEc2EksComputeEnvironment(stack, 'MyCE', { - ...defaultEksProps, - vpc, - images: [ - { - imageType: batch.EksMachineImageType.EKS_AL2_NVIDIA, - }, - ], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedEksProps, - ComputeResources: { - ...defaultComputeResources, - Ec2Configuration: [ - { - ImageType: 'EKS_AL2_NVIDIA', - }, - ], - }, - }); - }); -}); -describe('FargateComputeEnvironment', () => { - beforeEach(() => { - stack = new aws_cdk_lib_1.Stack(); - vpc = new ec2.Vpc(stack, 'vpc'); - }); - test('respects name', () => { - // WHEN - new lib_1.FargateComputeEnvironment(stack, 'maximalPropsFargate', { - vpc, - maxvCpus: 512, - computeEnvironmentName: 'maxPropsFargateCE', - replaceComputeEnvironment: true, - spot: true, - terminateOnUpdate: true, - updateTimeout: aws_cdk_lib_1.Duration.minutes(30), - updateToLatestImageVersion: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ComputeEnvironmentName: 'maxPropsFargateCE', - }); - }); - test('can be imported from arn', () => { - // WHEN - const ce = lib_1.FargateComputeEnvironment.fromFargateComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); - // THEN - expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name'); - }); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"managed-compute-environment.test.js","sourceRoot":"","sources":["managed-compute-environment.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as eks from 'aws-cdk-lib/aws-eks';\nimport { ArnPrincipal, Role, ServicePrincipal } from 'aws-cdk-lib/aws-iam';\nimport { Stack, Duration, Tags } from 'aws-cdk-lib';\nimport { capitalizePropertyNames } from './utils';\nimport * as batch from '../lib';\nimport { AllocationStrategy, ManagedEc2EcsComputeEnvironment, ManagedEc2EcsComputeEnvironmentProps, ManagedEc2EksComputeEnvironment, ManagedEc2EksComputeEnvironmentProps, FargateComputeEnvironment } from '../lib';\nimport { CfnComputeEnvironmentProps } from 'aws-cdk-lib/aws-batch';\n\nconst defaultExpectedEcsProps: CfnComputeEnvironmentProps = {\n  type: 'managed',\n  computeEnvironmentName: undefined,\n  serviceRole: undefined,\n  state: 'ENABLED',\n  eksConfiguration: undefined,\n  computeResources: {\n    allocationStrategy: AllocationStrategy.BEST_FIT_PROGRESSIVE,\n    bidPercentage: undefined,\n    desiredvCpus: undefined,\n    maxvCpus: 256,\n    type: 'EC2',\n    ec2Configuration: undefined,\n    minvCpus: 0,\n    subnets: [\n      { Ref: 'vpcPrivateSubnet1Subnet934893E8' } as any,\n      { Ref: 'vpcPrivateSubnet2Subnet7031C2BA' } as any,\n    ],\n    ec2KeyPair: undefined,\n    imageId: undefined,\n    instanceRole: { 'Fn::GetAtt': ['MyCEInstanceProfile6D69963F', 'Arn'] } as any,\n    instanceTypes: ['optimal'],\n    launchTemplate: undefined,\n    placementGroup: undefined,\n    securityGroupIds: [{\n      'Fn::GetAtt': ['MyCESecurityGroup81DCAA06', 'GroupId'],\n    }] as any,\n    spotIamFleetRole: undefined,\n    updateToLatestImageVersion: true,\n  },\n  replaceComputeEnvironment: false,\n};\n\nconst defaultExpectedEksProps: CfnComputeEnvironmentProps = {\n  ...defaultExpectedEcsProps,\n  eksConfiguration: {\n    eksClusterArn: {\n      'Fn::GetAtt': ['eksTestCluster1B416C0E', 'Arn'],\n    } as any,\n    kubernetesNamespace: 'cdk-test-namespace',\n  },\n};\n\nlet stack: Stack;\nlet vpc: ec2.Vpc;\n\nlet pascalCaseExpectedEcsProps: any;\nlet pascalCaseExpectedEksProps: any;\nlet defaultComputeResources: any;\n\nlet defaultEcsProps: ManagedEc2EcsComputeEnvironmentProps;\nlet defaultEksProps: ManagedEc2EksComputeEnvironmentProps;\n\nlet expectedProps: any;\nlet defaultProps: any;\n\ndescribe.each([ManagedEc2EcsComputeEnvironment, ManagedEc2EksComputeEnvironment])('%p type ComputeEnvironment', (ComputeEnvironment) => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n    expectedProps = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? pascalCaseExpectedEcsProps\n      : pascalCaseExpectedEksProps;\n    defaultProps = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? defaultEcsProps as ManagedEc2EcsComputeEnvironmentProps\n      : defaultEksProps as ManagedEc2EksComputeEnvironmentProps;\n  });\n\n  test('default props', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', {\n      Roles: [{ Ref: 'MyCEInstanceProfileRole895D248D' }],\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'ec2.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('can specify maxvCpus', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      maxvCpus: 512,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        MaxvCpus: 512,\n      },\n    });\n  });\n\n  test('can specify minvCpus', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      minvCpus: 8,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        MinvCpus: 8,\n      },\n    });\n  });\n\n  test('can be disabled', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      enabled: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      State: 'DISABLED',\n    });\n  });\n\n  test('spot => AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      spot: true,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Type: 'SPOT',\n        AllocationStrategy: 'SPOT_PRICE_CAPACITY_OPTIMIZED',\n      },\n    });\n  });\n\n  test('images are correctly rendered as EC2ConfigurationObjects', () => {\n    const expectedImageType = ComputeEnvironment === ManagedEc2EcsComputeEnvironment\n      ? batch.EcsMachineImageType.ECS_AL2\n      : batch.EksMachineImageType.EKS_AL2;\n\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      images: [\n        {\n          image: ec2.MachineImage.latestAmazonLinux2(),\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageIdOverride: { Ref: 'SsmParameterValueawsserviceamiamazonlinuxlatestamzn2amikernel510hvmx8664gp2C96584B6F00A464EAD1953AFF4B05118Parameter' },\n            ImageType: expectedImageType,\n          },\n        ],\n      },\n    });\n  });\n\n  test('instance classes are correctly rendered', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceClasses: [ec2.InstanceClass.R4],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4',\n          'optimal',\n        ],\n      },\n    });\n  });\n\n  test('instance types are correctly rendered', () => {\n    // WHEN\n    const ce = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceTypes: [ec2.InstanceType.of(ec2.InstanceClass.R4, ec2.InstanceSize.LARGE)],\n    });\n\n    ce.addInstanceClass(ec2.InstanceClass.M4);\n    ce.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.LARGE));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4.large',\n          'c4.large',\n          'm4',\n          'optimal',\n        ],\n      },\n    });\n  });\n\n  test('respects useOptimalInstanceClasses: false', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n      instanceClasses: [ec2.InstanceClass.R4],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'r4',\n        ],\n      },\n    });\n  });\n\n  test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceClass()', () => {\n    // WHEN\n    const myCE = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n    });\n\n    myCE.addInstanceClass(ec2.InstanceClass.C4);\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'c4',\n        ],\n      },\n    });\n  });\n\n  test('does not throw with useOptimalInstanceClasses: false and a call to addInstanceType()', () => {\n    // WHEN\n    const myCE = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      useOptimalInstanceClasses: false,\n    });\n\n    myCE.addInstanceType(ec2.InstanceType.of(ec2.InstanceClass.C4, ec2.InstanceSize.XLARGE112));\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        InstanceTypes: [\n          'c4.112xlarge',\n        ],\n      },\n    });\n  });\n\n  test('creates and uses instanceProfile, even when instanceRole is specified', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      instanceRole: new Role(stack, 'myRole', {\n        assumedBy: new ServicePrincipal('foo.amazonaws.com', {\n          region: 'bermuda-triangle-1337',\n        }),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        // instanceRole is unchanged from default\n      },\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::InstanceProfile', {\n      Roles: [{ Ref: 'myRoleE60D68E8' }],\n    });\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: { Service: 'foo.amazonaws.com' },\n        }],\n        Version: '2012-10-17',\n      },\n    });\n  });\n\n  test('respects launch template', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      launchTemplate: new ec2.LaunchTemplate(stack, 'launchTemplate'),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        LaunchTemplate: {\n          LaunchTemplateId: { Ref: 'launchTemplateDEE5742D' },\n        },\n      },\n    });\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      computeEnvironmentName: 'NamedCE',\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeEnvironmentName: 'NamedCE',\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('respects placement group', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      placementGroup: new ec2.PlacementGroup(stack, 'myPlacementGroup'),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        PlacementGroup: {\n          'Fn::GetAtt': ['myPlacementGroup2E94D14E', 'GroupName'],\n        },\n      },\n    });\n  });\n\n  test('respects replaceComputeEnvironment', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      replaceComputeEnvironment: true,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      ReplaceComputeEnvironment: true,\n    });\n  });\n\n  test('respects security groups', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      securityGroups: [new ec2.SecurityGroup(stack, 'TestSG', {\n        vpc,\n        allowAllOutbound: false,\n      })],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        SecurityGroupIds: [{\n          'Fn::GetAtt': ['TestSG581D3391', 'GroupId'],\n        }],\n      },\n    });\n  });\n\n  test('respects service role', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      serviceRole: new Role(stack, 'TestSLR', {\n        assumedBy: new ServicePrincipal('cdk.amazonaws.com'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ServiceRole: {\n        'Fn::GetAtt': ['TestSLR05974C22', 'Arn'],\n      },\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('respects vpcSubnets', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpcSubnets: {\n        subnets: [new ec2.Subnet(stack, 'testSubnet', {\n          availabilityZone: 'az-3',\n          cidrBlock: '10.0.0.0/32',\n          vpcId: new ec2.Vpc(stack, 'subnetVpc').vpcId,\n        })],\n      },\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Subnets: [\n          { Ref: 'testSubnet42F0FA0C' },\n        ],\n      },\n    });\n  });\n\n  test('respects updateTimeout', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      updateTimeout: Duration.minutes(1),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      UpdatePolicy: {\n        JobExecutionTimeoutMinutes: 1,\n      },\n    });\n  });\n\n  test('respects terminateOnUpdate', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      terminateOnUpdate: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n      UpdatePolicy: {\n        TerminateJobsOnUpdate: false,\n      },\n    });\n  });\n\n  test('respects updateToLatestImageVersion', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      updateToLatestImageVersion: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        UpdateToLatestImageVersion: false,\n      },\n    });\n  });\n\n  test('respects tags', () => {\n    // WHEN\n    const ce = new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n    });\n\n    Tags.of(ce).add('superfood', 'acai');\n    Tags.of(ce).add('super', 'salamander');\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...expectedProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Tags: {\n          superfood: 'acai',\n          super: 'salamander',\n        },\n      },\n    });\n  });\n\n  test('can be imported from arn', () => {\n    // WHEN\n    const ce = ManagedEc2EcsComputeEnvironment.fromManagedEc2EcsComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n\n    // THEN\n    expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n  });\n\n  test('attach necessary managed policy to instance role', () => {\n    // WHEN\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::IAM::Role', {\n      ManagedPolicyArns: [\n        {\n          'Fn::Join': [\n            '',\n            [\n              'arn:',\n              {\n                Ref: 'AWS::Partition',\n              },\n              ':iam::aws:policy/service-role/AmazonEC2ContainerServiceforEC2Role',\n            ],\n          ],\n        },\n      ],\n    });\n  });\n\n  test('throws when no instance types are provided', () => {\n    new ComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      useOptimalInstanceClasses: false,\n      vpc,\n    });\n\n    expect(() => {\n      Template.fromStack(stack);\n    }).toThrow(/Specifies 'useOptimalInstanceClasses: false' without specifying any instance types or classes/);\n  });\n\n  test('throws error when AllocationStrategy.SPOT_CAPACITY_OPTIMIZED is used without specfiying spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        allocationStrategy: AllocationStrategy.SPOT_CAPACITY_OPTIMIZED,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_CAPACITY_OPTIMIZED' without using spot instances/);\n  });\n\n  test('throws error when AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED is used without specfiying spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        allocationStrategy: AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED' without using spot instances/);\n  });\n\n  test('throws error when spotBidPercentage is specified without spot', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 80,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/);\n  });\n\n  test('throws error when spotBidPercentage is specified and spot is false', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 80,\n        spot: false,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' without specifying 'spot'/);\n  });\n\n  test('throws error when spotBidPercentage > 100', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: 120,\n        spot: true,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' > 100/);\n  });\n\n  test('throws error when spotBidPercentage < 0', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        spotBidPercentage: -120,\n        spot: true,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotBidPercentage' < 0/);\n  });\n\n  test('throws error when minvCpus > maxvCpus', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        maxvCpus: 512,\n        minvCpus: 1024,\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = 1024 > 'maxvCpus' = 512; 'minvCpus' cannot be greater than 'maxvCpus'/);\n  });\n\n  test('throws error when minvCpus < 0', () => {\n    // THEN\n    expect(() => {\n      new ComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        vpc,\n        minvCpus: -256,\n      });\n    }).toThrowError(/Managed ComputeEnvironment 'MyCE' has 'minvCpus' = -256 < 0; 'minvCpus' cannot be less than zero/);\n  });\n});\n\ndescribe('ManagedEc2EcsComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n  });\n\n  test('respects spotFleetRole', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultEcsProps,\n      spot: true,\n      spotFleetRole: new Role(stack, 'SpotFleetRole', {\n        assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'),\n      }),\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        AllocationStrategy: AllocationStrategy.SPOT_PRICE_CAPACITY_OPTIMIZED,\n        Type: 'SPOT',\n        SpotIamFleetRole: {\n          'Fn::GetAtt': ['SpotFleetRole6D4F7558', 'Arn'],\n        },\n      },\n    });\n  });\n\n  test('image types are correctly rendered as EC2ConfigurationObjects', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultEcsProps,\n      vpc,\n      images: [\n        {\n          imageType: batch.EcsMachineImageType.ECS_AL2_NVIDIA,\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageType: 'ECS_AL2_NVIDIA',\n          },\n        ],\n      },\n    });\n  });\n\n  test('can use non-default allocation strategy', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      allocationStrategy: AllocationStrategy.BEST_FIT,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        AllocationStrategy: 'BEST_FIT',\n      },\n    });\n  });\n\n  test('spot and AllocationStrategy.BEST_FIT => a default spot fleet role is created', () => {\n    // WHEN\n    new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n      ...defaultProps,\n      vpc,\n      spot: true,\n      allocationStrategy: AllocationStrategy.BEST_FIT,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEcsProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Type: 'SPOT',\n        AllocationStrategy: 'BEST_FIT',\n        SpotIamFleetRole: { 'Fn::GetAtt': ['MyCESpotFleetRole70BE30A0', 'Arn'] },\n      },\n    });\n  });\n\n  test('throws when spotFleetRole is specified without spot', () => {\n    // WHEN\n    expect(() => {\n      new ManagedEc2EcsComputeEnvironment(stack, 'MyCE', {\n        ...defaultEcsProps,\n        spotFleetRole: new Role(stack, 'SpotFleetRole', {\n          assumedBy: new ArnPrincipal('arn:aws:iam:123456789012:magicuser/foobar'),\n        }),\n      });\n    }).toThrow(/Managed ComputeEnvironment 'MyCE' specifies 'spotFleetRole' without specifying 'spot'/);\n  });\n});\n\ndescribe('ManagedEc2EksComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n\n    pascalCaseExpectedEcsProps = capitalizePropertyNames(stack, defaultExpectedEcsProps);\n    pascalCaseExpectedEksProps = capitalizePropertyNames(stack, defaultExpectedEksProps);\n    defaultComputeResources = pascalCaseExpectedEcsProps.ComputeResources;\n\n    defaultEcsProps = {\n      vpc,\n    };\n    defaultEksProps = {\n      vpc,\n      kubernetesNamespace: 'cdk-test-namespace',\n      eksCluster: new eks.Cluster(stack, 'eksTestCluster', {\n        version: eks.KubernetesVersion.V1_24,\n      }),\n    };\n  });\n\n  test('default props', () => {\n    // WHEN\n    new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n      ...defaultEksProps,\n      vpc,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEksProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n      },\n    });\n  });\n\n  test('throws error when AllocationStrategy.BEST_FIT is used', () => {\n    // THEN\n    expect(() => {\n      new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n        ...defaultProps,\n        allocationStrategy: AllocationStrategy.BEST_FIT,\n      });\n    }).toThrow(/ManagedEc2EksComputeEnvironment 'MyCE' uses invalid allocation strategy 'AllocationStrategy.BEST_FIT'/);\n  });\n\n  test('image types are correctly rendered as EC2ConfigurationObjects', () => {\n    // WHEN\n    new ManagedEc2EksComputeEnvironment(stack, 'MyCE', {\n      ...defaultEksProps,\n      vpc,\n      images: [\n        {\n          imageType: batch.EksMachineImageType.EKS_AL2_NVIDIA,\n        },\n      ],\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ...pascalCaseExpectedEksProps,\n      ComputeResources: {\n        ...defaultComputeResources,\n        Ec2Configuration: [\n          {\n            ImageType: 'EKS_AL2_NVIDIA',\n          },\n        ],\n      },\n    });\n  });\n});\n\ndescribe('FargateComputeEnvironment', () => {\n  beforeEach(() => {\n    stack = new Stack();\n    vpc = new ec2.Vpc(stack, 'vpc');\n  });\n\n  test('respects name', () => {\n    // WHEN\n    new FargateComputeEnvironment(stack, 'maximalPropsFargate', {\n      vpc,\n      maxvCpus: 512,\n      computeEnvironmentName: 'maxPropsFargateCE',\n      replaceComputeEnvironment: true,\n      spot: true,\n      terminateOnUpdate: true,\n      updateTimeout: Duration.minutes(30),\n      updateToLatestImageVersion: false,\n    });\n\n    // THEN\n    Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', {\n      ComputeEnvironmentName: 'maxPropsFargateCE',\n    });\n  });\n\n  test('can be imported from arn', () => {\n    // WHEN\n    const ce = FargateComputeEnvironment.fromFargateComputeEnvironmentArn(stack, 'import', 'arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n\n    // THEN\n    expect(ce.computeEnvironmentArn).toEqual('arn:aws:batch:us-east-1:123456789012:compute-environment/ce-name');\n  });\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js b/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js deleted file mode 100644 index 0120ecf9bd8eb..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/multinode-job-definition.test.js +++ /dev/null @@ -1,155 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const aws_ec2_1 = require("aws-cdk-lib/aws-ec2"); -const ecs = require("aws-cdk-lib/aws-ecs"); -const aws_cdk_lib_1 = require("aws-cdk-lib"); -const lib_1 = require("../lib"); -test('MultiNodeJobDefinition respects mainNode', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { - containers: [{ - container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 0, - endNode: 9, - }], - mainNode: 5, - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - NodeProperties: { - MainNode: 5, - NodeRangeProperties: [{ - Container: { - InstanceType: 'r4.large', - }, - TargetNodes: '0:9', - }], - NumNodes: 10, - }, - PlatformCapabilities: [lib_1.Compatibility.EC2], - }); -}); -test('EcsJobDefinition respects propagateTags', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { - propagateTags: true, - containers: [{ - container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 0, - endNode: 9, - }], - mainNode: 0, - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - PropagateTags: true, - }); -}); -test('MultiNodeJobDefinition one container', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { - containers: [{ - container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 0, - endNode: 9, - }], - mainNode: 0, - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - NodeProperties: { - MainNode: 0, - NodeRangeProperties: [{ - Container: { - InstanceType: 'r4.large', - }, - TargetNodes: '0:9', - }], - NumNodes: 10, - }, - PlatformCapabilities: [lib_1.Compatibility.EC2], - }); -}); -test('MultiNodeJobDefinition two containers', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { - containers: [ - { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer1', { - cpu: 256, - memory: aws_cdk_lib_1.Size.mebibytes(2048), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 0, - endNode: 9, - }, - { - container: new lib_1.EcsEc2ContainerDefinition(stack, 'MultinodeContainer2', { - cpu: 512, - memory: aws_cdk_lib_1.Size.mebibytes(4096), - image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'), - }), - startNode: 10, - endNode: 14, - }, - ], - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.R4, aws_ec2_1.InstanceSize.LARGE), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', { - NodeProperties: { - MainNode: 0, - NodeRangeProperties: [ - { - Container: { - InstanceType: 'r4.large', - }, - TargetNodes: '0:9', - }, - { - Container: { - InstanceType: 'r4.large', - }, - TargetNodes: '10:14', - }, - ], - NumNodes: 15, - }, - PlatformCapabilities: [lib_1.Compatibility.EC2], - }); -}); -test('multinode job requires at least one container', () => { - // GIVEN - const stack = new aws_cdk_lib_1.Stack(); - // WHEN - new lib_1.MultiNodeJobDefinition(stack, 'ECSJobDefn', { - instanceType: aws_ec2_1.InstanceType.of(aws_ec2_1.InstanceClass.C4, aws_ec2_1.InstanceSize.LARGE), - }); - // THEN - expect(() => assertions_1.Template.fromStack(stack)).toThrow(/multinode job has no containers!/); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multinode-job-definition.test.js","sourceRoot":"","sources":["multinode-job-definition.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { InstanceClass, InstanceSize, InstanceType } from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Size, Stack } from 'aws-cdk-lib';\nimport { Compatibility, EcsEc2ContainerDefinition, MultiNodeJobDefinition } from '../lib';\n\ntest('MultiNodeJobDefinition respects mainNode', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 5,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 5,\n      NodeRangeProperties: [{\n        Container: {\n          InstanceType: 'r4.large',\n        },\n        TargetNodes: '0:9',\n      }],\n      NumNodes: 10,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('EcsJobDefinition respects propagateTags', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    propagateTags: true,\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 0,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    PropagateTags: true,\n  });\n});\n\ntest('MultiNodeJobDefinition one container', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [{\n      container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer', {\n        cpu: 256,\n        memory: Size.mebibytes(2048),\n        image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n      }),\n      startNode: 0,\n      endNode: 9,\n    }],\n    mainNode: 0,\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 0,\n      NodeRangeProperties: [{\n        Container: {\n          InstanceType: 'r4.large',\n        },\n        TargetNodes: '0:9',\n      }],\n      NumNodes: 10,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('MultiNodeJobDefinition two containers', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    containers: [\n      {\n        container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer1', {\n          cpu: 256,\n          memory: Size.mebibytes(2048),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 0,\n        endNode: 9,\n      },\n      {\n        container: new EcsEc2ContainerDefinition(stack, 'MultinodeContainer2', {\n          cpu: 512,\n          memory: Size.mebibytes(4096),\n          image: ecs.ContainerImage.fromRegistry('amazon/amazon-ecs-sample'),\n        }),\n        startNode: 10,\n        endNode: 14,\n      },\n    ],\n    instanceType: InstanceType.of(InstanceClass.R4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::JobDefinition', {\n    NodeProperties: {\n      MainNode: 0,\n      NodeRangeProperties: [\n        {\n          Container: {\n            InstanceType: 'r4.large',\n          },\n          TargetNodes: '0:9',\n        },\n        {\n          Container: {\n            InstanceType: 'r4.large',\n          },\n          TargetNodes: '10:14',\n        },\n\n      ],\n      NumNodes: 15,\n    },\n    PlatformCapabilities: [Compatibility.EC2],\n  });\n});\n\ntest('multinode job requires at least one container', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new MultiNodeJobDefinition(stack, 'ECSJobDefn', {\n    instanceType: InstanceType.of(InstanceClass.C4, InstanceSize.LARGE),\n  });\n\n  // THEN\n  expect(() => Template.fromStack(stack)).toThrow(/multinode job has no containers!/);\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js b/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js deleted file mode 100644 index b15d5d7caa7f6..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/scheduling-policy.test.js +++ /dev/null @@ -1,133 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const core_1 = require("aws-cdk-lib/core"); -const lib_1 = require("../lib"); -test('empty fairshare policy', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy'); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - FairsharePolicy: { - ShareDistribution: [], - }, - }); -}); -test('fairshare policy respects computeReservation', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { - computeReservation: 75, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - FairsharePolicy: { - ComputeReservation: 75, - ShareDistribution: [], - }, - }); -}); -test('fairshare policy respects name', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { - schedulingPolicyName: 'FairsharePolicyName', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - Name: 'FairsharePolicyName', - FairsharePolicy: { - ShareDistribution: [], - }, - }); -}); -test('fairshare policy respects shareDecay', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { - shareDecay: core_1.Duration.hours(1), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - FairsharePolicy: { - ShareDecaySeconds: 3600, - ShareDistribution: [], - }, - }); -}); -test('fairshare policy respects shares', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { - shares: [ - { - shareIdentifier: 'myShareId', - weightFactor: 0.5, - }, - { - shareIdentifier: 'myShareId2', - weightFactor: 1, - }, - ], - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - FairsharePolicy: { - ShareDistribution: [ - { - ShareIdentifier: 'myShareId', - WeightFactor: 0.5, - }, - { - ShareIdentifier: 'myShareId2', - WeightFactor: 1, - }, - ], - }, - }); -}); -test('addShare() works', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - const policy = new lib_1.FairshareSchedulingPolicy(stack, 'schedulingPolicy', { - shares: [{ - shareIdentifier: 'myShareId', - weightFactor: 0.5, - }], - }); - policy.addShare({ - shareIdentifier: 'addedShareId', - weightFactor: 0.5, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', { - FairsharePolicy: { - ShareDistribution: [ - { - ShareIdentifier: 'myShareId', - WeightFactor: 0.5, - }, - { - ShareIdentifier: 'addedShareId', - WeightFactor: 0.5, - }, - ], - }, - }); -}); -test('can be imported from ARN', () => { - // GIVEN - const stack = new core_1.Stack(); - // WHEN - const policy = lib_1.FairshareSchedulingPolicy.fromFairshareSchedulingPolicyArn(stack, 'policyImport', 'arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport'); - // THEN - expect(policy.schedulingPolicyArn).toEqual('arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport'); -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheduling-policy.test.js","sourceRoot":"","sources":["scheduling-policy.test.ts"],"names":[],"mappings":";;AAAA,uDAAkD;AAClD,2CAAmD;AACnD,gCAAmD;AAEnD,IAAI,CAAC,wBAAwB,EAAE,GAAG,EAAE;IAClC,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;IAEzD,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,eAAe,EAAE;YACf,iBAAiB,EAAE,EAAE;SACtB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;IACxD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE;QACvD,kBAAkB,EAAE,EAAE;KACvB,CAAC,CAAC;IAEH,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,eAAe,EAAE;YACf,kBAAkB,EAAE,EAAE;YACtB,iBAAiB,EAAE,EAAE;SACtB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gCAAgC,EAAE,GAAG,EAAE;IAC1C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE;QACvD,oBAAoB,EAAE,qBAAqB;KAC5C,CAAC,CAAC;IAEH,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,IAAI,EAAE,qBAAqB;QAC3B,eAAe,EAAE;YACf,iBAAiB,EAAE,EAAE;SACtB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;IAChD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE;QACvD,UAAU,EAAE,eAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;KAC9B,CAAC,CAAC;IAEH,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,eAAe,EAAE;YACf,iBAAiB,EAAE,IAAI;YACvB,iBAAiB,EAAE,EAAE;SACtB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kCAAkC,EAAE,GAAG,EAAE;IAC5C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE;QACvD,MAAM,EAAE;YACN;gBACE,eAAe,EAAE,WAAW;gBAC5B,YAAY,EAAE,GAAG;aAClB;YACD;gBACE,eAAe,EAAE,YAAY;gBAC7B,YAAY,EAAE,CAAC;aAChB;SACF;KACF,CAAC,CAAC;IAEH,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,eAAe,EAAE;YACf,iBAAiB,EAAE;gBACjB;oBACE,eAAe,EAAE,WAAW;oBAC5B,YAAY,EAAE,GAAG;iBAClB;gBACD;oBACE,eAAe,EAAE,YAAY;oBAC7B,YAAY,EAAE,CAAC;iBAChB;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAC5B,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,MAAM,MAAM,GAAG,IAAI,+BAAyB,CAAC,KAAK,EAAE,kBAAkB,EAAE;QACtE,MAAM,EAAE,CAAC;gBACP,eAAe,EAAE,WAAW;gBAC5B,YAAY,EAAE,GAAG;aAClB,CAAC;KACH,CAAC,CAAC;IACH,MAAM,CAAC,QAAQ,CAAC;QACd,eAAe,EAAE,cAAc;QAC/B,YAAY,EAAE,GAAG;KAClB,CAAC,CAAC;IAEH,OAAO;IACP,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,8BAA8B,EAAE;QAC9E,eAAe,EAAE;YACf,iBAAiB,EAAE;gBACjB;oBACE,eAAe,EAAE,WAAW;oBAC5B,YAAY,EAAE,GAAG;iBAClB;gBACD;oBACE,eAAe,EAAE,cAAc;oBAC/B,YAAY,EAAE,GAAG;iBAClB;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACpC,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,YAAK,EAAE,CAAC;IAE1B,OAAO;IACP,MAAM,MAAM,GAAG,+BAAyB,CAAC,gCAAgC,CAAC,KAAK,EAAE,cAAc,EAC7F,qEAAqE,CAAC,CAAC;IAEzE,OAAO;IACP,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,qEAAqE,CAAC,CAAC;AACpH,CAAC,CAAC,CAAC","sourcesContent":["import { Template } from 'aws-cdk-lib/assertions';\nimport { Duration, Stack } from 'aws-cdk-lib/core';\nimport { FairshareSchedulingPolicy } from '../lib';\n\ntest('empty fairshare policy', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy');\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects computeReservation', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    computeReservation: 75,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ComputeReservation: 75,\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects name', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    schedulingPolicyName: 'FairsharePolicyName',\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    Name: 'FairsharePolicyName',\n    FairsharePolicy: {\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects shareDecay', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shareDecay: Duration.hours(1),\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDecaySeconds: 3600,\n      ShareDistribution: [],\n    },\n  });\n});\n\ntest('fairshare policy respects shares', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shares: [\n      {\n        shareIdentifier: 'myShareId',\n        weightFactor: 0.5,\n      },\n      {\n        shareIdentifier: 'myShareId2',\n        weightFactor: 1,\n      },\n    ],\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [\n        {\n          ShareIdentifier: 'myShareId',\n          WeightFactor: 0.5,\n        },\n        {\n          ShareIdentifier: 'myShareId2',\n          WeightFactor: 1,\n        },\n      ],\n    },\n  });\n});\n\ntest('addShare() works', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const policy = new FairshareSchedulingPolicy(stack, 'schedulingPolicy', {\n    shares: [{\n      shareIdentifier: 'myShareId',\n      weightFactor: 0.5,\n    }],\n  });\n  policy.addShare({\n    shareIdentifier: 'addedShareId',\n    weightFactor: 0.5,\n  });\n\n  // THEN\n  Template.fromStack(stack).hasResourceProperties('AWS::Batch::SchedulingPolicy', {\n    FairsharePolicy: {\n      ShareDistribution: [\n        {\n          ShareIdentifier: 'myShareId',\n          WeightFactor: 0.5,\n        },\n        {\n          ShareIdentifier: 'addedShareId',\n          WeightFactor: 0.5,\n        },\n      ],\n    },\n  });\n});\n\ntest('can be imported from ARN', () => {\n  // GIVEN\n  const stack = new Stack();\n\n  // WHEN\n  const policy = FairshareSchedulingPolicy.fromFairshareSchedulingPolicyArn(stack, 'policyImport',\n    'arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport');\n\n  // THEN\n  expect(policy.schedulingPolicyArn).toEqual('arn:aws:batch:us-east-1:123456789012:scheduling-policy/policyImport');\n});\n"]} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts deleted file mode 100644 index cb0ff5c3b541f..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.d.ts +++ /dev/null @@ -1 +0,0 @@ -export {}; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js b/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js deleted file mode 100644 index 4c7fe0a2e433a..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/unmanaged-compute-environment.test.js +++ /dev/null @@ -1,90 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -const assertions_1 = require("aws-cdk-lib/assertions"); -const aws_iam_1 = require("aws-cdk-lib/aws-iam"); -const core_1 = require("aws-cdk-lib/core"); -const utils_1 = require("./utils"); -const unmanaged_compute_environment_1 = require("../lib/unmanaged-compute-environment"); -const defaultExpectedProps = { - type: 'unmanaged', - computeEnvironmentName: undefined, - computeResources: undefined, - eksConfiguration: undefined, - replaceComputeEnvironment: undefined, - serviceRole: { - 'Fn::GetAtt': ['MyCEBatchServiceRole4FDA2CB6', 'Arn'], - }, - state: 'ENABLED', - tags: undefined, - unmanagedvCpus: undefined, - updatePolicy: undefined, -}; -let stack = new core_1.Stack(); -const pascalCaseExpectedProps = (0, utils_1.capitalizePropertyNames)(stack, defaultExpectedProps); -test('default props', () => { - // GIVEN - stack = new core_1.Stack(); - // WHEN - new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE'); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedProps, - }); -}); -test('respects enabled: false', () => { - // GIVEN - stack = new core_1.Stack(); - // WHEN - new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { - enabled: false, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedProps, - State: 'DISABLED', - }); -}); -test('respects name', () => { - // GIVEN - stack = new core_1.Stack(); - // WHEN - new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { - computeEnvironmentName: 'magic', - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedProps, - ComputeEnvironmentName: 'magic', - }); -}); -test('respects serviceRole', () => { - // GIVEN - stack = new core_1.Stack(); - // WHEN - new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { - serviceRole: new aws_iam_1.Role(stack, 'myMagicRole', { - assumedBy: new aws_iam_1.ServicePrincipal('batch.amazonaws.com'), - }), - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedProps, - ServiceRole: { - 'Fn::GetAtt': ['myMagicRole2BBD827A', 'Arn'], - }, - }); -}); -test('respects unmanagedvCpus', () => { - // GIVEN - stack = new core_1.Stack(); - // WHEN - new unmanaged_compute_environment_1.UnmanagedComputeEnvironment(stack, 'MyCE', { - unmanagedvCpus: 256, - }); - // THEN - assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::Batch::ComputeEnvironment', { - ...pascalCaseExpectedProps, - UnmanagedvCpus: 256, - }); -}); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5tYW5hZ2VkLWNvbXB1dGUtZW52aXJvbm1lbnQudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50LnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx1REFBa0Q7QUFDbEQsaURBQTZEO0FBQzdELDJDQUF5QztBQUN6QyxtQ0FBa0Q7QUFFbEQsd0ZBQW1GO0FBRW5GLE1BQU0sb0JBQW9CLEdBQStCO0lBQ3ZELElBQUksRUFBRSxXQUFXO0lBQ2pCLHNCQUFzQixFQUFFLFNBQVM7SUFDakMsZ0JBQWdCLEVBQUUsU0FBUztJQUMzQixnQkFBZ0IsRUFBRSxTQUFTO0lBQzNCLHlCQUF5QixFQUFFLFNBQVM7SUFDcEMsV0FBVyxFQUFFO1FBQ1gsWUFBWSxFQUFFLENBQUMsOEJBQThCLEVBQUUsS0FBSyxDQUFDO0tBQy9DO0lBQ1IsS0FBSyxFQUFFLFNBQVM7SUFDaEIsSUFBSSxFQUFFLFNBQVM7SUFDZixjQUFjLEVBQUUsU0FBUztJQUN6QixZQUFZLEVBQUUsU0FBUztDQUN4QixDQUFDO0FBRUYsSUFBSSxLQUFLLEdBQUcsSUFBSSxZQUFLLEVBQUUsQ0FBQztBQUN4QixNQUFNLHVCQUF1QixHQUFHLElBQUEsK0JBQXVCLEVBQUMsS0FBSyxFQUFFLG9CQUFvQixDQUFDLENBQUM7QUFFckYsSUFBSSxDQUFDLGVBQWUsRUFBRSxHQUFHLEVBQUU7SUFDekIsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztJQUUvQyxPQUFPO0lBQ1AscUJBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMscUJBQXFCLENBQUMsZ0NBQWdDLEVBQUU7UUFDaEYsR0FBRyx1QkFBdUI7S0FDM0IsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLENBQUMseUJBQXlCLEVBQUUsR0FBRyxFQUFFO0lBQ25DLFFBQVE7SUFDUixLQUFLLEdBQUcsSUFBSSxZQUFLLEVBQUUsQ0FBQztJQUVwQixPQUFPO0lBQ1AsSUFBSSwyREFBMkIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFO1FBQzdDLE9BQU8sRUFBRSxLQUFLO0tBQ2YsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLGdDQUFnQyxFQUFFO1FBQ2hGLEdBQUcsdUJBQXVCO1FBQzFCLEtBQUssRUFBRSxVQUFVO0tBQ2xCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDO0FBRUgsSUFBSSxDQUFDLGVBQWUsRUFBRSxHQUFHLEVBQUU7SUFDekIsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0Msc0JBQXNCLEVBQUUsT0FBTztLQUNoQyxDQUFDLENBQUM7SUFFSCxPQUFPO0lBQ1AscUJBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMscUJBQXFCLENBQUMsZ0NBQWdDLEVBQUU7UUFDaEYsR0FBRyx1QkFBdUI7UUFDMUIsc0JBQXNCLEVBQUUsT0FBTztLQUNoQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyxzQkFBc0IsRUFBRSxHQUFHLEVBQUU7SUFDaEMsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0MsV0FBVyxFQUFFLElBQUksY0FBSSxDQUFDLEtBQUssRUFBRSxhQUFhLEVBQUU7WUFDMUMsU0FBUyxFQUFFLElBQUksMEJBQWdCLENBQUMscUJBQXFCLENBQUM7U0FDdkQsQ0FBQztLQUNILENBQUMsQ0FBQztJQUVILE9BQU87SUFDUCxxQkFBUSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQyxnQ0FBZ0MsRUFBRTtRQUNoRixHQUFHLHVCQUF1QjtRQUMxQixXQUFXLEVBQUU7WUFDWCxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxLQUFLLENBQUM7U0FDN0M7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQztBQUVILElBQUksQ0FBQyx5QkFBeUIsRUFBRSxHQUFHLEVBQUU7SUFDbkMsUUFBUTtJQUNSLEtBQUssR0FBRyxJQUFJLFlBQUssRUFBRSxDQUFDO0lBRXBCLE9BQU87SUFDUCxJQUFJLDJEQUEyQixDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7UUFDN0MsY0FBYyxFQUFFLEdBQUc7S0FDcEIsQ0FBQyxDQUFDO0lBRUgsT0FBTztJQUNQLHFCQUFRLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLHFCQUFxQixDQUFDLGdDQUFnQyxFQUFFO1FBQ2hGLEdBQUcsdUJBQXVCO1FBQzFCLGNBQWMsRUFBRSxHQUFHO0tBQ3BCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGUgfSBmcm9tICdhd3MtY2RrLWxpYi9hc3NlcnRpb25zJztcbmltcG9ydCB7IFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnYXdzLWNkay1saWIvY29yZSc7XG5pbXBvcnQgeyBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgQ2ZuQ29tcHV0ZUVudmlyb25tZW50UHJvcHMgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtYmF0Y2gnO1xuaW1wb3J0IHsgVW5tYW5hZ2VkQ29tcHV0ZUVudmlyb25tZW50IH0gZnJvbSAnLi4vbGliL3VubWFuYWdlZC1jb21wdXRlLWVudmlyb25tZW50JztcblxuY29uc3QgZGVmYXVsdEV4cGVjdGVkUHJvcHM6IENmbkNvbXB1dGVFbnZpcm9ubWVudFByb3BzID0ge1xuICB0eXBlOiAndW5tYW5hZ2VkJyxcbiAgY29tcHV0ZUVudmlyb25tZW50TmFtZTogdW5kZWZpbmVkLFxuICBjb21wdXRlUmVzb3VyY2VzOiB1bmRlZmluZWQsXG4gIGVrc0NvbmZpZ3VyYXRpb246IHVuZGVmaW5lZCxcbiAgcmVwbGFjZUNvbXB1dGVFbnZpcm9ubWVudDogdW5kZWZpbmVkLFxuICBzZXJ2aWNlUm9sZToge1xuICAgICdGbjo6R2V0QXR0JzogWydNeUNFQmF0Y2hTZXJ2aWNlUm9sZTRGREEyQ0I2JywgJ0FybiddLFxuICB9IGFzIGFueSxcbiAgc3RhdGU6ICdFTkFCTEVEJyxcbiAgdGFnczogdW5kZWZpbmVkLFxuICB1bm1hbmFnZWR2Q3B1czogdW5kZWZpbmVkLFxuICB1cGRhdGVQb2xpY3k6IHVuZGVmaW5lZCxcbn07XG5cbmxldCBzdGFjayA9IG5ldyBTdGFjaygpO1xuY29uc3QgcGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMgPSBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhzdGFjaywgZGVmYXVsdEV4cGVjdGVkUHJvcHMpO1xuXG50ZXN0KCdkZWZhdWx0IHByb3BzJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnKTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnQnLCB7XG4gICAgLi4ucGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMsXG4gIH0pO1xufSk7XG5cbnRlc3QoJ3Jlc3BlY3RzIGVuYWJsZWQ6IGZhbHNlJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnLCB7XG4gICAgZW5hYmxlZDogZmFsc2UsXG4gIH0pO1xuXG4gIC8vIFRIRU5cbiAgVGVtcGxhdGUuZnJvbVN0YWNrKHN0YWNrKS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6QmF0Y2g6OkNvbXB1dGVFbnZpcm9ubWVudCcsIHtcbiAgICAuLi5wYXNjYWxDYXNlRXhwZWN0ZWRQcm9wcyxcbiAgICBTdGF0ZTogJ0RJU0FCTEVEJyxcbiAgfSk7XG59KTtcblxudGVzdCgncmVzcGVjdHMgbmFtZScsICgpID0+IHtcbiAgLy8gR0lWRU5cbiAgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAvLyBXSEVOXG4gIG5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdNeUNFJywge1xuICAgIGNvbXB1dGVFbnZpcm9ubWVudE5hbWU6ICdtYWdpYycsXG4gIH0pO1xuXG4gIC8vIFRIRU5cbiAgVGVtcGxhdGUuZnJvbVN0YWNrKHN0YWNrKS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6QmF0Y2g6OkNvbXB1dGVFbnZpcm9ubWVudCcsIHtcbiAgICAuLi5wYXNjYWxDYXNlRXhwZWN0ZWRQcm9wcyxcbiAgICBDb21wdXRlRW52aXJvbm1lbnROYW1lOiAnbWFnaWMnLFxuICB9KTtcbn0pO1xuXG50ZXN0KCdyZXNwZWN0cyBzZXJ2aWNlUm9sZScsICgpID0+IHtcbiAgLy8gR0lWRU5cbiAgc3RhY2sgPSBuZXcgU3RhY2soKTtcblxuICAvLyBXSEVOXG4gIG5ldyBVbm1hbmFnZWRDb21wdXRlRW52aXJvbm1lbnQoc3RhY2ssICdNeUNFJywge1xuICAgIHNlcnZpY2VSb2xlOiBuZXcgUm9sZShzdGFjaywgJ215TWFnaWNSb2xlJywge1xuICAgICAgYXNzdW1lZEJ5OiBuZXcgU2VydmljZVByaW5jaXBhbCgnYmF0Y2guYW1hem9uYXdzLmNvbScpLFxuICAgIH0pLFxuICB9KTtcblxuICAvLyBUSEVOXG4gIFRlbXBsYXRlLmZyb21TdGFjayhzdGFjaykuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkJhdGNoOjpDb21wdXRlRW52aXJvbm1lbnQnLCB7XG4gICAgLi4ucGFzY2FsQ2FzZUV4cGVjdGVkUHJvcHMsXG4gICAgU2VydmljZVJvbGU6IHtcbiAgICAgICdGbjo6R2V0QXR0JzogWydteU1hZ2ljUm9sZTJCQkQ4MjdBJywgJ0FybiddLFxuICAgIH0sXG4gIH0pO1xufSk7XG5cbnRlc3QoJ3Jlc3BlY3RzIHVubWFuYWdlZHZDcHVzJywgKCkgPT4ge1xuICAvLyBHSVZFTlxuICBzdGFjayA9IG5ldyBTdGFjaygpO1xuXG4gIC8vIFdIRU5cbiAgbmV3IFVubWFuYWdlZENvbXB1dGVFbnZpcm9ubWVudChzdGFjaywgJ015Q0UnLCB7XG4gICAgdW5tYW5hZ2VkdkNwdXM6IDI1NixcbiAgfSk7XG5cbiAgLy8gVEhFTlxuICBUZW1wbGF0ZS5mcm9tU3RhY2soc3RhY2spLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpCYXRjaDo6Q29tcHV0ZUVudmlyb25tZW50Jywge1xuICAgIC4uLnBhc2NhbENhc2VFeHBlY3RlZFByb3BzLFxuICAgIFVubWFuYWdlZHZDcHVzOiAyNTYsXG4gIH0pO1xufSk7XG4iXX0= \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts b/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts deleted file mode 100644 index 934fcac4357e0..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/utils.d.ts +++ /dev/null @@ -1,6 +0,0 @@ -import { IConstruct } from 'constructs'; -/** - * Given an object, converts all keys to PascalCase given they are currently in camel case. - * @param obj The object. - */ -export declare function capitalizePropertyNames(construct: IConstruct, obj: any): any; diff --git a/packages/@aws-cdk/aws-batch-alpha/test/utils.js b/packages/@aws-cdk/aws-batch-alpha/test/utils.js deleted file mode 100644 index c804b15bf6337..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/test/utils.js +++ /dev/null @@ -1,28 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.capitalizePropertyNames = void 0; -const aws_cdk_lib_1 = require("aws-cdk-lib"); -/** - * Given an object, converts all keys to PascalCase given they are currently in camel case. - * @param obj The object. - */ -function capitalizePropertyNames(construct, obj) { - const stack = aws_cdk_lib_1.Stack.of(construct); - obj = stack.resolve(obj); - if (typeof (obj) !== 'object') { - return obj; - } - if (Array.isArray(obj)) { - return obj.map(x => capitalizePropertyNames(construct, x)); - } - const newObj = {}; - for (const key of Object.keys(obj)) { - const value = obj[key]; - const first = key.charAt(0).toUpperCase(); - const newKey = first + key.slice(1); - newObj[newKey] = capitalizePropertyNames(construct, value); - } - return newObj; -} -exports.capitalizePropertyNames = capitalizePropertyNames; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2Q0FBb0M7QUFHcEM7OztHQUdHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQUMsU0FBcUIsRUFBRSxHQUFRO0lBQ3JFLE1BQU0sS0FBSyxHQUFHLG1CQUFLLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2xDLEdBQUcsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXpCLElBQUksT0FBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLFFBQVEsRUFBRTtRQUM1QixPQUFPLEdBQUcsQ0FBQztLQUNaO0lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQzVEO0lBRUQsTUFBTSxNQUFNLEdBQVEsRUFBRyxDQUFDO0lBQ3hCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNsQyxNQUFNLEtBQUssR0FBRyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdkIsTUFBTSxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUMxQyxNQUFNLE1BQU0sR0FBRyxLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNwQyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsdUJBQXVCLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO0tBQzVEO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQXRCRCwwREFzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuLyoqXG4gKiBHaXZlbiBhbiBvYmplY3QsIGNvbnZlcnRzIGFsbCBrZXlzIHRvIFBhc2NhbENhc2UgZ2l2ZW4gdGhleSBhcmUgY3VycmVudGx5IGluIGNhbWVsIGNhc2UuXG4gKiBAcGFyYW0gb2JqIFRoZSBvYmplY3QuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhjb25zdHJ1Y3Q6IElDb25zdHJ1Y3QsIG9iajogYW55KTogYW55IHtcbiAgY29uc3Qgc3RhY2sgPSBTdGFjay5vZihjb25zdHJ1Y3QpO1xuICBvYmogPSBzdGFjay5yZXNvbHZlKG9iaik7XG5cbiAgaWYgKHR5cGVvZihvYmopICE9PSAnb2JqZWN0Jykge1xuICAgIHJldHVybiBvYmo7XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShvYmopKSB7XG4gICAgcmV0dXJuIG9iai5tYXAoeCA9PiBjYXBpdGFsaXplUHJvcGVydHlOYW1lcyhjb25zdHJ1Y3QsIHgpKTtcbiAgfVxuXG4gIGNvbnN0IG5ld09iajogYW55ID0geyB9O1xuICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyhvYmopKSB7XG4gICAgY29uc3QgdmFsdWUgPSBvYmpba2V5XTtcblxuICAgIGNvbnN0IGZpcnN0ID0ga2V5LmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpO1xuICAgIGNvbnN0IG5ld0tleSA9IGZpcnN0ICsga2V5LnNsaWNlKDEpO1xuICAgIG5ld09ialtuZXdLZXldID0gY2FwaXRhbGl6ZVByb3BlcnR5TmFtZXMoY29uc3RydWN0LCB2YWx1ZSk7XG4gIH1cblxuICByZXR1cm4gbmV3T2JqO1xufVxuIl19 \ No newline at end of file diff --git a/packages/@aws-cdk/aws-batch-alpha/tsconfig.json b/packages/@aws-cdk/aws-batch-alpha/tsconfig.json deleted file mode 100644 index 00315950564fd..0000000000000 --- a/packages/@aws-cdk/aws-batch-alpha/tsconfig.json +++ /dev/null @@ -1,53 +0,0 @@ -{ - "compilerOptions": { - "declarationMap": false, - "inlineSourceMap": true, - "inlineSources": true, - "alwaysStrict": true, - "declaration": true, - "experimentalDecorators": true, - "incremental": true, - "lib": [ - "es2020" - ], - "module": "CommonJS", - "noEmitOnError": true, - "noFallthroughCasesInSwitch": true, - "noImplicitAny": true, - "noImplicitReturns": true, - "noImplicitThis": true, - "noUnusedLocals": true, - "noUnusedParameters": true, - "resolveJsonModule": true, - "skipLibCheck": true, - "strict": true, - "strictNullChecks": true, - "strictPropertyInitialization": true, - "stripInternal": false, - "target": "ES2020", - "composite": true, - "tsBuildInfoFile": "tsconfig.tsbuildinfo" - }, - "include": [ - "**/*.ts" - ], - "exclude": [ - "node_modules", - ".types-compat" - ], - "references": [ - { - "path": "../../../tools/@aws-cdk/cdk-build-tools" - }, - { - "path": "../integ-runner" - }, - { - "path": "../../../tools/@aws-cdk/pkglint" - }, - { - "path": "../integ-tests-alpha" - } - ], - "_generated_by_jsii_": "Generated by jsii - safe to delete, and ideally should be in .gitignore" -} \ No newline at end of file diff --git a/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts b/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts index 896a8105d2e3a..e97e45bf48689 100644 --- a/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts +++ b/packages/@aws-cdk/integ-runner/test/workers/integ-worker.test.ts @@ -222,7 +222,7 @@ describe('parallel worker', () => { const results = await runIntegrationTestsInParallel({ pool, tests, - regions: ['us-west-2'], + regions: ['us-east-1'], }); expect(stderrMock.mock.calls[0][0]).toContain( @@ -408,7 +408,7 @@ describe('parallel worker', () => { const results = await runIntegrationTestsInParallel({ tests, pool, - regions: ['us-west-2'], + regions: ['us-east-1'], }); expect(stderrMock.mock.calls[1][0]).toContain( From 7a950faa9c85a0c0bd2da94a881bbf0a79533119 Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 18:58:27 -0500 Subject: [PATCH 4/7] remove these too --- .../manifest.json | 237 ------------------ ...e782b91873a033a2af81afb07f38cf38ec67ea.zip | Bin 310 -> 0 bytes 2 files changed, 237 deletions(-) delete mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json delete mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json deleted file mode 100644 index 169010b153254..0000000000000 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json +++ /dev/null @@ -1,237 +0,0 @@ -{ - "version": "34.0.0", - "artifacts": { - "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets": { - "type": "cdk:asset-manifest", - "properties": { - "file": "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json", - "requiresBootstrapStackVersion": 6, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" - } - }, - "aws-cdk-codepipeline-elastic-beanstalk-deploy": { - "type": "aws:cloudformation:stack", - "environment": "aws://unknown-account/unknown-region", - "properties": { - "templateFile": "aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json", - "validateOnSynth": false, - "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", - "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", - "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", - "requiresBootstrapStackVersion": 6, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", - "additionalDependencies": [ - "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets" - ], - "lookupRole": { - "arn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-lookup-role-${AWS::AccountId}-${AWS::Region}", - "requiresBootstrapStackVersion": 8, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" - } - }, - "dependencies": [ - "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets" - ], - "metadata": { - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineBucketB967BD35" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/Policy/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineBucketPolicyD65CDEF5" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/AutoDeleteObjectsCustomResource/Default": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineBucketAutoDeleteObjectsCustomResource5F37E165" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::S3AutoDeleteObjectsCustomResourceProvider/Role": [ - { - "type": "aws:cdk:logicalId", - "data": "CustomS3AutoDeleteObjectsCustomResourceProviderRole3B1BD092" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::S3AutoDeleteObjectsCustomResourceProvider/Handler": [ - { - "type": "aws:cdk:logicalId", - "data": "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/DeployApp/AwsCliLayer/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "DeployAppAwsCliLayerAEF99B2F" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/DeployApp/CustomResource/Default": [ - { - "type": "aws:cdk:logicalId", - "data": "DeployAppCustomResourceDEE6DDD6" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/ServiceRole/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRole89A01265" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/ServiceRole/DefaultPolicy/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRoleDefaultPolicy88902FDF" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C81C01536" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/service-role/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "servicerole2C3CD20E" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/instance-profile-role/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "instanceprofilerole786BCBC7" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/instance-profile": [ - { - "type": "aws:cdk:logicalId", - "data": "instanceprofile" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/beastalk-app": [ - { - "type": "aws:cdk:logicalId", - "data": "beastalkapp" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/beanstlk-env": [ - { - "type": "aws:cdk:logicalId", - "data": "beanstlkenv" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Role/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineRoleD68726F7" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Role/DefaultPolicy/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineRoleDefaultPolicyC7A05455" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineC660917D" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Source/Source/CodePipelineActionRole/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineSourceCodePipelineActionRoleC6F9E7F5" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Source/Source/CodePipelineActionRole/DefaultPolicy/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineSourceCodePipelineActionRoleDefaultPolicy2D565925" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Deploy/Deploy/CodePipelineActionRole/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineDeployCodePipelineActionRole8B83082E" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Deploy/Deploy/CodePipelineActionRole/DefaultPolicy/Resource": [ - { - "type": "aws:cdk:logicalId", - "data": "PipelineDeployCodePipelineActionRoleDefaultPolicyEE6D615B" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/BootstrapVersion": [ - { - "type": "aws:cdk:logicalId", - "data": "BootstrapVersion" - } - ], - "/aws-cdk-codepipeline-elastic-beanstalk-deploy/CheckBootstrapVersion": [ - { - "type": "aws:cdk:logicalId", - "data": "CheckBootstrapVersion" - } - ] - }, - "displayName": "aws-cdk-codepipeline-elastic-beanstalk-deploy" - }, - "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets": { - "type": "cdk:asset-manifest", - "properties": { - "file": "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets.json", - "requiresBootstrapStackVersion": 6, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" - } - }, - "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B": { - "type": "aws:cloudformation:stack", - "environment": "aws://unknown-account/unknown-region", - "properties": { - "templateFile": "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.template.json", - "validateOnSynth": false, - "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", - "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", - "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/21fbb51d7b23f6a6c262b46a9caee79d744a3ac019fd45422d988b96d44b2a22.json", - "requiresBootstrapStackVersion": 6, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", - "additionalDependencies": [ - "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets" - ], - "lookupRole": { - "arn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-lookup-role-${AWS::AccountId}-${AWS::Region}", - "requiresBootstrapStackVersion": 8, - "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" - } - }, - "dependencies": [ - "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets" - ], - "metadata": { - "/codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert/BootstrapVersion": [ - { - "type": "aws:cdk:logicalId", - "data": "BootstrapVersion" - } - ], - "/codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert/CheckBootstrapVersion": [ - { - "type": "aws:cdk:logicalId", - "data": "CheckBootstrapVersion" - } - ] - }, - "displayName": "codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert" - }, - "Tree": { - "type": "cdk:tree", - "properties": { - "file": "tree.json" - } - } - } -} \ No newline at end of file diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip b/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/d1ba2cb2e5cfca13267ff70863e782b91873a033a2af81afb07f38cf38ec67ea.zip deleted file mode 100644 index 3cf3517aadf3c86fe0b7520aa3a9693e6b601fcd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 310 zcmWIWW@Zs#-~d7f21Ou700$t`)Xc=xz|_FN(AXl?Fv-Niz%nH%$uu$1GAY^AFgZEJ zFx4O_*}%ZWB-t#{#MC&+#2_WjJk>PO(A>zx#N5O{ThCWZ@1%~V?#VOfx%E7OjBP<0 zZbFxJ^?d#OboKnS&jvm@<$1=}%d Date: Tue, 12 Sep 2023 19:01:17 -0500 Subject: [PATCH 5/7] remove --- ...1497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip | Bin 4540 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip b/packages/@aws-cdk-testing/framework-integ/test/aws-s3-deployment/test/integ.bucket-deployment-substitution.js.snapshot/.cache/9eb41a5505d37607ac419321497a4f8c21cf0ee1f9b4a6b29aa04301aea5c7fd.zip deleted file mode 100644 index cb2790cf47f87701182d2d185a3bef4ec4634d2b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4540 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 ac~DCQ1^@s60096205$*s0B{ii00014ZoSF? From 15459f9b8a07798c4544817405a1fa66e7f8bd3d Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 19:14:37 -0500 Subject: [PATCH 6/7] update snaps --- .../manifest.json | 237 ++++++++++++++++++ 1 file changed, 237 insertions(+) create mode 100644 packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json new file mode 100644 index 0000000000000..169010b153254 --- /dev/null +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json @@ -0,0 +1,237 @@ +{ + "version": "34.0.0", + "artifacts": { + "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets": { + "type": "cdk:asset-manifest", + "properties": { + "file": "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json", + "requiresBootstrapStackVersion": 6, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" + } + }, + "aws-cdk-codepipeline-elastic-beanstalk-deploy": { + "type": "aws:cloudformation:stack", + "environment": "aws://unknown-account/unknown-region", + "properties": { + "templateFile": "aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json", + "validateOnSynth": false, + "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", + "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", + "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", + "requiresBootstrapStackVersion": 6, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", + "additionalDependencies": [ + "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets" + ], + "lookupRole": { + "arn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-lookup-role-${AWS::AccountId}-${AWS::Region}", + "requiresBootstrapStackVersion": 8, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" + } + }, + "dependencies": [ + "aws-cdk-codepipeline-elastic-beanstalk-deploy.assets" + ], + "metadata": { + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineBucketB967BD35" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/Policy/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineBucketPolicyD65CDEF5" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/PipelineBucket/AutoDeleteObjectsCustomResource/Default": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineBucketAutoDeleteObjectsCustomResource5F37E165" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::S3AutoDeleteObjectsCustomResourceProvider/Role": [ + { + "type": "aws:cdk:logicalId", + "data": "CustomS3AutoDeleteObjectsCustomResourceProviderRole3B1BD092" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::S3AutoDeleteObjectsCustomResourceProvider/Handler": [ + { + "type": "aws:cdk:logicalId", + "data": "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/DeployApp/AwsCliLayer/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "DeployAppAwsCliLayerAEF99B2F" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/DeployApp/CustomResource/Default": [ + { + "type": "aws:cdk:logicalId", + "data": "DeployAppCustomResourceDEE6DDD6" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/ServiceRole/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRole89A01265" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/ServiceRole/DefaultPolicy/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRoleDefaultPolicy88902FDF" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Custom::CDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756C81C01536" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/service-role/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "servicerole2C3CD20E" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/instance-profile-role/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "instanceprofilerole786BCBC7" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/instance-profile": [ + { + "type": "aws:cdk:logicalId", + "data": "instanceprofile" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/beastalk-app": [ + { + "type": "aws:cdk:logicalId", + "data": "beastalkapp" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/beanstlk-env": [ + { + "type": "aws:cdk:logicalId", + "data": "beanstlkenv" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Role/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineRoleD68726F7" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Role/DefaultPolicy/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineRoleDefaultPolicyC7A05455" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineC660917D" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Source/Source/CodePipelineActionRole/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineSourceCodePipelineActionRoleC6F9E7F5" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Source/Source/CodePipelineActionRole/DefaultPolicy/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineSourceCodePipelineActionRoleDefaultPolicy2D565925" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Deploy/Deploy/CodePipelineActionRole/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineDeployCodePipelineActionRole8B83082E" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/Pipeline/Deploy/Deploy/CodePipelineActionRole/DefaultPolicy/Resource": [ + { + "type": "aws:cdk:logicalId", + "data": "PipelineDeployCodePipelineActionRoleDefaultPolicyEE6D615B" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/BootstrapVersion": [ + { + "type": "aws:cdk:logicalId", + "data": "BootstrapVersion" + } + ], + "/aws-cdk-codepipeline-elastic-beanstalk-deploy/CheckBootstrapVersion": [ + { + "type": "aws:cdk:logicalId", + "data": "CheckBootstrapVersion" + } + ] + }, + "displayName": "aws-cdk-codepipeline-elastic-beanstalk-deploy" + }, + "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets": { + "type": "cdk:asset-manifest", + "properties": { + "file": "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets.json", + "requiresBootstrapStackVersion": 6, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" + } + }, + "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B": { + "type": "aws:cloudformation:stack", + "environment": "aws://unknown-account/unknown-region", + "properties": { + "templateFile": "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.template.json", + "validateOnSynth": false, + "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", + "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", + "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/21fbb51d7b23f6a6c262b46a9caee79d744a3ac019fd45422d988b96d44b2a22.json", + "requiresBootstrapStackVersion": 6, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", + "additionalDependencies": [ + "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets" + ], + "lookupRole": { + "arn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-lookup-role-${AWS::AccountId}-${AWS::Region}", + "requiresBootstrapStackVersion": 8, + "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" + } + }, + "dependencies": [ + "codepipelineelasticbeanstalkdeployDefaultTestDeployAssert785E452B.assets" + ], + "metadata": { + "/codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert/BootstrapVersion": [ + { + "type": "aws:cdk:logicalId", + "data": "BootstrapVersion" + } + ], + "/codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert/CheckBootstrapVersion": [ + { + "type": "aws:cdk:logicalId", + "data": "CheckBootstrapVersion" + } + ] + }, + "displayName": "codepipeline-elastic-beanstalk-deploy/DefaultTest/DeployAssert" + }, + "Tree": { + "type": "cdk:tree", + "properties": { + "file": "tree.json" + } + } + } +} \ No newline at end of file From ea7f63712c9057e05f671ff98b649c9a23e9a55d Mon Sep 17 00:00:00 2001 From: Michael Sambol Date: Tue, 12 Sep 2023 19:28:52 -0500 Subject: [PATCH 7/7] but actually --- .../aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json | 4 ++-- ...ws-cdk-codepipeline-elastic-beanstalk-deploy.template.json | 4 ++-- .../manifest.json | 2 +- .../tree.json | 4 ++-- .../test/integ.pipeline-elastic-beanstalk-deploy.ts | 2 +- 5 files changed, 8 insertions(+), 8 deletions(-) diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json index 0d246ebffb760..8a5031d35779d 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.assets.json @@ -53,7 +53,7 @@ } } }, - "c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55": { + "4de4e5d8bb87dcc2a1eea96c71bef35d6dcf4a63d8767f64f0d53f9362cbbef2": { "source": { "path": "aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json", "packaging": "file" @@ -61,7 +61,7 @@ "destinations": { "current_account-current_region": { "bucketName": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}", - "objectKey": "c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", + "objectKey": "4de4e5d8bb87dcc2a1eea96c71bef35d6dcf4a63d8767f64f0d53f9362cbbef2.json", "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}" } } diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json index 3fabf1dc5a284..2debab0dd131e 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/aws-cdk-codepipeline-elastic-beanstalk-deploy.template.json @@ -579,7 +579,7 @@ "Name": "Source", "OutputArtifacts": [ { - "Name": "SourceArtifact" + "Name": "SourceArtifact-issue-27117" } ], "RoleArn": { @@ -608,7 +608,7 @@ }, "InputArtifacts": [ { - "Name": "SourceArtifact" + "Name": "SourceArtifact-issue-27117" } ], "Name": "Deploy", diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json index 169010b153254..86ae22a0097ab 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/manifest.json @@ -17,7 +17,7 @@ "validateOnSynth": false, "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", - "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/c1011949c96fc4192d3b0537c512ef1797916ab8aaa1ce027020b92033705b55.json", + "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/4de4e5d8bb87dcc2a1eea96c71bef35d6dcf4a63d8767f64f0d53f9362cbbef2.json", "requiresBootstrapStackVersion": 6, "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", "additionalDependencies": [ diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/tree.json b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/tree.json index f862bf0af9093..2ebd0efab5f8f 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/tree.json +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.js.snapshot/tree.json @@ -862,7 +862,7 @@ "name": "Source", "outputArtifacts": [ { - "name": "SourceArtifact" + "name": "SourceArtifact-issue-27117" } ], "actionTypeId": { @@ -904,7 +904,7 @@ "name": "Deploy", "inputArtifacts": [ { - "name": "SourceArtifact" + "name": "SourceArtifact-issue-27117" } ], "actionTypeId": { diff --git a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.ts b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.ts index 30760ddbbb7c4..7d592b76c0712 100644 --- a/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.ts +++ b/packages/@aws-cdk-testing/framework-integ/test/aws-codepipeline-actions/test/integ.pipeline-elastic-beanstalk-deploy.ts @@ -111,7 +111,7 @@ const pipeline = new codepipeline.Pipeline(stack, 'Pipeline', { artifactBucket: bucket, }); -const sourceOutput = new codepipeline.Artifact('SourceArtifact'); +const sourceOutput = new codepipeline.Artifact('SourceArtifact-issue-27117'); const sourceAction = new cpactions.S3SourceAction({ actionName: 'Source', output: sourceOutput,