projen-cdktf-hybrid-construct 0.1.44 → 0.1.47

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md ADDED
@@ -0,0 +1,9 @@
1
+ # Changelog
2
+
3
+ ## 0.1.45
4
+
5
+ - _Breaking Change_: `terraformExamplesFolder`, `terraformProvider`, `terraformProvider*Config` are now part of `terraformExamples` and differently structured.
6
+ - Add documentation hook (using docker if `terraform-docs` is not enabled)
7
+ - Add terraform and construct example folders
8
+ - Add tests to the generated code
9
+ - Remove `pre-commit` hooks
package/README.md CHANGED
@@ -18,13 +18,43 @@ const { HybridModule } = require("projen-cdktf-hybrid-construct");
18
18
 
19
19
  const project = new HybridModule({
20
20
  defaultReleaseBranch: "main",
21
- name: "my-new-hybrid-construct",
21
+ // The name of the module & repository need to start with terraform-cdk-
22
+ name: "terraform-cdk-my-new-hybrid-construct",
23
+ repositoryUrl:
24
+ "github.com/DanielMSchmidt/terraform-cdk-my-new-hybrid-construct",
22
25
 
23
- // All options available in the Projen Typescript template
24
- // deps: [], /* Runtime dependencies of this module. */
25
- // description: undefined, /* The description is just a string that helps people understand the purpose of the package. */
26
- // devDeps: [], /* Build dependencies for this module. */
27
- // packageName: undefined, /* The "name" in package.json. */
26
+ author: "Daniel Schmidt",
27
+ authorAddress: "danielmschmidt92@gmail.com",
28
+
29
+ // If enabled an example folder with terraform code will be created
30
+ terraformExamples: {
31
+ enabled: true,
32
+ folder: "terraform",
33
+ // The configuration to add to the example terraform file
34
+ providerConfig: `
35
+ terraform {
36
+ required_providers {
37
+ aws = {
38
+ source = "hashicorp/aws"
39
+ version = "~> 3.74"
40
+ }
41
+ }
42
+ # Terraform binary version constraint
43
+ required_version = "~> 1.1.0"
44
+ }
45
+
46
+
47
+ provider "aws" {
48
+ region = "eu-central-1"
49
+ }
50
+ `,
51
+ },
52
+
53
+ // If enabled a constructs example folder will be created
54
+ constructExamples: {
55
+ enabled: true,
56
+ folder: "construct-examples",
57
+ },
28
58
  });
29
59
  project.synth();
