Want to help improve SST? Thank you! Take a second to review this document before you get started.
To be sure that you are not working on something that's already being worked on, make sure to either:
- Open a new issue about it
- Or join us on Discord and send us a message
In this section we'll talk about the workflow we recommend while working on SST. It's based on how we work internally, but catered specifically for our community contributors. For more context on how we work, you can check out this document.
When assigned an issue, the first step is to get all the details and seek any necessary clarification. If the issue was brought up by a user, make sure you fully understand the requirement from the user. Contact the user on Discord or ask them on GitHub. Or, contact a member from the core team that opened the issue.
Next, do the necessary research. Draft a plan for the implementation; the cases that need to be tested; and the docs required to be updated.
Here is an example of a spec in action:
- Research: How is it currently done in other popular frameworks, ie. Create React App.
- Implement: Add an eslint section in the
package.json
to allow users to specify a list of linting packages. - Implement: Update the
create-sst
template to prefill thepackage.json
with SST's default linting package. - Test: Add a test with SST's default linting package and check the
no-unused-vars
rule is enforced. - Test: Add a test with custom linting packages and check that the
no-unused-vars
rule is not enforced. - Doc: Document the default linting package in "Working Locally" doc.
- Doc: Show an example of customizing linting packages.
Then, add the spec to the GitHub issue. It's necessary to come up with this list before working on the task. This gives the core team a chance to propose changes. And, a good spec is one where it can be handed to anyone on the team. That person is then able to follow through and complete the implementation.
If the solution isn’t obvious or is a bigger design change, get the core team involved. Before the group discussion, come up with a proposed solution. More on this here.
The core team then reviews the spec.
Create a Pull Request. Inform the core team upon completion. And the core team will review the PR and merge it.
Here's how to run SST locally.
To run this project locally, clone the repo and initialize the project.
$ git clone https://github.com/serverless-stack/sst.git
$ cd serverless-stack
$ yarn
Build the project
$ yarn build
If you are working on the packages/core
part, run the watcher at the root.
$ yarn watch
If you are working on the packages/resources
part, run the watcher at the root.
$ yarn watch
And if you make changes to the stub Lambdas, you'll need to package them.
$ cd packages/resources
$ yarn build
Finally, after making your changes, run all the tests in the packages/resources
directory.
$ yarn test
Alternatively, you can run the tests for a specific construct.
$ yarn test <path_to_the_test_for_the_construct>
If you are working on the packages/cli
just go ahead and make your changes. Then run your tests.
$ cd packages/cli
$ yarn test
Alternatively, you can run a specific test.
$ yarn test <path_to_the_test_dir>
To run the docs site.
$ cd www
$ yarn start
Make sure to add your changes as a pull request. Start by forking the repo. Then make your changes and submit a PR.
- Use a descriptive name for the PR
- With the format, "[Construct/package name]: [Description]"
- For example, "Api: Add support for HTTP proxy routes"
- Pick a label for the PR from:
breaking
: These are for breaking changesbug
: Bug fixesenhancement
: New featuresdocumentation
: Improvements to the docs or examplesskip changelog
: Don't mention this in the release notes
If you are submitting the PR for the first time, we'll need to approve it to run the tests.
To cut a release, start by merging the PRs that are going into this release.
-
Generate changelog
$ yarn changelog
You'll need to configure the
GITHUB_AUTH
token locally to be able to run this. Follow these steps and configure the local environment variable. -
Publish a release to npm
To publish the release to npm run:
$ yarn release
Pick the version you want (patch/minor/major). This is based on the type of changes in the changelog above.
breaking
and majorenhancement
changes are a minor version updatebug
and minorenhancement
changes are a patch version update
We are not currently updating the major version until our 1.0 release.
Verify that only the 5 core packages (
core
,cli
,resources
,create-sst
,static-site-env
) are getting published.Confirm and publish!
-
Draft a new release
Copy the changelog that was generated above and draft a new release.
Make necessary edits to the changelog to make it more readable and helpful.
- For
breaking
changes, add a message at the top clearly documenting the change (example). - For major
enhancement
changes, add a code snippet on how to use the feature (example).
Add this snippet at the bottom of the changelog and replace it with the version that's going to be released.
--- Update using: ```sh $ npm install --save --save-exact @serverless-stack/[email protected] @serverless-stack/[email protected] ```
- For
-
Publish GitHub release
In the Tag version of the release draft, select the version that was just published to npm.
Copy-paste that version as the Release title. And hit Publish release.
Optionally, you can publish a canary release to npm.
This is useful if you'd like to test your release before pushing it live.
Create a canary release by running.
$ yarn release-canary
Follow the checklist below when deprecating a Construct property or method.
-
Docs: Label the old property name (or method) as deprecated.
oldProp (deprecated)
-
Docs: Add migration instructions under the old property (or method):
`oldProp` has been renamed to `newProp` in v0.46.0. If you are configuring the `oldProp` like so: ```js new Table(this, "Table", { ... oldProp: "value", } ``` Change it to: ```js new Table(this, "Table", { ... newProp: "value", } ```
-
Construct code: Decorate the old property (or method) as deprecated.
/** * @deprecated Use newProp */
-
Construct code: Ensure the old property (or method) will continue to work.
-
Construct code: Print a warning in verbose mode if the old property (or method) is used.
WARNING: The "oldProp" property has been renamed to "newProp". "oldProp" will continue to work but will be removed at a later date. More details on the deprecation - https://docs.sst.dev/constructs/Table#secondaryindexes-deprecated
-
Construct tests: Ensure tests added for both the old and the new property (or method).
See the Table
construct for a deprecation example of renaming secondaryIndexes
to globalIndexes
.
Help us improve this doc. If you've had a chance to contribute to SST, feel free to edit this doc and submit a PR.