Skip to content

Contribute

We'd love you to contribute to Otterdog!

Issues

Questions, feature requests and bug reports are all welcome as discussions or issues.

Merge Requests

It should be extremely simple to get started and create a Merge Request.

Unless your change is trivial (typo, docs tweak etc.), please create an issue to discuss the change before creating a pull request.

If you're looking for something to get your teeth into, check out the "help wanted" label on gitlab.

To make contributing as easy and fast as possible, you'll want to run tests and linting locally. Luckily, Otterdog has few dependencies, doesn't require compiling and tests don't need access to databases, etc. Because of this, setting up and running the tests should be very simple.

Prerequisites

You'll need the following prerequisites:

  • Any Python version >= 3.10
  • git
  • make
  • poetry

Installation and setup

Fork the repository on Gitlab and clone your fork locally.

# Clone your fork and cd into the repo directory
git clone https://gitlab.eclipse.org/<your username>/otterdog.git
cd otterdog

# Install poetry
curl -sSL https://install.python-poetry.org | python3 -

# Install dependencies
make init

Check out a new branch and make your changes

Create a new branch for your changes.

# Checkout a new branch and make your changes
git checkout -b my-new-feature-branch
# Make your changes...

Run tests

Run tests locally to make sure everything is working as expected.

# Run tests
make test

Commit and push your changes

Commit your changes, push your branch to Gitlab, and create a pull request.

Please follow the pull request template and fill in as much information as possible. Link to any relevant issues and include a description of your changes.

When your pull request is ready for review, add a comment with the message "please review" and we'll take a look as soon as we can.

Code style and requirements

TODO

Documentation style

Documentation is written in Markdown and built using Material for MkDocs.

Code documentation

When contributing to Pydantic, please make sure that all code is well documented. The following should be documented using properly formatted docstrings:

  • Modules
  • Class definitions
  • Function definitions
  • Module-level variables

Otterdog uses Google-style docstrings formatted according to PEP 257 guidelines. (See Example Google Style Python Docstrings for further examples.)

Where this is a conflict between Google-style docstrings and pydocstyle linting, follow the pydocstyle linting hints.

Class attributes and function arguments should be documented in the format "name: description." When applicable, a return type should be documented with just a description. Types are inferred from the signature.

class Foo:
    """A class docstring.

    Attributes:
        bar: A description of bar. Defaults to "bar".
    """

    bar: str = 'bar'
def bar(self, baz: int) -> str:
    """A function docstring.

    Args:
        baz: A description of `baz`.

    Returns:
        A description of the return value.
    """

    return 'bar'

You may include example code in docstrings. This code should be complete, self-contained, and runnable. Docstring examples are tested using doctest, so make sure they are correct and complete.

Class and instance attributes

Class attributes should be documented in the class docstring.

Instance attributes should be documented as "Args" in the __init__ docstring.