Developer documentation
This document was created to help you set up your development environment and to understand the project structure.
Setting up the development environment
Step 1: (Optional) Install SeaGOAT
This step is recommended in order to make sure that SeaGOAT works properly on your computer.
Follow the official documentation
Step 2: Make sure you have all developer dependencies installed
The following dependencies need to be installed:
- Git
- Python 3.11 or newer
- Poetry (how to install)
Step 3: Clone the repository
Use Git to clone the repository:
Step 4: Run poetry install
Poetry is used to manage dependencies in this project. Poetry also manages virtualenvs automatically.
If you have Poetry installed correctly, automatically setting up a virtualenv and installing all dependencies is as easy as running:
Step 5: Run tests
To make sure that your development environment was set up correctly, run tests:
If all tests pass, you have set up your development environment correctly.
Step 6: (Optional) Set up pre-commit hooks
There are several tools in use in SeaGOAT to make sure that code is ready to merge. Some of these tools will automatically fix issues with the code, such as reformatting the code to enforce code style. Other tools will merely point out issues before you commit your code.
It is recommended to set up pre-commit hooks so that these checks are executed automatically. You can do so by running this command:
If you do not wish to use pre-commit hooks, you can still execute all checks manually by running:
Developing SeaGOAT
Automated testing
Automated testing is done using pytest
. Here are some example use cases:
Watch mode
Automatically runs tests for all files when you save your changes:
Test changed files
Test all files
Snapshot testing
Snapshot testing is used in a few test cases. You can update snapshots by running
Manual testing
In order to test your local changes to SeaGOAT manually, you can prefix
the command by poetry run
. For example to run your local
version of seagoat-server
, just run:
Similarly, to run your local version of gt
/seagoat
, you can run:
You can run an ipython
in the correct virtualenv also by prefixing it
with poetry run
:
Automatic checks (linting) and automatic formatting
This repository uses pre-commit
to run automatic checks and fixes on the
codebase in addition to automatic and manual testing.
If you have set up commit hooks (recommended), then these checks and fixes are automatically executed each time you attempt to make a commit.
If you don't like commit hooks, or if you want to run the checks for all files, not just changed files then you can run the following command:
Contributing to SeaGOAT
Welcome to SeaGOAT!
We value your contributions and ask you to please adhere to our Code of Conduct and follow these brief guidelines.
Getting Started
- Follow the guide on how set up the development environment
- Look for issues labeled
up for grabs
orgood first issue
as starting points. - Report bugs or suggest enhancements by
creating an issue
with the
bug
orenhancement
label.
Contribution Process
- Fork & Create a Branch: Fork the repo and create a branch with a descriptive name in your fork.
- Develop & Test Changes: Make and test your changes, adhering to existing coding standards. If you have configured your development environment correctly, automated tools will help you with this.
- Submit a Pull Request:
Open a Pull Request
targeting the
main
branch of the original repo. - Address Review Comments: After you submitted a pull request, it will be reviewed by a maintainer as soon as possible. In order to make sure your changes get merged, you have to address any comments in your pull request until it is finally approved. After your changes are approved and merged, they will be released automatically if there are any user facing changes.
By contributing to SeaGOAT you agree to release your contributions under the same license SeaGOAT is licensed to, including future relicensing or double licensing of the codebase