Skip to content

Latest commit

 

History

History
executable file
·
148 lines (104 loc) · 6.21 KB

DEVELOPMENT_GUIDE.rst

File metadata and controls

executable file
·
148 lines (104 loc) · 6.21 KB

DEVELOPMENT GUIDE

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.

Environment Setup

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.

1. Install Python Versions

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

  1. Install PyEnv - curl -L https://github.com/pyenv/pyenv-installer/raw/master/bin/pyenv-installer | bash
  2. pyenv install 2.7.14
  3. Make the Python version available in the project: pyenv local 2.7.14

2. Install Additional Tooling

Black

We format our code using Black and verify the source code is black compliant in Appveyor during PRs. Black will be installed automatically with make init.

After installing, you can run our formatting through our Makefile by make black or integrating Black directly in your favorite IDE (instructions can be found here)

(workaround) Integrating Black directly in your favorite IDE

Since black is installed in virtualenv, when you follow this instruction, which black might give you this

(samtranslator37) $ where black
/Users/<username>/.pyenv/shims/black

However, IDEs such as PyCharm (using FileWatcher) will have a hard time invoking /Users/<username>/.pyenv/shims/black and this will happen:

pyenv: black: command not found

The `black' command exists in these Python versions:
  3.7.2/envs/samtranslator37
  samtranslator37

A simple workaround is to use /Users/<username>/.pyenv/versions/samtranslator37/bin/black instead of /Users/<username>/.pyenv/shims/black.

Pre-commit

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.

3. Activate Virtualenv

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.

  1. Create new virtualenv if it does not exist: pyenv virtualenv 2.7.14 samtranslator27
  2. pyenv activate samtranslator27
  3. [Optional] Automatically activate the virtualenv in for this folder: pyenv local samtranslator27

4. Install dependencies

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

Running Tests

Unit tests

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.

Pull Requests

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.

Profiling

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

Verifying transforms

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