From 6504e92d894eb2aac98a18fbd17a5fc3abf6de17 Mon Sep 17 00:00:00 2001 From: Ulad Kasach Date: Sun, 29 Oct 2023 18:46:54 -0400 Subject: [PATCH] fix(sls): automatically fix missing prune plugin --- .../serverless/best-practice/serverless.yml.declapract.ts | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/practices/serverless/best-practice/serverless.yml.declapract.ts b/src/practices/serverless/best-practice/serverless.yml.declapract.ts index 0fe74a7..768242a 100644 --- a/src/practices/serverless/best-practice/serverless.yml.declapract.ts +++ b/src/practices/serverless/best-practice/serverless.yml.declapract.ts @@ -9,7 +9,6 @@ export const fix: FileFixFunction = (contents) => { // TODO: when we have special support for yml, do this better (i.e., instead of string replace, just add to the yml object after parsing it) contents: contents .replace(/runtime\: nodejs\d\d.x/, 'runtime: nodejs16.x') - .replace('\nplugins:\n', '') .replace(/ - serverless-offline .*\n/, '') // a plugin we no longer use (never used it, no need to have it) .replace(/ - serverless-pseudo-parameters .*\n/, '') // a plugin we no longer use (serverless supports variables natively now) .replace(/\#\{AWS\:\:Region\}/g, '${aws:region}') // use the serverless native variables, instead of the pseudo-parameters format @@ -26,6 +25,10 @@ export const fix: FileFixFunction = (contents) => { .replace( /service: ([a-zA-Z0-9\-]+)\n\n?provider:/, 'service: $1\n\npackage:\n artifact: .artifact/contents.zip\n\nprovider:', + ) + .replace( + ' artifact: .artifact/contents.zip\n\nprovider:', // if no plugins at all + ' artifact: .artifact/contents.zip\n\nplugins:\n\n - serverless-prune-plugin\n\nprovider:', // add the sls prune plugin ), }; };