projalf 0.0.19 → 0.0.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/Projalf.js CHANGED
@@ -52,6 +52,17 @@ class Projalf extends projen_1.awscdk.AwsCdkTypeScriptApp {
52
52
  ...options.prettierOptions?.settings,
53
53
  },
54
54
  },
55
+ jestOptions: {
56
+ configFilePath: "jest.config.json",
57
+ jestConfig: {
58
+ testMatch: ["<rootDir>/(test/unit|src)/**/*(*.)@(spec|test).ts?(x)"],
59
+ transform: {
60
+ "^.+\\.tsx?$": new projen_1.javascript.Transform("ts-jest", {
61
+ tsconfig: "tsconfig.dev.json",
62
+ }),
63
+ },
64
+ },
65
+ },
55
66
  });
56
67
  new files_1.Files(this, className, fileBase, inferredName);
57
68
  // Enforce ESLint style: double quotes and no semicolons
@@ -129,4 +140,4 @@ function toPascalCase(input) {
129
140
  .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
130
141
  .join("");
131
142
  }
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Projalf.js","sourceRoot":"","sources":["../src/Projalf.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cp from \"child_process\"\nimport * as path from \"path\"\nimport { awscdk, javascript, SampleFile } from \"projen\"\nimport { Files } from \"./files\"\nimport { workflow } from \"./workflows\"\n\nconst defaultJestConfig: javascript.JestConfigOptions = {\n  preset: \"ts-jest\",\n  transform: {\n    \"^.+\\\\.tsx?$\": new javascript.Transform(\"ts-jest\", {\n      tsconfig: \"tsconfig.dev.json\",\n    }),\n  },\n  setupFilesAfterEnv: [\"<rootDir>/test/setup.ts\"],\n}\n\nexport interface ProjalfOptions extends awscdk.AwsCdkTypeScriptAppOptions {}\n\nexport class Projalf extends awscdk.AwsCdkTypeScriptApp {\n  constructor(options: ProjalfOptions) {\n    const inferredName =\n      options.name ?? inferNameFromGit() ?? inferNameFromCwd()\n    const className = toPascalCase(inferredName)\n    const fileBase = inferredName.toLowerCase()\n\n    const mergedContext = { ...(options.context ?? {}) } as Record<string, any>\n    if (mergedContext.serviceName === undefined) {\n      mergedContext.serviceName = inferredName\n    }\n\n    super({\n      ...options,\n      name: inferredName,\n      defaultReleaseBranch: options.defaultReleaseBranch ?? \"main\",\n      packageManager:\n        options.packageManager ?? javascript.NodePackageManager.NPM,\n      projenrcTs: options.projenrcTs ?? true,\n      cdkVersion: options.cdkVersion ?? \"2.156.0\",\n      context: mergedContext,\n      deps: options.deps ?? [],\n      devDeps: options.devDeps ?? [],\n      buildWorkflow: false,\n      release: false,\n      depsUpgrade: false,\n      githubOptions: {\n        pullRequestLint: false,\n      },\n      watchIncludes: [\"src/**/*.ts\", \"src/**/*.tsx\"],\n\n      prettierOptions: {\n        ...options.prettierOptions,\n        settings: {\n          semi: false,\n          printWidth: 100,\n          singleQuote: false,\n          ...options.prettierOptions?.settings,\n        },\n      },\n    })\n\n    new Files(this, className, fileBase, inferredName)\n\n    // Enforce ESLint style: double quotes and no semicolons\n    this.eslint?.addRules({\n      \"@stylistic/quotes\": [\"error\", \"double\", { avoidEscape: true }],\n      \"@stylistic/semi\": [\"error\", \"never\"],\n      \"@stylistic/consistent-quotes\": [\"off\"],\n      \"@stylistic/member-delimiter-style\": [\"off\"],\n      \"@stylistic/comma-dangle\": [\"error\", \"always-multiline\"],\n    })\n\n    workflow(this)\n\n    this.addTask(\"deploy:watch\", {\n      exec: \"cdk deploy --all --method=direct --outputs-file=test.output.json --watch --hotswap-fallback --require-approval=never\",\n      receiveArgs: true,\n    })\n    this.addTask(\"test:e2e\", {\n      exec: \"jest --config jest.e2e.config.json --runInBand --passWithNoTests\",\n    })\n\n    new javascript.Jest(this, {\n      configFilePath: \"jest.integ.config.json\",\n      jestConfig: {\n        collectCoverage: false,\n        testMatch: [\n          \"<rootDir>/test/integ/**/*(*.)@(spec|test).ts?(x)\",\n          \"<rootDir>/(test|src)/**/*(*.)@(integ).ts?(x)\",\n        ],\n        ...defaultJestConfig,\n      },\n    })\n\n    new javascript.Jest(this, {\n      configFilePath: \"jest.e2e.config.json\",\n      jestConfig: {\n        collectCoverage: false,\n        testMatch: [\n          \"<rootDir>/test/e2e/**/*(*.)@(spec|test).ts?(x)\",\n          \"<rootDir>/(test|src)/**/*(*.)@(e2e).ts?(x)\",\n        ],\n        ...defaultJestConfig,\n      },\n    })\n\n    new SampleFile(this, \"test/setup.ts\", {\n      contents: `jest.setTimeout(10000)\n`,\n    })\n  }\n}\n\nfunction inferNameFromGit(): string | undefined {\n  try {\n    const remote = cp\n      .execSync(\"git config --get remote.origin.url\", {\n        stdio: [\"ignore\", \"pipe\", \"ignore\"],\n      })\n      .toString()\n      .trim()\n    if (!remote) return undefined\n    const match = remote.match(/\\/([^\\/]+?)(?:\\.git)?$/)\n    return match?.[1]\n  } catch {\n    return undefined\n  }\n}\n\nfunction inferNameFromCwd(): string {\n  return path.basename(process.cwd())\n}\n\nfunction toPascalCase(input: string): string {\n  return input\n    .replace(/[^a-zA-Z0-9]+/g, \" \")\n    .split(\" \")\n    .filter(Boolean)\n    .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())\n    .join(\"\")\n}\n"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Projalf.js","sourceRoot":"","sources":["../src/Projalf.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cp from \"child_process\"\nimport * as path from \"path\"\nimport { awscdk, javascript, SampleFile } from \"projen\"\nimport { Files } from \"./files\"\nimport { workflow } from \"./workflows\"\n\nconst defaultJestConfig: javascript.JestConfigOptions = {\n  preset: \"ts-jest\",\n  transform: {\n    \"^.+\\\\.tsx?$\": new javascript.Transform(\"ts-jest\", {\n      tsconfig: \"tsconfig.dev.json\",\n    }),\n  },\n  setupFilesAfterEnv: [\"<rootDir>/test/setup.ts\"],\n}\n\nexport interface ProjalfOptions extends awscdk.AwsCdkTypeScriptAppOptions {}\n\nexport class Projalf extends awscdk.AwsCdkTypeScriptApp {\n  constructor(options: ProjalfOptions) {\n    const inferredName =\n      options.name ?? inferNameFromGit() ?? inferNameFromCwd()\n    const className = toPascalCase(inferredName)\n    const fileBase = inferredName.toLowerCase()\n\n    const mergedContext = { ...(options.context ?? {}) } as Record<string, any>\n    if (mergedContext.serviceName === undefined) {\n      mergedContext.serviceName = inferredName\n    }\n\n    super({\n      ...options,\n      name: inferredName,\n      defaultReleaseBranch: options.defaultReleaseBranch ?? \"main\",\n      packageManager:\n        options.packageManager ?? javascript.NodePackageManager.NPM,\n      projenrcTs: options.projenrcTs ?? true,\n      cdkVersion: options.cdkVersion ?? \"2.156.0\",\n      context: mergedContext,\n      deps: options.deps ?? [],\n      devDeps: options.devDeps ?? [],\n      buildWorkflow: false,\n      release: false,\n      depsUpgrade: false,\n      githubOptions: {\n        pullRequestLint: false,\n      },\n      watchIncludes: [\"src/**/*.ts\", \"src/**/*.tsx\"],\n\n      prettierOptions: {\n        ...options.prettierOptions,\n        settings: {\n          semi: false,\n          printWidth: 100,\n          singleQuote: false,\n          ...options.prettierOptions?.settings,\n        },\n      },\n\n      jestOptions: {\n        configFilePath: \"jest.config.json\",\n        jestConfig: {\n          testMatch: [\"<rootDir>/(test/unit|src)/**/*(*.)@(spec|test).ts?(x)\"],\n          transform: {\n            \"^.+\\\\.tsx?$\": new javascript.Transform(\"ts-jest\", {\n              tsconfig: \"tsconfig.dev.json\",\n            }),\n          },\n        },\n      },\n    })\n\n    new Files(this, className, fileBase, inferredName)\n\n    // Enforce ESLint style: double quotes and no semicolons\n    this.eslint?.addRules({\n      \"@stylistic/quotes\": [\"error\", \"double\", { avoidEscape: true }],\n      \"@stylistic/semi\": [\"error\", \"never\"],\n      \"@stylistic/consistent-quotes\": [\"off\"],\n      \"@stylistic/member-delimiter-style\": [\"off\"],\n      \"@stylistic/comma-dangle\": [\"error\", \"always-multiline\"],\n    })\n\n    workflow(this)\n\n    this.addTask(\"deploy:watch\", {\n      exec: \"cdk deploy --all --method=direct --outputs-file=test.output.json --watch --hotswap-fallback --require-approval=never\",\n      receiveArgs: true,\n    })\n    this.addTask(\"test:e2e\", {\n      exec: \"jest --config jest.e2e.config.json --runInBand --passWithNoTests\",\n    })\n\n    new javascript.Jest(this, {\n      configFilePath: \"jest.integ.config.json\",\n      jestConfig: {\n        collectCoverage: false,\n        testMatch: [\n          \"<rootDir>/test/integ/**/*(*.)@(spec|test).ts?(x)\",\n          \"<rootDir>/(test|src)/**/*(*.)@(integ).ts?(x)\",\n        ],\n        ...defaultJestConfig,\n      },\n    })\n\n    new javascript.Jest(this, {\n      configFilePath: \"jest.e2e.config.json\",\n      jestConfig: {\n        collectCoverage: false,\n        testMatch: [\n          \"<rootDir>/test/e2e/**/*(*.)@(spec|test).ts?(x)\",\n          \"<rootDir>/(test|src)/**/*(*.)@(e2e).ts?(x)\",\n        ],\n        ...defaultJestConfig,\n      },\n    })\n\n    new SampleFile(this, \"test/setup.ts\", {\n      contents: `jest.setTimeout(10000)\n`,\n    })\n  }\n}\n\nfunction inferNameFromGit(): string | undefined {\n  try {\n    const remote = cp\n      .execSync(\"git config --get remote.origin.url\", {\n        stdio: [\"ignore\", \"pipe\", \"ignore\"],\n      })\n      .toString()\n      .trim()\n    if (!remote) return undefined\n    const match = remote.match(/\\/([^\\/]+?)(?:\\.git)?$/)\n    return match?.[1]\n  } catch {\n    return undefined\n  }\n}\n\nfunction inferNameFromCwd(): string {\n  return path.basename(process.cwd())\n}\n\nfunction toPascalCase(input: string): string {\n  return input\n    .replace(/[^a-zA-Z0-9]+/g, \" \")\n    .split(\" \")\n    .filter(Boolean)\n    .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())\n    .join(\"\")\n}\n"]}
package/lib/workflows.js CHANGED
@@ -3,12 +3,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.workflow = workflow;
4
4
  const workflows_model_1 = require("projen/lib/github/workflows-model");
