Welcome hacker!
This document will make your life easier by helping you setup a development environment, IDEs, tests, coding practices, or anything that will help you be more productive. If you found something is missing or inaccurate, update this guide and send a Pull Request.
Note
You need to have pyenv installed, please see the installation instructions for more information.
make setup
will perform the following steps for you. You can either run make setup
command or perform the
steps manually.
Our officially supported Python versions are 2.7, 3.6, 3.7 and 3.8. Follow the idioms from this excellent cheatsheet to make sure your code is compatible with both Python 2.7 and 3 versions.
Setup Python locally using pyenv
- Install PyEnv -
curl -L https://github.com/pyenv/pyenv-installer/raw/master/bin/pyenv-installer | bash
pyenv install 2.7.14
- Make the Python version available in the project:
pyenv local 2.7.14
We format our code using Black and verify the source code is black compliant in Appveyor during PRs. You can find installation instructions on Black's docs.
After installing, you can check your formatting through our Makefile by running make black-check. To automatically update your code to match our formatting, please run make black. You can also integrate Black directly in your favorite IDE (instructions can be found here)
If you don't wish to manually run black on each pr or install black manually, we have integrated black into git hooks through pre-commit. After installing pre-commit, run pre-commit install in the root of the project. This will install black for you and run the black formatting on commit.
Virtualenv allows you to install required libraries outside of the Python installation. A good practice is to setup a different virtualenv for each project. pyenv comes with a handy plugin that can create virtualenv.
- Create new virtualenv if it does not exist:
pyenv virtualenv 2.7.14 samtranslator27
pyenv activate samtranslator27
- [Optional] Automatically activate the virtualenv in for this folder:
pyenv local samtranslator27
Install dependencies by running the following command. Make sure the Virtualenv you created above is active.
pip install -r requirements/base.txt -r requirements/dev.txt
make test
command will run all unit tests. This command is configured to fail when code coverage for package
drops below 95%.
pytest -k "TestMyClass"
command will run all unit tests within the TestMyClass class.
Before sending pull requests make sure to run make pr
command. This will run unit tests, linters, and static
analysis tools to verify that your code changes follow the coding standards required by this package.
It will also fail if unit test coverage drops below 95%. All new code that you write must have 100% unit test coverage. This might sound over-ambitious, especially if you come from Java world, but with Python this is actually realistic. In Python, if you do not test a piece of code, there is zero confidence that the code will ever work in the future. Tests are also a documentation of the success and failure cases, which is crucial when refactoring code in future.
Install snakeviz pip install snakeviz
python -m cProfile -o sam_profile_results bin/sam-translate.py translate --template-file=tests/translator/input/alexa_skill.yaml --output-template=cfn-template.json
snakeviz sam_profile_results
If you make changes to the transformer and want to verify the resulting CloudFormation template works as expected, you can transform your SAM template into a CloudFormation template using the following process:
# Optional: You only need to run the package command in certain cases; e.g. when your CodeUri specifies a local path
# Replace MY_TEMPLATE_PATH with the path to your template and MY_S3_BUCKET with an existing S3 bucket
aws cloudformation package --template-file MY_TEMPLATE_PATH/template.yaml --output-template-file output-template.yaml --s3-bucket MY_S3_BUCKET
# Transform your SAM template into a CloudFormation template
# Replace "output-template.yaml" if you didn't run the package command above or specified a different path for --output-template-file
bin/sam-translate.py --template-file=output-template.yaml
# Deploy your transformed CloudFormation template
# Replace MY_STACK_NAME with a unique name each time you deploy
aws cloudformation deploy --template-file cfn-template.json --capabilities CAPABILITY_NAMED_IAM --stack-name MY_STACK_NAME