Skip to content

Commit

Permalink
Add section on documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
Ewan Jones committed Nov 1, 2018
1 parent b194274 commit c6166be
Showing 1 changed file with 52 additions and 0 deletions.
52 changes: 52 additions & 0 deletions python.md
Original file line number Diff line number Diff line change
Expand Up @@ -758,3 +758,55 @@ def test_some_longwinded_process(support_client, factory):
```

You get the idea.


## Documentation

### READMEs

Each directory within the domain layer should be modular and intuitive to use. A README can
optionally be placed in the root module directory and should detail specifics such as:

- How is this module laid out?
- How might someone use it?
- What are the use cases?
- How to extend behaviour (e.g. adding a new flow handler)
- Who to contact if you run into errors

### Docstrings

Important classes and modules which are intended to be used throughout the whole codebase
should be well documented. Docstrings are helpful and, if used, should be laid out like the
following:

```
"""
*<Short summary>* (1 line)
* Responsibility
*<More Information>* (5-10 lines)
* How does it interact with the project?
* What depends on it?
* What does it depend on?
* When is it used (when does it need to change)?
* Data structures?
Params:
param1 (<type>): Description of parameter1.
param2 (<type>): Description of parameter2.
Returns (func):
Description of what this function returns
Attributes (class):
attr1 (<type>): Description of attribute1.
attr2 (<type>): Description of attribute2.
Methods (class):
method1 (<type>): Description of method1.
method2 (<type>): Description of method2.
"""
```

Writing documentation helps you think about the structure of the module and how it fits with
the SOLID principles.

0 comments on commit c6166be

Please sign in to comment.