5
5
  function workflow(project) {
6
+ const testWorkflow = project.github.addWorkflow("test");
6
7
  const deployWorkflow = project.github.addWorkflow("deploy");
7
- // Trigger on PR and push to main
8
- deployWorkflow.on({
8
+ // Test workflow - triggers on PR and push to main
9
+ testWorkflow.on({
9
10
  pullRequest: {},
10
11
  push: { branches: ["main"] },
11
12
  });
13
+ // Deploy workflow - triggers after test workflow completes successfully
14
+ deployWorkflow.on({
15
+ workflowRun: {
16
+ workflows: ["test"],
17
+ types: ["completed"],
18
+ branches: ["main"],
19
+ },
20
+ });
12
21
  // Reusable job template
13
22
  const jobDefaults = {
14
23
  runsOn: ["ubuntu-latest"],
@@ -35,11 +44,49 @@ function workflow(project) {
35
44
  },
36
45
  ],
37
46
  };
47
+ // Test job: deploy test stack, run e2e tests, destroy stack
48
+ testWorkflow.addJobs({
49
+ test: {
50
+ ...jobDefaults,
51
+ steps: [
52
+ ...jobDefaults.steps,
53
+ {
54
+ name: "Generate random stage ID",
55
+ id: "stage",
56
+ run: 'echo "STAGE_ID=test-$(shuf -i 10000-99999 -n 1)" >> $GITHUB_OUTPUT',
57
+ },
58
+ {
59
+ name: "Deploy Test Stack",
60
+ run: "npm run deploy -- -c stage=${{ steps.stage.outputs.STAGE_ID }} --require-approval never",
61
+ env: {
62
+ CDK_DEPLOY_ACCOUNT: "${{ secrets.AWS_TEST_ACCOUNT }}",
63
+ CDK_DEPLOY_REGION: "${{ secrets.AWS_REGION || 'eu-central-1' }}",
64
+ },
65
+ },
66
+ {
67
+ name: "Run E2E Tests",
68
+ run: "npm run test:e2e",
69
+ env: {
70
+ STAGE: "${{ steps.stage.outputs.STAGE_ID }}",
71
+ },
72
+ },
73
+ {
74
+ name: "Destroy Test Stack",
75
+ if: "always()",
76
+ run: "npm run destroy -- -c stage=${{ steps.stage.outputs.STAGE_ID }} --force",
77
+ env: {
78
+ CDK_DEPLOY_ACCOUNT: "${{ secrets.AWS_TEST_ACCOUNT }}",
79
+ CDK_DEPLOY_REGION: "${{ secrets.AWS_REGION || 'eu-central-1' }}",
80
+ },
81
+ },
82
+ ],
83
+ },
84
+ });
38
85
  // Job: deploy dev on PR
39
86
  deployWorkflow.addJobs({
40
87
  deploy_dev: {
41
88
  ...jobDefaults,
42
- if: "github.event_name == 'pull_request'",
89
+ if: "github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'",
43
90
  steps: [
44
91
  ...jobDefaults.steps,
45
92
  {
@@ -54,7 +101,7 @@ function workflow(project) {
54
101
  },
55
102
  deploy_prod: {
56
103
  ...jobDefaults,
57
- if: "github.ref == 'refs/heads/main' && github.event_name == 'push'",
104
+ if: "github.event.workflow_run.head_branch == 'main' && github.event.workflow_run.event == 'push' && github.event.workflow_run.conclusion == 'success'",
58
105
  steps: [
59
106
  ...jobDefaults.steps,
60
107
  {
@@ -69,4 +116,4 @@ function workflow(project) {
69
116
  },
70
117
  });
71
118
  }
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3dzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3dvcmtmbG93cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUdBLDRCQXFFQztBQXhFRCx1RUFBaUU7QUFHakUsU0FBZ0IsUUFBUSxDQUFDLE9BQWdCO0lBQ3ZDLE1BQU0sY0FBYyxHQUFHLE9BQU8sQ0FBQyxNQUFPLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFBO0lBRTVELGlDQUFpQztJQUNqQyxjQUFjLENBQUMsRUFBRSxDQUFDO1FBQ2hCLFdBQVcsRUFBRSxFQUFFO1FBQ2YsSUFBSSxFQUFFLEVBQUUsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUU7S0FDN0IsQ0FBQyxDQUFBO0lBRUYsd0JBQXdCO0lBQ3hCLE1BQU0sV0FBVyxHQUFHO1FBQ2xCLE1BQU0sRUFBRSxDQUFDLGVBQWUsQ0FBQztRQUN6QixXQUFXLEVBQUU7WUFDWCxRQUFRLEVBQUUsK0JBQWEsQ0FBQyxLQUFLO1lBQzdCLE9BQU8sRUFBRSwrQkFBYSxDQUFDLEtBQUs7U0FDN0I7UUFDRCxLQUFLLEVBQUU7WUFDTCxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLHFCQUFxQixFQUFFO1lBQ2pEO2dCQUNFLElBQUksRUFBRSxlQUFlO2dCQUNyQixJQUFJLEVBQUUsdUJBQXVCO2dCQUM3QixJQUFJLEVBQUUsRUFBRSxjQUFjLEVBQUUsSUFBSSxFQUFFO2FBQy9CO1lBQ0QsRUFBRSxJQUFJLEVBQUUsc0JBQXNCLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRTtZQUMvQztnQkFDRSxJQUFJLEVBQUUsMkJBQTJCO2dCQUNqQyxJQUFJLEVBQUUsMENBQTBDO2dCQUNoRCxJQUFJLEVBQUU7b0JBQ0osbUJBQW1CLEVBQUUsa0NBQWtDO29CQUN2RCx1QkFBdUIsRUFBRSxzQ0FBc0M7b0JBQy9ELFlBQVksRUFBRSw2Q0FBNkM7aUJBQzVEO2FBQ0Y7U0FDRjtLQUNGLENBQUE7SUFFRCx3QkFBd0I7SUFDeEIsY0FBYyxDQUFDLE9BQU8sQ0FBQztRQUNyQixVQUFVLEVBQUU7WUFDVixHQUFHLFdBQVc7WUFDZCxFQUFFLEVBQUUscUNBQXFDO1lBQ3pDLEtBQUssRUFBRTtnQkFDTCxHQUFHLFdBQVcsQ0FBQyxLQUFLO2dCQUNwQjtvQkFDRSxJQUFJLEVBQUUsWUFBWTtvQkFDbEIsR0FBRyxFQUFFLHlEQUF5RDtvQkFDOUQsR0FBRyxFQUFFO3dCQUNILGtCQUFrQixFQUFFLGdDQUFnQzt3QkFDcEQsaUJBQWlCLEVBQUUsNkNBQTZDO3FCQUNqRTtpQkFDRjthQUNGO1NBQ0Y7UUFDRCxXQUFXLEVBQUU7WUFDWCxHQUFHLFdBQVc7WUFDZCxFQUFFLEVBQUUsZ0VBQWdFO1lBQ3BFLEtBQUssRUFBRTtnQkFDTCxHQUFHLFdBQVcsQ0FBQyxLQUFLO2dCQUNwQjtvQkFDRSxJQUFJLEVBQUUsYUFBYTtvQkFDbkIsR0FBRyxFQUFFLDBEQUEwRDtvQkFDL0QsR0FBRyxFQUFFO3dCQUNILGtCQUFrQixFQUFFLGlDQUFpQzt3QkFDckQsaUJBQWlCLEVBQUUsNkNBQTZDO3FCQUNqRTtpQkFDRjthQUNGO1NBQ0Y7S0FDRixDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSm9iUGVybWlzc2lvbiB9IGZyb20gXCJwcm9qZW4vbGliL2dpdGh1Yi93b3JrZmxvd3MtbW9kZWxcIlxuaW1wb3J0IHsgUHJvamFsZiB9IGZyb20gXCIuL1Byb2phbGZcIlxuXG5leHBvcnQgZnVuY3Rpb24gd29ya2Zsb3cocHJvamVjdDogUHJvamFsZikge1xuICBjb25zdCBkZXBsb3lXb3JrZmxvdyA9IHByb2plY3QuZ2l0aHViIS5hZGRXb3JrZmxvdyhcImRlcGxveVwiKVxuXG4gIC8vIFRyaWdnZXIgb24gUFIgYW5kIHB1c2ggdG8gbWFpblxuICBkZXBsb3lXb3JrZmxvdy5vbih7XG4gICAgcHVsbFJlcXVlc3Q6IHt9LFxuICAgIHB1c2g6IHsgYnJhbmNoZXM6IFtcIm1haW5cIl0gfSxcbiAgfSlcblxuICAvLyBSZXVzYWJsZSBqb2IgdGVtcGxhdGVcbiAgY29uc3Qgam9iRGVmYXVsdHMgPSB7XG4gICAgcnVuc09uOiBbXCJ1YnVudHUtbGF0ZXN0XCJdLFxuICAgIHBlcm1pc3Npb25zOiB7XG4gICAgICBjb250ZW50czogSm9iUGVybWlzc2lvbi5XUklURSxcbiAgICAgIGlkVG9rZW46IEpvYlBlcm1pc3Npb24uV1JJVEUsXG4gICAgfSxcbiAgICBzdGVwczogW1xuICAgICAgeyBuYW1lOiBcIkNoZWNrb3V0XCIsIHVzZXM6IFwiYWN0aW9ucy9jaGVja291dEB2NFwiIH0sXG4gICAgICB7XG4gICAgICAgIG5hbWU6IFwiU2V0dXAgTm9kZS5qc1wiLFxuICAgICAgICB1c2VzOiBcImFjdGlvbnMvc2V0dXAtbm9kZUB2NFwiLFxuICAgICAgICB3aXRoOiB7IFwibm9kZS12ZXJzaW9uXCI6IFwiMjBcIiB9LFxuICAgICAgfSxcbiAgICAgIHsgbmFtZTogXCJJbnN0YWxsIGRlcGVuZGVuY2llc1wiLCBydW46IFwibnBtIGNpXCIgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogXCJDb25maWd1cmUgQVdTIGNyZWRlbnRpYWxzXCIsXG4gICAgICAgIHVzZXM6IFwiYXdzLWFjdGlvbnMvY29uZmlndXJlLWF3cy1jcmVkZW50aWFsc0B2NFwiLFxuICAgICAgICB3aXRoOiB7XG4gICAgICAgICAgXCJhd3MtYWNjZXNzLWtleS1pZFwiOiBcIiR7eyBzZWNyZXRzLkFXU19BQ0NFU1NfS0VZX0lEIH19XCIsXG4gICAgICAgICAgXCJhd3Mtc2VjcmV0LWFjY2Vzcy1rZXlcIjogXCIke3sgc2VjcmV0cy5BV1NfU0VDUkVUX0FDQ0VTU19LRVkgfX1cIixcbiAgICAgICAgICBcImF3cy1yZWdpb25cIjogXCIke3sgc2VjcmV0cy5BV1NfUkVHSU9OIHx8ICdldS1jZW50cmFsLTEnIH19XCIsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIF0sXG4gIH1cblxuICAvLyBKb2I6IGRlcGxveSBkZXYgb24gUFJcbiAgZGVwbG95V29ya2Zsb3cuYWRkSm9icyh7XG4gICAgZGVwbG95X2Rldjoge1xuICAgICAgLi4uam9iRGVmYXVsdHMsXG4gICAgICBpZjogXCJnaXRodWIuZXZlbnRfbmFtZSA9PSAncHVsbF9yZXF1ZXN0J1wiLFxuICAgICAgc3RlcHM6IFtcbiAgICAgICAgLi4uam9iRGVmYXVsdHMuc3RlcHMsXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lOiBcIkRlcGxveSBEZXZcIixcbiAgICAgICAgICBydW46IFwibnBtIHJ1biBkZXBsb3kgLS0gLWMgc3RhZ2U9ZGV2IC0tcmVxdWlyZS1hcHByb3ZhbCBuZXZlclwiLFxuICAgICAgICAgIGVudjoge1xuICAgICAgICAgICAgQ0RLX0RFUExPWV9BQ0NPVU5UOiBcIiR7eyBzZWNyZXRzLkFXU19ERVZfQUNDT1VOVCB9fVwiLFxuICAgICAgICAgICAgQ0RLX0RFUExPWV9SRUdJT046IFwiJHt7IHNlY3JldHMuQVdTX1JFR0lPTiB8fCAnZXUtY2VudHJhbC0xJyB9fVwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0sXG4gICAgZGVwbG95X3Byb2Q6IHtcbiAgICAgIC4uLmpvYkRlZmF1bHRzLFxuICAgICAgaWY6IFwiZ2l0aHViLnJlZiA9PSAncmVmcy9oZWFkcy9tYWluJyAmJiBnaXRodWIuZXZlbnRfbmFtZSA9PSAncHVzaCdcIixcbiAgICAgIHN0ZXBzOiBbXG4gICAgICAgIC4uLmpvYkRlZmF1bHRzLnN0ZXBzLFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZTogXCJEZXBsb3kgUHJvZFwiLFxuICAgICAgICAgIHJ1bjogXCJucG0gcnVuIGRlcGxveSAtLSAtYyBzdGFnZT1wcm9kIC0tcmVxdWlyZS1hcHByb3ZhbCBuZXZlclwiLFxuICAgICAgICAgIGVudjoge1xuICAgICAgICAgICAgQ0RLX0RFUExPWV9BQ0NPVU5UOiBcIiR7eyBzZWNyZXRzLkFXU19QUk9EX0FDQ09VTlQgfX1cIixcbiAgICAgICAgICAgIENES19ERVBMT1lfUkVHSU9OOiBcIiR7eyBzZWNyZXRzLkFXU19SRUdJT04gfHwgJ2V1LWNlbnRyYWwtMScgfX1cIixcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9LFxuICB9KVxufVxuIl19
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflows.js","sourceRoot":"","sources":["../src/workflows.ts"],"names":[],"mappings":";;AAGA,4BAsHC;AAzHD,uEAAiE;AAGjE,SAAgB,QAAQ,CAAC,OAAgB;IACvC,MAAM,YAAY,GAAG,OAAO,CAAC,MAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;IACxD,MAAM,cAAc,GAAG,OAAO,CAAC,MAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;IAE5D,kDAAkD;IAClD,YAAY,CAAC,EAAE,CAAC;QACd,WAAW,EAAE,EAAE;QACf,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,MAAM,CAAC,EAAE;KAC7B,CAAC,CAAA;IAEF,wEAAwE;IACxE,cAAc,CAAC,EAAE,CAAC;QAChB,WAAW,EAAE;YACX,SAAS,EAAE,CAAC,MAAM,CAAC;YACnB,KAAK,EAAE,CAAC,WAAW,CAAC;YACpB,QAAQ,EAAE,CAAC,MAAM,CAAC;SACnB;KACF,CAAC,CAAA;IAEF,wBAAwB;IACxB,MAAM,WAAW,GAAG;QAClB,MAAM,EAAE,CAAC,eAAe,CAAC;QACzB,WAAW,EAAE;YACX,QAAQ,EAAE,+BAAa,CAAC,KAAK;YAC7B,OAAO,EAAE,+BAAa,CAAC,KAAK;SAC7B;QACD,KAAK,EAAE;YACL,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,qBAAqB,EAAE;YACjD;gBACE,IAAI,EAAE,eAAe;gBACrB,IAAI,EAAE,uBAAuB;gBAC7B,IAAI,EAAE,EAAE,cAAc,EAAE,IAAI,EAAE;aAC/B;YACD,EAAE,IAAI,EAAE,sBAAsB,EAAE,GAAG,EAAE,QAAQ,EAAE;YAC/C;gBACE,IAAI,EAAE,2BAA2B;gBACjC,IAAI,EAAE,0CAA0C;gBAChD,IAAI,EAAE;oBACJ,mBAAmB,EAAE,kCAAkC;oBACvD,uBAAuB,EAAE,sCAAsC;oBAC/D,YAAY,EAAE,6CAA6C;iBAC5D;aACF;SACF;KACF,CAAA;IAED,4DAA4D;IAC5D,YAAY,CAAC,OAAO,CAAC;QACnB,IAAI,EAAE;YACJ,GAAG,WAAW;YACd,KAAK,EAAE;gBACL,GAAG,WAAW,CAAC,KAAK;gBACpB;oBACE,IAAI,EAAE,0BAA0B;oBAChC,EAAE,EAAE,OAAO;oBACX,GAAG,EAAE,oEAAoE;iBAC1E;gBACD;oBACE,IAAI,EAAE,mBAAmB;oBACzB,GAAG,EAAE,yFAAyF;oBAC9F,GAAG,EAAE;wBACH,kBAAkB,EAAE,iCAAiC;wBACrD,iBAAiB,EAAE,6CAA6C;qBACjE;iBACF;gBACD;oBACE,IAAI,EAAE,eAAe;oBACrB,GAAG,EAAE,kBAAkB;oBACvB,GAAG,EAAE;wBACH,KAAK,EAAE,qCAAqC;qBAC7C;iBACF;gBACD;oBACE,IAAI,EAAE,oBAAoB;oBAC1B,EAAE,EAAE,UAAU;oBACd,GAAG,EAAE,yEAAyE;oBAC9E,GAAG,EAAE;wBACH,kBAAkB,EAAE,iCAAiC;wBACrD,iBAAiB,EAAE,6CAA6C;qBACjE;iBACF;aACF;SACF;KACF,CAAC,CAAA;IAEF,wBAAwB;IACxB,cAAc,CAAC,OAAO,CAAC;QACrB,UAAU,EAAE;YACV,GAAG,WAAW;YACd,EAAE,EAAE,wGAAwG;YAC5G,KAAK,EAAE;gBACL,GAAG,WAAW,CAAC,KAAK;gBACpB;oBACE,IAAI,EAAE,YAAY;oBAClB,GAAG,EAAE,yDAAyD;oBAC9D,GAAG,EAAE;wBACH,kBAAkB,EAAE,gCAAgC;wBACpD,iBAAiB,EAAE,6CAA6C;qBACjE;iBACF;aACF;SACF;QACD,WAAW,EAAE;YACX,GAAG,WAAW;YACd,EAAE,EAAE,mJAAmJ;YACvJ,KAAK,EAAE;gBACL,GAAG,WAAW,CAAC,KAAK;gBACpB;oBACE,IAAI,EAAE,aAAa;oBACnB,GAAG,EAAE,0DAA0D;oBAC/D,GAAG,EAAE;wBACH,kBAAkB,EAAE,iCAAiC;wBACrD,iBAAiB,EAAE,6CAA6C;qBACjE;iBACF;aACF;SACF;KACF,CAAC,CAAA;AACJ,CAAC","sourcesContent":["import { JobPermission } from \"projen/lib/github/workflows-model\"\nimport { Projalf } from \"./Projalf\"\n\nexport function workflow(project: Projalf) {\n  const testWorkflow = project.github!.addWorkflow(\"test\")\n  const deployWorkflow = project.github!.addWorkflow(\"deploy\")\n\n  // Test workflow - triggers on PR and push to main\n  testWorkflow.on({\n    pullRequest: {},\n    push: { branches: [\"main\"] },\n  })\n\n  // Deploy workflow - triggers after test workflow completes successfully\n  deployWorkflow.on({\n    workflowRun: {\n      workflows: [\"test\"],\n      types: [\"completed\"],\n      branches: [\"main\"],\n    },\n  })\n\n  // Reusable job template\n  const jobDefaults = {\n    runsOn: [\"ubuntu-latest\"],\n    permissions: {\n      contents: JobPermission.WRITE,\n      idToken: JobPermission.WRITE,\n    },\n    steps: [\n      { name: \"Checkout\", uses: \"actions/checkout@v4\" },\n      {\n        name: \"Setup Node.js\",\n        uses: \"actions/setup-node@v4\",\n        with: { \"node-version\": \"20\" },\n      },\n      { name: \"Install dependencies\", run: \"npm ci\" },\n      {\n        name: \"Configure AWS credentials\",\n        uses: \"aws-actions/configure-aws-credentials@v4\",\n        with: {\n          \"aws-access-key-id\": \"${{ secrets.AWS_ACCESS_KEY_ID }}\",\n          \"aws-secret-access-key\": \"${{ secrets.AWS_SECRET_ACCESS_KEY }}\",\n          \"aws-region\": \"${{ secrets.AWS_REGION || 'eu-central-1' }}\",\n        },\n      },\n    ],\n  }\n\n  // Test job: deploy test stack, run e2e tests, destroy stack\n  testWorkflow.addJobs({\n    test: {\n      ...jobDefaults,\n      steps: [\n        ...jobDefaults.steps,\n        {\n          name: \"Generate random stage ID\",\n          id: \"stage\",\n          run: 'echo \"STAGE_ID=test-$(shuf -i 10000-99999 -n 1)\" >> $GITHUB_OUTPUT',\n        },\n        {\n          name: \"Deploy Test Stack\",\n          run: \"npm run deploy -- -c stage=${{ steps.stage.outputs.STAGE_ID }} --require-approval never\",\n          env: {\n            CDK_DEPLOY_ACCOUNT: \"${{ secrets.AWS_TEST_ACCOUNT }}\",\n            CDK_DEPLOY_REGION: \"${{ secrets.AWS_REGION || 'eu-central-1' }}\",\n          },\n        },\n        {\n          name: \"Run E2E Tests\",\n          run: \"npm run test:e2e\",\n          env: {\n            STAGE: \"${{ steps.stage.outputs.STAGE_ID }}\",\n          },\n        },\n        {\n          name: \"Destroy Test Stack\",\n          if: \"always()\",\n          run: \"npm run destroy -- -c stage=${{ steps.stage.outputs.STAGE_ID }} --force\",\n          env: {\n            CDK_DEPLOY_ACCOUNT: \"${{ secrets.AWS_TEST_ACCOUNT }}\",\n            CDK_DEPLOY_REGION: \"${{ secrets.AWS_REGION || 'eu-central-1' }}\",\n          },\n        },\n      ],\n    },\n  })\n\n  // Job: deploy dev on PR\n  deployWorkflow.addJobs({\n    deploy_dev: {\n      ...jobDefaults,\n      if: \"github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'\",\n      steps: [\n        ...jobDefaults.steps,\n        {\n          name: \"Deploy Dev\",\n          run: \"npm run deploy -- -c stage=dev --require-approval never\",\n          env: {\n            CDK_DEPLOY_ACCOUNT: \"${{ secrets.AWS_DEV_ACCOUNT }}\",\n            CDK_DEPLOY_REGION: \"${{ secrets.AWS_REGION || 'eu-central-1' }}\",\n          },\n        },\n      ],\n    },\n    deploy_prod: {\n      ...jobDefaults,\n      if: \"github.event.workflow_run.head_branch == 'main' && github.event.workflow_run.event == 'push' && github.event.workflow_run.conclusion == 'success'\",\n      steps: [\n        ...jobDefaults.steps,\n        {\n          name: \"Deploy Prod\",\n          run: \"npm run deploy -- -c stage=prod --require-approval never\",\n          env: {\n            CDK_DEPLOY_ACCOUNT: \"${{ secrets.AWS_PROD_ACCOUNT }}\",\n            CDK_DEPLOY_REGION: \"${{ secrets.AWS_REGION || 'eu-central-1' }}\",\n          },\n        },\n      ],\n    },\n  })\n}\n"]}
package/package.json CHANGED
@@ -65,7 +65,7 @@
65
65
  "publishConfig": {
66
66
  "access": "public"
67
67
  },
68
- "version": "0.0.19",
68
+ "version": "0.0.21",
69
69
  "jest": {
70
70
  "coverageProvider": "v8",
71
71
  "testMatch": [