30
60
  ```
@@ -35,7 +65,8 @@ project.synth();
35
65
  - [x] Add example folder
36
66
  - [x] Add `terraform` example folder
37
67
  - [x] [Auto-generate parts of the docs](https://github.com/terraform-aws-modules/terraform-aws-eks/blob/e90c877a741ab3cc4215376a70f7bcc360b6a3d2/.github/workflows/pre-commit.yml)
38
- - [ ] Add testing strategy
68
+ - [x] Add example folder to project using this
69
+ - [x] Add testing strategy
39
70
  - [ ] Add deployment scripts to Artifactory
40
71
  - [ ] Add deployment scripts to Github Packages
41
72
  - [ ] Add construct / option / docs to publish existing module as construct
@@ -12,7 +12,6 @@
12
12
  /.gitignore linguist-generated
13
13
  /.mergify.yml linguist-generated
14
14
  /.npmignore linguist-generated
15
- /.pre-commit-config.yaml linguist-generated
16
15
  /.prettierignore linguist-generated
17
16
  /.prettierrc.json linguist-generated
18
17
  /.projen/** linguist-generated
@@ -3,16 +3,35 @@ import { HybridModule } from "../lib";
3
3
  const project = new HybridModule({
4
4
  name: "my-module",
5
5
  author: "Daniel Schmidt",
6
- repository: "github.com/DanielMSchmidt/my-module",
7
6
  defaultReleaseBranch: "main",
8
7
  authorAddress: "danielmschmidt92@gmail.com",
9
8
  repositoryUrl: "github.com/DanielMSchmidt/my-module",
10
9
  outdir: ".",
11
- terraformExamplesFolder: "terraform",
12
- terraformProvider: "aws",
13
- terraformProviderAwsConfig: {
14
- region: "eu-central-1",
15
- requiredProviderVersion: "3.74",
10
+ terraformExamples: {
11
+ enabled: true,
12
+ folder: "terraform",
13
+ providerConfig: `
14
+ terraform {
15
+ # Limit provider version (some modules are not compatible with aws 4.x)
16
+ required_providers {
17
+ aws = {
18
+ source = "hashicorp/aws"
19
+ version = "~> 3.74"
20
+ }
21
+ }
22
+ # Terraform binary version constraint
23
+ required_version = "~> 1.1.0"
24
+ }
25
+
26
+
27
+ provider "aws" {
28
+ region = "eu-central-1"
29
+ }
30
+ `,
31
+ },
32
+ constructExamples: {
33
+ enabled: true,
34
+ folder: "construct-examples",
16
35
  },
17
36
  projectId: "my-project-id",
18
37
  });
@@ -0,0 +1,7 @@
1
+ # Construct Examples
2
+
3
+ Example use-cases for the Construct library.
4
+
5
+ - [Basic Usage](./basic.ts)
6
+
7
+ To ensure all examples are working, please make sure the [index.ts](./index.ts) file is importing all of them.
@@ -0,0 +1,14 @@
1
+ import { TerraformStack } from "cdktf";
2
+ import { Construct } from "constructs";
3
+
4
+ import { MyConstruct } from "../src/";
5
+
6
+ export class BasicExample extends TerraformStack {
7
+ constructor(scope: Construct, name: string) {
8
+ super(scope, name);
9
+
10
+ new MyConstruct(this, "my-construct", {
11
+ propertyA: "valueA",
12
+ });
13
+ }
14
+ }
@@ -0,0 +1,5 @@
1
+ {
2
+ "language": "typescript",
3
+ "app": "npx ts-node index.ts",
4
+ "projectId": "my-project-id"
5
+ }
@@ -0,0 +1,13 @@
1
+ {
2
+ "version": "0.9.4",
3
+ "stacks": {
4
+ "basic-example": {
5
+ "name": "basic-example",
6
+ "constructPath": "basic-example",
7
+ "workingDirectory": "stacks/basic-example",
8
+ "synthesizedStackPath": "stacks/basic-example/cdk.tf.json",
9
+ "annotations": [],
10
+ "dependencies": []
11
+ }
12
+ }
13
+ }
@@ -0,0 +1,18 @@
1
+ {
2
+ "//": {
3
+ "metadata": {
4
+ "backend": "local",
5
+ "stackName": "basic-example",
6
+ "version": "0.9.4"
7
+ },
8
+ "outputs": {
9
+ }
10
+ },
11
+ "terraform": {
12
+ "backend": {
13
+ "local": {
14
+ "path": "/home/runner/work/projen-cdktf-hybrid-construct/projen-cdktf-hybrid-construct/example/construct-examples/terraform.basic-example.tfstate"
15
+ }
16
+ }
17
+ }
18
+ }
@@ -0,0 +1,11 @@
1
+ // This file will be synthesized to check if all examples are working
2
+
3
+ import { App } from "cdktf";
4
+ // All examples need to be imported here
5
+ import { BasicExample } from "./basic";
6
+
7
+ const app = new App();
8
+
9
+ // All examples need to be initialized here
10
+ new BasicExample(app, "basic-example");
11
+ app.synth();
@@ -0,0 +1 @@
1
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const cdktf_1 = require("cdktf");
4
+ require("cdktf/lib/testing/adapters/jest");
5
+ const __1 = require("../");
6
+ // To learn more about testing see cdk.tf/testing
7
+ describe("MyConstruct", () => {
8
+ it("should synthesize", () => {
9
+ expect(cdktf_1.Testing.synthScope((scope) => {
10
+ new __1.MyConstruct(scope, "my-construct", {
11
+ propertyA: "valueA",
12
+ });
13
+ })).toMatchSnapshot();
14
+ });
15
+ });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgtdGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vaW5kZXgtdGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGlDQUFnQztBQUNoQywyQ0FBeUM7QUFDekMsMkJBQWtDO0FBRWxDLGlEQUFpRDtBQUNqRCxRQUFRLENBQUMsYUFBYSxFQUFFLEdBQUcsRUFBRTtJQUMzQixFQUFFLENBQUMsbUJBQW1CLEVBQUUsR0FBRyxFQUFFO1FBQzNCLE1BQU0sQ0FDSixlQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDM0IsSUFBSSxlQUFXLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRTtnQkFDckMsU0FBUyxFQUFFLFFBQVE7YUFDcEIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQ0gsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN0QixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVzdGluZyB9IGZyb20gXCJjZGt0ZlwiO1xuaW1wb3J0IFwiY2RrdGYvbGliL3Rlc3RpbmcvYWRhcHRlcnMvamVzdFwiO1xuaW1wb3J0IHsgTXlDb25zdHJ1Y3QgfSBmcm9tIFwiLi4vXCI7XG5cbi8vIFRvIGxlYXJuIG1vcmUgYWJvdXQgdGVzdGluZyBzZWUgY2RrLnRmL3Rlc3RpbmdcbmRlc2NyaWJlKFwiTXlDb25zdHJ1Y3RcIiwgKCkgPT4ge1xuICBpdChcInNob3VsZCBzeW50aGVzaXplXCIsICgpID0+IHtcbiAgICBleHBlY3QoXG4gICAgICBUZXN0aW5nLnN5bnRoU2NvcGUoKHNjb3BlKSA9PiB7XG4gICAgICAgIG5ldyBNeUNvbnN0cnVjdChzY29wZSwgXCJteS1jb25zdHJ1Y3RcIiwge1xuICAgICAgICAgIHByb3BlcnR5QTogXCJ2YWx1ZUFcIixcbiAgICAgICAgfSk7XG4gICAgICB9KVxuICAgICkudG9NYXRjaFNuYXBzaG90KCk7XG4gIH0pO1xufSk7Il19
@@ -7,4 +7,29 @@ module "eks_managed_node_group" {
7
7
  source = "DanielMSchmidt/my-module//modules/my-awesome-module"
8
8
 
9
9
  }
10
- ```
10
+ ```
11
+ <!-- BEGIN_TF_DOCS -->
12
+ ## Requirements
13
+
14
+ No requirements.
15
+
16
+ ## Providers
17
+
18
+ No providers.
19
+
20
+ ## Modules
21
+
22
+ No modules.
23
+
24
+ ## Resources
25
+
26
+ No resources.
27
+
28
+ ## Inputs
29
+
30
+ No inputs.
31
+
32
+ ## Outputs
33
+
34
+ No outputs.
35
+ <!-- END_TF_DOCS -->
@@ -20,7 +20,6 @@
20
20
  "post-compile": "npx projen post-compile",
21
21
  "post-upgrade": "npx projen post-upgrade",
22
22
  "pre-compile": "npx projen pre-compile",
23
- "precommit": "npx projen precommit",
24
23
  "release": "npx projen release",
25
24
  "test": "npx projen test",
26
25
  "test:update": "npx projen test:update",
@@ -38,4 +38,11 @@ for d in */ ; do
38
38
  mkdir -p "$TARGET_FOLDER/$dirname"
39
39
  cp "$MODULES_FOLDER/$dirname/cdk.tf.json" "$TARGET_FOLDER/$dirname/cdk.tf.json"
40
40
  cp "$SRC_FOLDER/$dirname.md" "$TARGET_FOLDER/$dirname/README.md"
41
+
42
+ # Add README hcl docs
43
+ if which terraform-docs >/dev/null; then
44
+ terraform-docs markdown table --output-file "$TARGET_FOLDER/$dirname/README.md" "$TARGET_FOLDER/$dirname"
45
+ else
46
+ docker run --rm --volume "$SCRIPTPATH/../modules:/terraform-docs" -u $(id -u) quay.io/terraform-docs/terraform-docs:0.16.0 markdown table --output-file "/terraform-docs/$dirname/README.md" /terraform-docs/$dirname
47
+ fi
41
48
  done
package/lib/index.d.ts CHANGED
@@ -1,29 +1,17 @@
1
1
  import { ConstructLibrary, ConstructLibraryOptions } from "projen/lib/cdk";
2
- declare type TerraformProviderAwsConfig = {
3
- region: string;
4
- requiredProviderVersion: string;
5
- };
6
- declare type TerraformProviderAzureConfig = {
7
- location: string;
8
- requiredProviderVersion: string;
9
- resourceGroupName: string;
10
- };
11
2
  declare type HybridModuleOptions = ConstructLibraryOptions & {
12
3
  cdktfVersion?: string;
13
4
  constructVersion?: string;
14
- repository: string;
15
5
  author: string;
16
- terraformExamplesFolder: string;
17
- terraformProvider: string;
18
- terraformProviderAwsConfig?: TerraformProviderAwsConfig;
19
- terraformProviderAzureConfig?: TerraformProviderAzureConfig;
20
- documentationPrecommitHook?: boolean;
21
- documentationPrecommitHookOptions?: {
22
- version?: string;
23
- disableFormatHook?: boolean;
24
- disableDocsHook?: boolean;
6
+ terraformExamples?: {
7
+ enabled: boolean;
8
+ folder?: string;
9
+ providerConfig?: string;
10
+ };
11
+ constructExamples?: {
12
+ enabled: boolean;
13
+ folder?: string;
25
14
  };
26
- additionalPrecommitHooks?: Record<string, any>[];
27
15
  projectId?: string;
28
16
  };
29
17
  export declare class HybridModule extends ConstructLibrary {
package/lib/index.js CHANGED
@@ -21,6 +21,25 @@ export class MyConstruct extends Construct {
21
21
  super(scope, id);
22
22
  }
23
23
  }
24
+ `;
25
+ const constructTestCode = `
26
+ import { Testing } from "cdktf";
27
+ import "cdktf/lib/testing/adapters/jest";
28
+ import { MyConstruct } from "../";
29
+
30
+ // To learn more about testing see cdk.tf/testing
31
+ describe("MyConstruct", () => {
32
+ it("should synthesize", () => {
33
+ expect(
34
+ Testing.synthScope((scope) => {
35
+ new MyConstruct(scope, "my-construct", {
36
+ propertyA: "valueA",
37
+ });
38
+ })
39
+ ).toMatchSnapshot();
40
+ });
41
+ });
42
+
24
43
  `;
