AWS official Blueprints documentation and Wiki
This repository contains common blueprint components, the base blueprint contructs and several public blueprints. Codecatalyst blueprints are available for anyone to develop today. Blueprints are built by a number of teams internally, and this repository only contains the base constructs and a small number of blueprints maintained by the core blueprints team.
Blueprints are code generators used to create and maintain projects in Amazon CodeCatalyst. You can build your own blueprint today by upgrading to the CodeCatalyst Enterprise tier.
Custom blueprints and lifecycle management are generally available to everyone. To build your own blueprint, go to codecatalyst.aws and make sure your space is upgraded to the Enterprise tier. For more information, see Changing your CodeCatalyst billing tier and Getting started with custom blueprints.
See our contribution guidelines and our community Code of Conduct before opening a pull request. CodeCatalyst blueprints want your feedback and bug reports too! Please add them to our github issues for triage by the service team.
To learn more about blueprints, see the wiki. To learn about using blueprints for your CodeCatalyst projects or steps to create a custom blueprint, see the AWS documentation.
In this repository you can find our blueprints SDK, tooling, and several sample blueprints
- Blueprint base and examples:
/packages/blueprints/
- These are some of the blueprints available to you on CodeCatalyst.
- Base blueprint: All blueprints extend this base blueprint.
- Blueprint builder: A blueprint that generates additional blueprints.
- ...
- Blueprint component constructs:
/packages/components/
- These are components used to make working with and generating CodeCatalyst resources easier. See the AWS documentation for detailed API docs on how to use these components in your project.
- Blueprint utility tooling:
packages/utils/
- This tooling contains the blueprints CLI (used to publish blueprints), as well as basic Projen constructs that define the blueprint and component construct codebases.
This section details how to develop in this repository. We recommend you use VSCode. While plugins also exist for vim, many gitignored files might be invisible in vim and can cause disruptive issues. To get an overview of blueprints and what they are, see the Wiki.
Blueprints are TypeScript node modules by default (they don't have to be). Install the node tooling globally. These are requirements for various tooling to work properly and are available from public npm.
brew install nvm # blueprints work with Node 18.x
brew install jq
nvm use
npm install npm@6.14.13 -g # we suggest using npm 6.14.13, v9.7.2 has performance issues
npm install yarn ts-node webpack webpack-cli -g
Pull down this codebase. We recommend making your own fork. For more information, see the contribution guidelines.
git clone <my-fork-codecatalyst-blueprints>
Run these commands to get started building blueprints. The first time set-up may take a few minutes.
cd codecatalyst-blueprints
nvm use
yarn && yarn build
After completing the setup, you can make changes to the repository and test them out yourself.
The easiest way to test a blueprint directly in CodeCatalyst is publishing that blueprint into a space you own. Publishing a blueprint allows you to test a CodeCatalyst blueprint directly in a space. You must be an adminstrator of the target space in order to successfully publish. Your target space must be part of the Enterprise tier as well.
cd packages/blueprints/<blueprint>
yarn blueprint:preview --space my-awesome-space # publishes under a "preview" version tag to 'my-awesome-space'
yarn blueprint:release --space my-awesome-space # publishes normal version to 'my-awesome-space'
yarn blueprint:preview --space my-awesome-space --project my-project # previews blueprint application to an existing project
This will publish a private verision of your blueprint into my-awesome-space
. It will only be available for that space. You may run the command
multiple times to publish to multiple spaces.
The fastest way to test a blueprint is to build it locally. You can do this by invoking the following command:
cd packages/blueprints/<blueprint>
yarn blueprint:synth (--cache) # cache will emulate how the wizard processes the blueprint
yarn blueprint:resynth (--cache)
The yarn blueprint:synth
command will mock generate a new project with a set of options, while yarn blueprint:resynth
command will mock
generate into an existing project or changing options. Each of these commands result in an output bundle being added into the ./synth/
folder for
each mocked wizard configuration under wizard-configuration/*.json
. Each of these JSONs represent a partial set of options to be merged on top of
the defaults.json
when synthesizing.
For a deep dive on blueprint generation, the bundle format, and how to think about lifecycle updates, see the Wiki.
Blueprints are made up of components found under ./packages/components
. These component constructs represent project components (such as a source
repository).
Modify a component:
cd packages/components/<component>
Rebuild the component:
yarn build
To see the changes applied in a blueprint run synth:
cd packages/blueprints/<blueprint>
yarn blueprint:synth
This generates the blueprint in the synth
folder:
packages/blueprints/<blueprint>/synth/
Blueprints support snapshot testing on configurations provided by blueprint authors. Once snapshot testing is enabled and configured, the build/test process will synthesize the given configurations and verify that the synthesized outputs haven't changed from the reference snapshot.
To enable:
- In
.projenrc.ts
, update the input object toProjenBlueprint
with the file(s) you want snapshoted.
{
....
blueprintSnapshotConfiguration: {
snapshotGlobs: ['**', '!environments/**', '!aws-account-to-environment/**'],
},
}
- Resynthesize the blueprint with
yarn projen
. This will create several TypeScript files in your blueprint project. Don't edit these source files, as they're maintained and regenerated by Projen. - Find the directory
src/wizard-configurations
, where you'll find the filedefault-config.json
with an empty object. Customize or replace this file with one or more of your own test configurations. Each test configurations will be merged with the project'sdefaults.json
, synthesized, and compared to snapshots duringyarn test
.
To run: yarn test
or yarn test:update
or any task that includes test. The first time you run it, expect to see the following lines:
Snapshot Summary › NN snapshots written from 1 test suite.
Subsequent test runs will verify that synthesized output hasn't changed from these snapshots and display a line like:
Snapshots: NN passed, NN total
If you intentionally change your blueprint to emit different output, then run yarn test:update
to update the reference snapshots.
Snapshots expect synthesized output to be constant from run to run. If your blueprint generates files that vary, you must exclude it from snapshot
testing. Update the blueprintSnapshotConfiguration
object of your ProjenBlueprint
input object to add the snapshotGlobs
property. This property
is an array of globs that determine which files to include and exclude from snapshotting. Note that
there is a default list of globs; if you specify your own list, you may need to explicitly bring back the default entries.