Files
opensearch-pyd/DEVELOPER_GUIDE.md
T

45 lines
1.7 KiB
Markdown
Raw Normal View History

- [Developer Guide](#developer-guide)
- [Linter and Test Suite](#linter-and-test-suite)
- [Integration Tests](#integration-tests)
- [Build the Documentation with Sphinx](#build-the-documentation-with-sphinx)
2022-01-19 21:44:52 +01:00
# Developer Guide
## Linter and Test Suite
2021-08-31 19:42:26 +05:30
Run the linter and test suite to ensure your changes do not break existing code:
```
# Install Nox for task management
$ python -m pip install nox
# Auto-format and lint your changes
$ nox -rs format
# Run the test suite
$ nox -rs test
```
2022-01-19 21:44:52 +01:00
## Integration Tests
2021-08-31 19:42:26 +05:30
To run the integration tests locally, run:
```
./.ci/run-tests opensearch true 1.3.0
2021-08-31 19:42:26 +05:30
```
The first argument, `opensearch` tells the server type to run integration test against. Valid values are `opensearch` and `opendistro`.
The second argument tells whether to run server with security plugin enabled or not.
The third argument specifies the version of OpenSearch the tests should run against, if not specified, the tests run against the latest version. This argument is ignored if the server type is `opendistro`.
2021-08-31 19:42:26 +05:30
Note that integration tests require docker to be installed and running, and downloads quite a bit of data from over the internet and hence take few minutes to complete.
2022-01-19 21:44:52 +01:00
## Build the Documentation with Sphinx
This are the steps to build the documentation with [Sphinx](https://www.sphinx-doc.org/):
1. change into the `opensearch-py` directory where `setup.py` is located
2022-02-08 19:53:26 +01:00
2. install opensearch-py - we recommend [editable mode](https://pip.pypa.io/en/stable/cli/pip_install/#cmdoption-e
- with bash: `pip install -e .[docs]`
- with zsh: `pip install -e .\[docs]`
4. change into the `docs` directory
5. execute `make html`
6. use your favorite web browser to open the file called `opensearch-py/docs/build/html/index.html`