25
44
  const moduleSrcCode = `
26
45
  import { App } from "cdktf";
@@ -45,54 +64,6 @@ const app = new App();
45
64
  new MyAwesomeModule(app, "my-awesome-module");
46
65
  app.synth();
47
66
  `;
48
- const terraformAwsMainSrcCode = `
49
- terraform {
50
- # Limit provider version (some modules are not compatible with aws 4.x)
51
- required_providers {
52
- aws = {
53
- source = "hashicorp/aws"
54
- version = "~> __requiredProviderVersion__"
55
- }
56
- }
57
- # Terraform binary version constraint
58
- required_version = "~> 1.1.0"
59
- }
60
-
61
-
62
- provider "aws" {
63
- region = "__region__"
64
- }
65
- `;
66
- const terraformAzureMainSrcCode = `
67
- # Configure the Azure provider
68
- terraform {
69
- required_providers {
70
- azurerm = {
71
- source = "hashicorp/azurerm"
72
- version = "~> __requiredProviderVersion__"
73
- }
74
- }
75
-
76
- required_version = ">= 1.1.0"
77
- }
78
-
79
- provider "azurerm" {
80
- features {}
81
- }
82
-
83
- resource "azurerm_resource_group" "rg" {
84
- name = "__resourceGroupName__"
85
- location = "__location__"
86
- }
87
- `;
88
- const terraformMainSrcCodeMap = {
89
- aws: {
90
- srcCode: terraformAwsMainSrcCode,
91
- },
92
- azure: {
93
- srcCode: terraformAzureMainSrcCode,
94
- },
95
- };
96
67
  const terraformReadmeDocs = `
97
68
  # Please add here some pure HCL tests for your modules in order to test HCL Interoperability
98
69
 
@@ -124,20 +95,7 @@ class HybridModule extends cdk_1.ConstructLibrary {
124
95
  eslintOptions: Object.assign({}, config.eslintOptions, {
125
96
  lintProjenRc: false,
126
97
  }),
127
- postBuildSteps: config.documentationPrecommitHook !== false
128
- ? [
129
- {
130
- id: "install-pre-commit",
131
- name: "Install pre-commit hook",
132
- run: "pip install pre-commit",
133
- },
134
- {
135
- id: "documentation-precommit-hook",
136
- name: "Documentation Pre-commit Hook",
137
- run: "pre-commit run --all-files",
138
- },
139
- ]
140
- : [],
98
+ postBuildSteps: [],
141
99
  });
142
100
  const constructVersion = config.constructVersion || "^10.0.25";
143
101
  const cdktfVersion = config.cdktfVersion || "^0.9.4";
@@ -154,7 +112,7 @@ class HybridModule extends cdk_1.ConstructLibrary {
154
112
 
155
113
  \`\`\`hcl
156
114
  module "eks_managed_node_group" {
157
- source = "${((_a = config.repository) === null || _a === void 0 ? void 0 : _a.replace("https://github.com/", "").replace("http://github.com/", "").replace("github.com/", "")) || "my-github-repo"}//modules/my-awesome-module"
115
+ source = "${((_a = config.repositoryUrl) === null || _a === void 0 ? void 0 : _a.replace("https://github.com/", "").replace("http://github.com/", "").replace("github.com/", "")) || "my-github-repo"}//modules/my-awesome-module"
158
116
 
159
117
  }
160
118
  \`\`\`
@@ -172,35 +130,101 @@ module "eks_managed_node_group" {
172
130
  output: "modules",
173
131
  projectId: config.projectId || (0, uuid_1.v4)(),
174
132
  }, null, 2),
133
+ "__tests__/index-test.ts": constructTestCode.trim(),
175
134
  },
176
135
  });
177
- // Retrieve correct TF main stuff
178
- let mainTfFile = terraformMainSrcCodeMap[config.terraformProvider].srcCode.trim();
179
- let configProperty = {};
180
- switch (config.terraformProvider) {
181
- case "aws": {
182
- configProperty = config.terraformProviderAwsConfig;
183
- break;
184
- }
185
- case "azure": {
186
- configProperty = config.terraformProviderAzureConfig;
187
- break;
188
- }
189
- default: {
190
- throw new Error("Need to define correctly a Provider, only [aws,azure,gcp] allowed");
191
- }
136
+ if (config.terraformExamples && config.terraformExamples.enabled) {
137
+ const providerConfig = config.terraformExamples.providerConfig ||
138
+ `
139
+ terraform {
140
+ # Terraform binary version constraint
141
+ required_version = "~> 1.1.0"
142
+
143
+ # Define all needed providers here, you can find all available providers here:
144
+ # https://registry.terraform.io/
145
+ required_providers {}
146
+ }
147
+
148
+ # Initialize your provider here
149
+
150
+ `.trim();
151
+ const examplesFolder = config.terraformExamples.folder || "terraform-examples";
152
+ new projen_1.SampleDir(this, examplesFolder, {
153
+ files: {
154
+ "main.tf": `
155
+ # Configure Terraform
156
+ ${providerConfig}
157
+
158
+ `.trimStart(),
159
+ "README.md": terraformReadmeDocs.trim(),
160
+ },
161
+ });
162
+ this.gitignore.addPatterns(`${examplesFolder}/.terraform`, `${examplesFolder}/.terraform.lock.hcl`);
163
+ }
164
+ if (config.constructExamples && config.constructExamples.enabled) {
165
+ const constructExampleFolder = config.constructExamples.folder || "construct-examples";
166
+ const levels = constructExampleFolder
167
+ .split("/")
168
+ .map(() => "..")
169
+ .join("/");
170
+ const constructReadmeDocs = `
171
+ # Construct Examples
172
+
173
+ Example use-cases for the Construct library.
174
+
175
+ - [Basic Usage](./basic.ts)
176
+
177
+ To ensure all examples are working, please make sure the [index.ts](./index.ts) file is importing all of them.
178
+ `;
179
+ const constructExampleCode = `
180
+ import { TerraformStack } from "cdktf";
181
+ import { Construct } from "constructs";
182
+
183
+ import { MyConstruct } from "${levels}/src/";
184
+
185
+ export class BasicExample extends TerraformStack {
186
+ constructor(scope: Construct, name: string) {
187
+ super(scope, name);
188
+
189
+ new MyConstruct(this, "my-construct", {
190
+ propertyA: "valueA",
191
+ });
192
+ }
193
+ }
194
+
195
+
196
+ `;
197
+ const exampleCollectionCode = `
198
+ // This file will be synthesized to check if all examples are working
199
+
200
+ import { App } from "cdktf";
201
+ // All examples need to be imported here
202
+ import { BasicExample } from "./basic";
203
+
204
+ const app = new App();
205
+
206
+ // All examples need to be initialized here
207
+ new BasicExample(app, "basic-example");
208
+ app.synth();
209
+ `;
210
+ new projen_1.SampleDir(this, constructExampleFolder, {
211
+ files: {
212
+ "index.ts": exampleCollectionCode.trim(),
213
+ "basic.ts": constructExampleCode.trim(),
214
+ "cdktf.json": JSON.stringify({
215
+ language: "typescript",
216
+ app: "npx ts-node index.ts",
217
+ projectId: config.projectId || (0, uuid_1.v4)(),
218
+ }, null, 2),
219
+ "README.md": constructReadmeDocs.trim(),
220
+ },
221
+ });
222
+ this.testTask.exec(`cdktf synth`, {
223
+ cwd: constructExampleFolder,
224
+ });
225
+ this.gitignore.addPatterns(`${constructExampleFolder}/cdktf.out`);
192
226
  }
193
- Object.keys(configProperty).forEach((key) => {
194
- mainTfFile = mainTfFile.replace(`__${key}__`, configProperty[key]);
195
- });
196
- new projen_1.SampleDir(this, config.terraformExamplesFolder, {
197
- files: {
198
- "main.tf": mainTfFile,
199
- "README.md": terraformReadmeDocs.trim(),
200
- },
201
- });
202
227
  this.gitignore.addPatterns("src/.gen", "src/cdktf.out", "src/modules");
203
- this.gitignore.addPatterns(`${config.terraformExamplesFolder}/.terraform`, `${config.terraformExamplesFolder}/.terraform.lock.hcl`);
204
228
  this.compileTask.prependExec("cdktf get", {
205
229
  cwd: this.srcdir,
206
230
  });
@@ -249,6 +273,13 @@ for d in */ ; do
249
273
  mkdir -p "$TARGET_FOLDER/$dirname"
250
274
  cp "$MODULES_FOLDER/$dirname/cdk.tf.json" "$TARGET_FOLDER/$dirname/cdk.tf.json"
251
275
  cp "$SRC_FOLDER/$dirname.md" "$TARGET_FOLDER/$dirname/README.md"
276
+
277
+ # Add README hcl docs
278
+ if which terraform-docs >/dev/null; then
279
+ terraform-docs markdown table --output-file "$TARGET_FOLDER/$dirname/README.md" "$TARGET_FOLDER/$dirname"
280
+ else
281
+ docker run --rm --volume "$SCRIPTPATH/../modules:/terraform-docs" -u $(id -u) quay.io/terraform-docs/terraform-docs:0.16.0 markdown table --output-file "/terraform-docs/$dirname/README.md" /terraform-docs/$dirname
282
+ fi
252
283
  done
253
284
  `.trim());
