projen-cdktf-hybrid-construct 0.1.44 → 0.1.45
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 +9 -0
- package/README.md +2 -1
- package/example/.gitattributes +0 -1
- package/example/.projenrc.ts +25 -5
- package/example/construct-examples/README.md +7 -0
- package/example/construct-examples/basic.ts +14 -0
- package/example/construct-examples/cdktf.json +5 -0
- package/example/construct-examples/cdktf.out/manifest.json +13 -0
- package/example/construct-examples/cdktf.out/stacks/basic-example/cdk.tf.json +18 -0
- package/example/construct-examples/index.ts +11 -0
- package/example/lib/__tests__/index-test.d.ts +1 -0
- package/example/lib/__tests__/index-test.js +16 -0
- package/example/modules/my-awesome-module/README.md +26 -1
- package/example/package.json +0 -1
- package/example/scripts/copy-modules.sh +7 -0
- package/lib/index.d.ts +8 -19
- package/lib/index.js +119 -113
- package/package.json +1 -1
- package/example/.pre-commit-config.yaml +0 -8
package/CHANGELOG.md
ADDED
@@ -0,0 +1,9 @@
|
|
1
|
+
# Changelog
|
2
|
+
|
3
|
+
## 0.1.0
|
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
@@ -35,7 +35,8 @@ project.synth();
|
|
35
35
|
- [x] Add example folder
|
36
36
|
- [x] Add `terraform` example folder
|
37
37
|
- [x] [Auto-generate parts of the docs](https://github.com/terraform-aws-modules/terraform-aws-eks/blob/e90c877a741ab3cc4215376a70f7bcc360b6a3d2/.github/workflows/pre-commit.yml)
|
38
|
-
- [
|
38
|
+
- [x] Add example folder to project using this
|
39
|
+
- [x] Add testing strategy
|
39
40
|
- [ ] Add deployment scripts to Artifactory
|
40
41
|
- [ ] Add deployment scripts to Github Packages
|
41
42
|
- [ ] Add construct / option / docs to publish existing module as construct
|
package/example/.gitattributes
CHANGED
@@ -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
|
package/example/.projenrc.ts
CHANGED
@@ -8,11 +8,31 @@ const project = new HybridModule({
|
|
8
8
|
authorAddress: "danielmschmidt92@gmail.com",
|
9
9
|
repositoryUrl: "github.com/DanielMSchmidt/my-module",
|
10
10
|
outdir: ".",
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
11
|
+
terraformExamples: {
|
12
|
+
enabled: true,
|
13
|
+
folder: "terraform",
|
14
|
+
providerConfig: `
|
15
|
+
terraform {
|
16
|
+
# Limit provider version (some modules are not compatible with aws 4.x)
|
17
|
+
required_providers {
|
18
|
+
aws = {
|
19
|
+
source = "hashicorp/aws"
|
20
|
+
version = "~> 3.74"
|
21
|
+
}
|
22
|
+
}
|
23
|
+
# Terraform binary version constraint
|
24
|
+
required_version = "~> 1.1.0"
|
25
|
+
}
|
26
|
+
|
27
|
+
|
28
|
+
provider "aws" {
|
29
|
+
region = "eu-central-1"
|
30
|
+
}
|
31
|
+
`,
|
32
|
+
},
|
33
|
+
constructExamples: {
|
34
|
+
enabled: true,
|
35
|
+
folder: "construct-examples",
|
16
36
|
},
|
17
37
|
projectId: "my-project-id",
|
18
38
|
});
|
@@ -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,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 -->
|
package/example/package.json
CHANGED
@@ -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,18 @@
|
|
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
5
|
repository: string;
|
15
6
|
author: string;
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
disableDocsHook?: boolean;
|
7
|
+
terraformExamples?: {
|
8
|
+
enabled: boolean;
|
9
|
+
folder?: string;
|
10
|
+
providerConfig?: string;
|
11
|
+
};
|
12
|
+
constructExamples?: {
|
13
|
+
enabled: boolean;
|
14
|
+
folder?: string;
|
25
15
|
};
|
26
|
-
additionalPrecommitHooks?: Record<string, any>[];
|
27
16
|
projectId?: string;
|
28
17
|
};
|
29
18
|
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:
|
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";
|
@@ -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
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
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  // URL of the repository\n  repository: 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.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        \"__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