254
285
  this.compileTask.exec("./scripts/copy-modules.sh", {
@@ -268,32 +299,7 @@ terraform -chdir=terraform plan
268
299
  `);
269
300
  this.testTask.exec("./scripts/tf-module-test.sh");
270
301
  (_c = this.jest) === null || _c === void 0 ? void 0 : _c.addIgnorePattern("terraform");
271
- // Pre-commit hooks
272
- if (config.documentationPrecommitHook !== false) {
273
- const { additionalPrecommitHooks, documentationPrecommitHookOptions } = config;
274
- const { version = "v1.70.1", disableDocsHook = false, disableFormatHook = false, } = documentationPrecommitHookOptions || {};
275
- new projen_1.YamlFile(this, ".pre-commit-config.yaml", {
276
- committed: true,
277
- obj: {
278
- repos: [
279
- {
280
- repo: "https://github.com/antonbabenko/pre-commit-terraform",
281
- rev: version,
282
- hooks: [
283
- disableFormatHook ? null : { id: "terraform_fmt" },
284
- disableDocsHook ? null : { id: "terraform_docs" },
285
- ].filter((item) => item !== null),
286
- },
287
- ...(additionalPrecommitHooks !== null && additionalPrecommitHooks !== void 0 ? additionalPrecommitHooks : []),
288
- ],
289
- },
290
- });
291
- this.tasks.addTask("precommit", {
292
- description: "Runs precommit hooks",
293
- exec: "pre-commit install",
294
- });
295
- }
296
302
  }
297
303
  }
298
304
  exports.HybridModule = HybridModule;
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { FileBase, IResolver, Project, SampleDir, YamlFile } from \"projen\";\nimport { ConstructLibrary, ConstructLibraryOptions } from \"projen/lib/cdk\";\nimport { v4 as uuid } from \"uuid\";\n\ntype TerraformProviderAwsConfig = {\n  region: string;\n  requiredProviderVersion: string;\n};\n\ntype TerraformProviderAzureConfig = {\n  location: string;\n  requiredProviderVersion: string;\n  resourceGroupName: string;\n};\n\ntype HybridModuleOptions = ConstructLibraryOptions & {\n  cdktfVersion?: string;\n  constructVersion?: string;\n  repository: string;\n  author: string;\n  terraformExamplesFolder: string;\n  terraformProvider: string;\n  terraformProviderAwsConfig?: TerraformProviderAwsConfig;\n  terraformProviderAzureConfig?: TerraformProviderAzureConfig;\n  // Run pre-commit hooks using local binaries / not at all\n  documentationPrecommitHook?: boolean;\n  documentationPrecommitHookOptions?: {\n    version?: string; // Get the latest from: https://github.com/antonbabenko/pre-commit-terraform/releases\n    disableFormatHook?: boolean;\n    disableDocsHook?: boolean;\n  };\n  additionalPrecommitHooks?: Record<string, any>[];\n  // Defaulted to a uuid string as cdktf would\n  projectId?: string;\n};\n\nconst defaults = {\n  prettier: true,\n  projenrcTs: true,\n  defaultReleaseBranch: \"main\",\n};\n\nconst constructSrcCode = `\nimport { Construct } from \"constructs\";\n\nexport interface MyConstructOptions {\n  readonly propertyA: string;\n}\n\nexport class MyConstruct extends Construct {\n  constructor(scope: Construct, id: string, public config: MyConstructOptions) {\n    super(scope, id);\n  }\n}\n`;\n\nconst moduleSrcCode = `\nimport { App } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { TFModuleStack } from \"cdktf-tf-module-stack\";\nimport { MyConstruct } from \"./index\";\n\nclass MyAwesomeModule extends TFModuleStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    new MyConstruct(this, \"my-construct\", {\n      propertyA: \"valueA\",\n    });\n  }\n}\n\nconst app = new App();\n// This is the name the module can be found under. \n// We expect a \"my-awesome-module.md\" file in this directory.\n// The README.md file will be generated from this file.\nnew MyAwesomeModule(app, \"my-awesome-module\");\napp.synth();\n`;\n\nconst terraformAwsMainSrcCode = `\nterraform {\n  # Limit provider version (some modules are not compatible with aws 4.x)\n  required_providers {\n    aws = {\n      source  = \"hashicorp/aws\"\n      version = \"~> __requiredProviderVersion__\"\n    }\n  }\n  # Terraform binary version constraint\n  required_version = \"~> 1.1.0\"\n}\n\n\nprovider \"aws\" {\n  region = \"__region__\"\n}\n`;\n\nconst terraformAzureMainSrcCode = `\n# Configure the Azure provider\nterraform {\n  required_providers {\n    azurerm = {\n      source  = \"hashicorp/azurerm\"\n      version = \"~> __requiredProviderVersion__\"\n    }\n  }\n\n  required_version = \">= 1.1.0\"\n}\n\nprovider \"azurerm\" {\n  features {}\n}\n\nresource \"azurerm_resource_group\" \"rg\" {\n  name     = \"__resourceGroupName__\"\n  location = \"__location__\"\n}\n`;\n\nconst terraformMainSrcCodeMap: { [key: string]: { srcCode: string } } = {\n  aws: {\n    srcCode: terraformAwsMainSrcCode,\n  },\n  azure: {\n    srcCode: terraformAzureMainSrcCode,\n  },\n};\n\nconst terraformReadmeDocs = `\n# Please add here some pure HCL tests for your modules in order to test HCL Interoperability\n\nExamples:\n\nmodule \"my_awesome_test\" {\n  source = \"../modules/my-awesome-modules\"\n  ...variables...\n}\n    `;\n\nclass ScriptFile extends FileBase {\n  constructor(project: Project, path: string, private content: string) {\n    super(project, path, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\nexport class HybridModule extends ConstructLibrary {\n  constructor(config: HybridModuleOptions) {\n    super({\n      ...defaults,\n      ...config,\n      sampleCode: false,\n      eslintOptions: Object.assign({}, config.eslintOptions, {\n        lintProjenRc: false,\n      }),\n      postBuildSteps:\n        config.documentationPrecommitHook !== false\n          ? [\n              {\n                id: \"install-pre-commit\",\n                name: \"Install pre-commit hook\",\n                run: \"pip install pre-commit\",\n              },\n              {\n                id: \"documentation-precommit-hook\",\n                name: \"Documentation Pre-commit Hook\",\n                run: \"pre-commit run --all-files\",\n              },\n            ]\n          : [],\n    });\n    const constructVersion = config.constructVersion || \"^10.0.25\";\n    const cdktfVersion = config.cdktfVersion || \"^0.9.4\";\n\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(`cdktf-cli@${cdktfVersion}`, \"ts-node\");\n    this.addKeywords(\"cdktf\", \"cdktf-hybrid\");\n    this.setScript(\"terraform:test\", \"./scripts/tf-module-test.sh\");\n\n    // Module Entrypoint\n    this.addDeps(\"cdktf-tf-module-stack\");\n    const moduleDocs = `\n# My Awesome Module\n\n## Usage\n\n\\`\\`\\`hcl\nmodule \"eks_managed_node_group\" {\n  source = \"${\n    config.repository\n      ?.replace(\"https://github.com/\", \"\")\n      .replace(\"http://github.com/\", \"\")\n      .replace(\"github.com/\", \"\") || \"my-github-repo\"\n  }//modules/my-awesome-module\"\n\n}\n\\`\\`\\`\n    `;\n\n    new SampleDir(this, this.srcdir, {\n      files: {\n        \"index.ts\": constructSrcCode.trim(),\n        \"tfModules.ts\": moduleSrcCode.trim(),\n        \"my-awesome-module.md\": moduleDocs.trim(),\n        \"cdktf.json\": JSON.stringify(\n          {\n            language: \"typescript\",\n            app: \"npx ts-node tfModules.ts\",\n            terraformProviders: [\"hashicorp/null@3.1.1\"], // We need at least a provider for get to succeed\n            terraformModules: [],\n            output: \"modules\",\n            projectId: config.projectId || uuid(),\n          },\n          null,\n          2\n        ),\n      },\n    });\n\n    // Retrieve correct TF main stuff\n    let mainTfFile =\n      terraformMainSrcCodeMap[config.terraformProvider].srcCode.trim();\n\n    let configProperty: any = {};\n    switch (config.terraformProvider) {\n      case \"aws\": {\n        configProperty = config.terraformProviderAwsConfig;\n        break;\n      }\n      case \"azure\": {\n        configProperty = config.terraformProviderAzureConfig;\n        break;\n      }\n      default: {\n        throw new Error(\n          \"Need to define correctly a Provider, only [aws,azure,gcp] allowed\"\n        );\n      }\n    }\n\n    Object.keys(configProperty).forEach((key: string) => {\n      mainTfFile = mainTfFile.replace(`__${key}__`, configProperty[key]);\n    });\n\n    new SampleDir(this, config.terraformExamplesFolder, {\n      files: {\n        \"main.tf\": mainTfFile,\n        \"README.md\": terraformReadmeDocs.trim(),\n      },\n    });\n\n    this.gitignore.addPatterns(\"src/.gen\", \"src/cdktf.out\", \"src/modules\");\n    this.gitignore.addPatterns(\n      `${config.terraformExamplesFolder}/.terraform`,\n      `${config.terraformExamplesFolder}/.terraform.lock.hcl`\n    );\n    this.compileTask.prependExec(\"cdktf get\", {\n      cwd: this.srcdir,\n    });\n    this.compileTask.exec(\"cdktf synth\", {\n      cwd: this.srcdir,\n      name: \"Synthesize module HCL\",\n    });\n\n    new ScriptFile(\n      this,\n      \"scripts/copy-modules.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nSCRIPTPATH=\"$( cd -- \"$(dirname \"$0\")\" >/dev/null 2>&1 ; pwd -P )\"\n\n# check if the module folder has been generated as expected\nMODULES_FOLDER=$( cd -- \"$SCRIPTPATH/../src/modules/stacks\" >/dev/null 2>&1 ; pwd -P )\nSRC_FOLDER=$( cd -- \"$SCRIPTPATH/../src/\" >/dev/null 2>&1 ; pwd -P )\nTARGET_FOLDER=\"$SCRIPTPATH/../modules\"\n\nif [ ! -d \"$MODULES_FOLDER\" ]; then\n  echo \"Expected module folder to exist at $MODULES_FOLDER\"\n  exit 1\nfi\n\ncd \"$MODULES_FOLDER\"\nfor d in */ ; do\n    [ -L \"\\${d%/}\" ] && continue\n\n    dirname=\"\\${d%/}\"\n\n\n    # Check if everything is in place\n    if [ ! -f \"$MODULES_FOLDER/$dirname/cdk.tf.json\" ]; then\n      echo \"Expected code for $dirname at cdk.tf.json to exist at $MODULES_FOLDER/$dirname\"\n      exit 1\n    fi\n\n    if [ ! -f \"$SRC_FOLDER/$dirname.md\" ]; then\n      echo \"Expected Documentation for $dirname at $dirname.md to exist at $SRC_FOLDER/$dirname.md\"\n      exit 1\n    fi\n\n    # Copy module and readme together\n    echo \"Copying Code and README for module $dirname\"\n    mkdir -p \"$TARGET_FOLDER\"\n    mkdir -p \"$TARGET_FOLDER/$dirname\"\n    cp \"$MODULES_FOLDER/$dirname/cdk.tf.json\" \"$TARGET_FOLDER/$dirname/cdk.tf.json\"\n    cp \"$SRC_FOLDER/$dirname.md\" \"$TARGET_FOLDER/$dirname/README.md\"\ndone\n`.trim()\n    );\n    this.compileTask.exec(\"./scripts/copy-modules.sh\", {\n      name: \"Copy HCL Modules\",\n    });\n\n    // ignore dist in tests\n    this.jest?.addIgnorePattern(\"dist\");\n\n    new ScriptFile(\n      this,\n      \"./scripts/tf-module-test.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nterraform -chdir=terraform init --upgrade\nterraform -chdir=terraform fmt\nterraform -chdir=terraform validate\nterraform -chdir=terraform plan     \n        `\n    );\n\n    this.testTask.exec(\"./scripts/tf-module-test.sh\");\n    this.jest?.addIgnorePattern(\"terraform\");\n\n    // Pre-commit hooks\n    if (config.documentationPrecommitHook !== false) {\n      const { additionalPrecommitHooks, documentationPrecommitHookOptions } =\n        config;\n      const {\n        version = \"v1.70.1\",\n        disableDocsHook = false,\n        disableFormatHook = false,\n      } = documentationPrecommitHookOptions || {};\n\n      new YamlFile(this, \".pre-commit-config.yaml\", {\n        committed: true,\n        obj: {\n          repos: [\n            {\n              repo: \"https://github.com/antonbabenko/pre-commit-terraform\",\n              rev: version,\n              hooks: [\n                disableFormatHook ? null : { id: \"terraform_fmt\" },\n                disableDocsHook ? null : { id: \"terraform_docs\" },\n              ].filter((item) => item !== null),\n            },\n            ...(additionalPrecommitHooks ?? []),\n          ],\n        },\n      });\n\n      this.tasks.addTask(\"precommit\", {\n        description: \"Runs precommit hooks\",\n        exec: \"pre-commit install\",\n      });\n    }\n  }\n}\n"]}
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { FileBase, IResolver, Project, SampleDir } from \"projen\";\nimport { ConstructLibrary, ConstructLibraryOptions } from \"projen/lib/cdk\";\nimport { v4 as uuid } from \"uuid\";\n\ntype HybridModuleOptions = ConstructLibraryOptions & {\n  cdktfVersion?: string;\n  constructVersion?: string;\n  // Name of the author\n  author: string;\n  // If set a terraform examples folder will be created\n  terraformExamples?: {\n    // If set terraform examples will be rendered\n    enabled: boolean;\n    // Path for the terraform examples\n    folder?: string;\n    // The HCL config file to use for the terraform provider\n    providerConfig?: string;\n  };\n  constructExamples?: {\n    // If set construct examples will be rendered\n    enabled: boolean;\n    // Path for the construct examples\n    folder?: string;\n  };\n  // Defaulted to a uuid string as cdktf would\n  projectId?: string;\n};\n\nconst defaults = {\n  prettier: true,\n  projenrcTs: true,\n  defaultReleaseBranch: \"main\",\n};\n\nconst constructSrcCode = `\nimport { Construct } from \"constructs\";\n\nexport interface MyConstructOptions {\n  readonly propertyA: string;\n}\n\nexport class MyConstruct extends Construct {\n  constructor(scope: Construct, id: string, public config: MyConstructOptions) {\n    super(scope, id);\n  }\n}\n`;\n\nconst constructTestCode = `\nimport { Testing } from \"cdktf\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { MyConstruct } from \"../\";\n\n// To learn more about testing see cdk.tf/testing\ndescribe(\"MyConstruct\", () => {\n  it(\"should synthesize\", () => {\n    expect(\n      Testing.synthScope((scope) => {\n        new MyConstruct(scope, \"my-construct\", {\n          propertyA: \"valueA\",\n        });\n      })\n    ).toMatchSnapshot();\n  });\n});\n\n`;\n\nconst moduleSrcCode = `\nimport { App } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { TFModuleStack } from \"cdktf-tf-module-stack\";\nimport { MyConstruct } from \"./index\";\n\nclass MyAwesomeModule extends TFModuleStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    new MyConstruct(this, \"my-construct\", {\n      propertyA: \"valueA\",\n    });\n  }\n}\n\nconst app = new App();\n// This is the name the module can be found under. \n// We expect a \"my-awesome-module.md\" file in this directory.\n// The README.md file will be generated from this file.\nnew MyAwesomeModule(app, \"my-awesome-module\");\napp.synth();\n`;\n\nconst terraformReadmeDocs = `\n# Please add here some pure HCL tests for your modules in order to test HCL Interoperability\n\nExamples:\n\nmodule \"my_awesome_test\" {\n  source = \"../modules/my-awesome-modules\"\n  ...variables...\n}\n    `;\n\nclass ScriptFile extends FileBase {\n  constructor(project: Project, path: string, private content: string) {\n    super(project, path, {\n      executable: true,\n    });\n  }\n\n  protected synthesizeContent(_: IResolver): string | undefined {\n    return this.content;\n  }\n}\n\nexport class HybridModule extends ConstructLibrary {\n  constructor(config: HybridModuleOptions) {\n    super({\n      ...defaults,\n      ...config,\n      sampleCode: false,\n      eslintOptions: Object.assign({}, config.eslintOptions, {\n        lintProjenRc: false,\n      }),\n      postBuildSteps: [],\n    });\n    const constructVersion = config.constructVersion || \"^10.0.25\";\n    const cdktfVersion = config.cdktfVersion || \"^0.9.4\";\n\n    this.addPeerDeps(`constructs@${constructVersion}`, `cdktf@${cdktfVersion}`);\n    this.addDevDeps(`cdktf-cli@${cdktfVersion}`, \"ts-node\");\n    this.addKeywords(\"cdktf\", \"cdktf-hybrid\");\n    this.setScript(\"terraform:test\", \"./scripts/tf-module-test.sh\");\n\n    // Module Entrypoint\n    this.addDeps(\"cdktf-tf-module-stack\");\n    const moduleDocs = `\n# My Awesome Module\n\n## Usage\n\n\\`\\`\\`hcl\nmodule \"eks_managed_node_group\" {\n  source = \"${\n    config.repositoryUrl\n      ?.replace(\"https://github.com/\", \"\")\n      .replace(\"http://github.com/\", \"\")\n      .replace(\"github.com/\", \"\") || \"my-github-repo\"\n  }//modules/my-awesome-module\"\n\n}\n\\`\\`\\`\n    `;\n\n    new SampleDir(this, this.srcdir, {\n      files: {\n        \"index.ts\": constructSrcCode.trim(),\n        \"tfModules.ts\": moduleSrcCode.trim(),\n        \"my-awesome-module.md\": moduleDocs.trim(),\n        \"cdktf.json\": JSON.stringify(\n          {\n            language: \"typescript\",\n            app: \"npx ts-node tfModules.ts\",\n            terraformProviders: [\"hashicorp/null@3.1.1\"], // We need at least a provider for get to succeed\n            terraformModules: [],\n            output: \"modules\",\n            projectId: config.projectId || uuid(),\n          },\n          null,\n          2\n        ),\n        \"__tests__/index-test.ts\": constructTestCode.trim(),\n      },\n    });\n\n    if (config.terraformExamples && config.terraformExamples.enabled) {\n      const providerConfig =\n        config.terraformExamples.providerConfig ||\n        `\nterraform {\n  # Terraform binary version constraint\n  required_version = \"~> 1.1.0\"\n\n  # Define all needed providers here, you can find all available providers here:\n  # https://registry.terraform.io/\n  required_providers {}\n}\n\n# Initialize your provider here\n\n`.trim();\n      const examplesFolder =\n        config.terraformExamples.folder || \"terraform-examples\";\n\n      new SampleDir(this, examplesFolder, {\n        files: {\n          \"main.tf\": `\n# Configure Terraform\n${providerConfig}\n\n            `.trimStart(),\n          \"README.md\": terraformReadmeDocs.trim(),\n        },\n      });\n\n      this.gitignore.addPatterns(\n        `${examplesFolder}/.terraform`,\n        `${examplesFolder}/.terraform.lock.hcl`\n      );\n    }\n\n    if (config.constructExamples && config.constructExamples.enabled) {\n      const constructExampleFolder =\n        config.constructExamples.folder || \"construct-examples\";\n\n      const levels = constructExampleFolder\n        .split(\"/\")\n        .map(() => \"..\")\n        .join(\"/\");\n\n      const constructReadmeDocs = `\n# Construct Examples\n\nExample use-cases for the Construct library.\n\n- [Basic Usage](./basic.ts)\n\nTo ensure all examples are working, please make sure the [index.ts](./index.ts) file is importing all of them.\n`;\n\n      const constructExampleCode = `\nimport { TerraformStack } from \"cdktf\";\nimport { Construct } from \"constructs\";\n\nimport { MyConstruct } from \"${levels}/src/\";\n\nexport class BasicExample extends TerraformStack {\n  constructor(scope: Construct, name: string) {\n    super(scope, name);\n\n    new MyConstruct(this, \"my-construct\", {\n      propertyA: \"valueA\",\n    });\n  }\n}\n\n\n`;\n\n      const exampleCollectionCode = `\n// This file will be synthesized to check if all examples are working\n\nimport { App } from \"cdktf\";\n// All examples need to be imported here\nimport { BasicExample } from \"./basic\";\n\nconst app = new App();\n\n// All examples need to be initialized here\nnew BasicExample(app, \"basic-example\");\napp.synth();\n`;\n\n      new SampleDir(this, constructExampleFolder, {\n        files: {\n          \"index.ts\": exampleCollectionCode.trim(),\n          \"basic.ts\": constructExampleCode.trim(),\n          \"cdktf.json\": JSON.stringify(\n            {\n              language: \"typescript\",\n              app: \"npx ts-node index.ts\",\n              projectId: config.projectId || uuid(),\n            },\n            null,\n            2\n          ),\n          \"README.md\": constructReadmeDocs.trim(),\n        },\n      });\n\n      this.testTask.exec(`cdktf synth`, {\n        cwd: constructExampleFolder,\n      });\n      this.gitignore.addPatterns(`${constructExampleFolder}/cdktf.out`);\n    }\n\n    this.gitignore.addPatterns(\"src/.gen\", \"src/cdktf.out\", \"src/modules\");\n    this.compileTask.prependExec(\"cdktf get\", {\n      cwd: this.srcdir,\n    });\n    this.compileTask.exec(\"cdktf synth\", {\n      cwd: this.srcdir,\n      name: \"Synthesize module HCL\",\n    });\n\n    new ScriptFile(\n      this,\n      \"scripts/copy-modules.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nSCRIPTPATH=\"$( cd -- \"$(dirname \"$0\")\" >/dev/null 2>&1 ; pwd -P )\"\n\n# check if the module folder has been generated as expected\nMODULES_FOLDER=$( cd -- \"$SCRIPTPATH/../src/modules/stacks\" >/dev/null 2>&1 ; pwd -P )\nSRC_FOLDER=$( cd -- \"$SCRIPTPATH/../src/\" >/dev/null 2>&1 ; pwd -P )\nTARGET_FOLDER=\"$SCRIPTPATH/../modules\"\n\nif [ ! -d \"$MODULES_FOLDER\" ]; then\n  echo \"Expected module folder to exist at $MODULES_FOLDER\"\n  exit 1\nfi\n\ncd \"$MODULES_FOLDER\"\nfor d in */ ; do\n    [ -L \"\\${d%/}\" ] && continue\n\n    dirname=\"\\${d%/}\"\n\n\n    # Check if everything is in place\n    if [ ! -f \"$MODULES_FOLDER/$dirname/cdk.tf.json\" ]; then\n      echo \"Expected code for $dirname at cdk.tf.json to exist at $MODULES_FOLDER/$dirname\"\n      exit 1\n    fi\n\n    if [ ! -f \"$SRC_FOLDER/$dirname.md\" ]; then\n      echo \"Expected Documentation for $dirname at $dirname.md to exist at $SRC_FOLDER/$dirname.md\"\n      exit 1\n    fi\n\n    # Copy module and readme together\n    echo \"Copying Code and README for module $dirname\"\n    mkdir -p \"$TARGET_FOLDER\"\n    mkdir -p \"$TARGET_FOLDER/$dirname\"\n    cp \"$MODULES_FOLDER/$dirname/cdk.tf.json\" \"$TARGET_FOLDER/$dirname/cdk.tf.json\"\n    cp \"$SRC_FOLDER/$dirname.md\" \"$TARGET_FOLDER/$dirname/README.md\"\n\n    # Add README hcl docs\n    if which terraform-docs >/dev/null; then\n      terraform-docs markdown table --output-file \"$TARGET_FOLDER/$dirname/README.md\" \"$TARGET_FOLDER/$dirname\" \n    else\n      docker run --rm --volume \"$SCRIPTPATH/../modules:/terraform-docs\" -u $(id -u) quay.io/terraform-docs/terraform-docs:0.16.0 markdown table --output-file \"/terraform-docs/$dirname/README.md\" /terraform-docs/$dirname\n    fi\ndone\n`.trim()\n    );\n    this.compileTask.exec(\"./scripts/copy-modules.sh\", {\n      name: \"Copy HCL Modules\",\n    });\n\n    // ignore dist in tests\n    this.jest?.addIgnorePattern(\"dist\");\n\n    new ScriptFile(\n      this,\n      \"./scripts/tf-module-test.sh\",\n      `\n#!/bin/bash\n# This script is created by projen, do not edit it directly.\nset -e\n\nterraform -chdir=terraform init --upgrade\nterraform -chdir=terraform fmt\nterraform -chdir=terraform validate\nterraform -chdir=terraform plan     \n        `\n    );\n\n    this.testTask.exec(\"./scripts/tf-module-test.sh\");\n    this.jest?.addIgnorePattern(\"terraform\");\n  }\n}\n"]}
package/package.json CHANGED
@@ -57,7 +57,7 @@
57
57
  },
58
58
  "main": "lib/index.js",
59
59
  "license": "MIT",
60
- "version": "0.1.44",
60
+ "version": "0.1.47",
61
61
  "jest": {
62
62
  "testMatch": [
63
63
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
@@ -1,8 +0,0 @@
1
- # ~~ Generated by projen. To modify, edit .projenrc.js and run "npx projen".
2
-
3
- repos:
4
- - repo: https://github.com/antonbabenko/pre-commit-terraform
5
- rev: v1.70.1
6
- hooks:
7
- - id: terraform_fmt
8
- - id: terraform_docs