- Environment Setup
- Prerequisites
- Cloning TabPy Repository
- Setting Up Environment
- Unit Tests
- Integration Tests
- Code Coverage
- TabPy in Python Virtual Environment
- Documentation Updates
- TabPy with Swagger
- Code styling
The purpose of this guide is to enable developers of Tabpy to install the project and run it locally.
These are prerequisites for an environment required for a contributor to be able to work on TabPy changes:
- Python 3.6.5:
- To see which version of Python you have installed, run
python --version
.
- To see which version of Python you have installed, run
- git
- TabPy repo:
- Get the latest TabPy repository with
git clone https://github.com/tableau/TabPy.git
- Create a new branch for your changes.
- When changes are ready push them on github and create merge request.
- Get the latest TabPy repository with
-
Open your OS shell.
-
Navigate to the folder in which you would like to save your local TabPy repository.
-
In the command prompt, enter the following commands:
git clone https://github.com/tableau/TabPy.git cd TabPy
Before making any code changes run environment setup script. For Windows run the next command from the repository root folder:
utils\set_env.cmd
and for Linux or Mac the next command from the repository root folder:
source utils/set_env.sh
TabPy has test suites for tabpy-server
and tabpy-tools
components.
To run the unit test use pytest
which you may need to install first
(see https://docs.pytest.org for details):
pytest tests/unit
Check pytest
documentation for how to run individual tests or set of tests.
Integration tests can be executed with the next command:
pytest tests/integration
You can run unit tests to collect code coverage data. To do so run pytest
either for server or tools test, or even combined:
pytest tests --cov=tabpy-server/tabpy_server --cov=tabpy-tools/tabpy_tools --cov-append
It is possible (and recommended) to run TabPy in a virtual environment, more details are on TabPy in Python virtual environment page.
For any process, scripts or API changes documentation needs to be updated accordingly. Please use markdown validation tools like web-basedmarkdownlint or npm markdownlint-cli.
TOC for markdown file is built with markdown-toc:
markdown-toc -i docs/server-startup.md
You can invoke TabPy Server API against running TabPy instance with Swagger:
- Make CORS related changes in TabPy configuration file: update
tabpy-server\state.ini
file in your local repository to have the next settings:
[Service Info]
Access-Control-Allow-Origin = *
Access-Control-Allow-Headers = Origin, X-Requested-with, Content-Type
Access-Control-Allow-Methods = GET, OPTIONS, POST
- Start local instance of TabPy server following TabPy Server Startup Guide.
- Run local copy of Swagger editor with steps provided at https://github.com/swagger-api/swagger-editor.
- Open
misc/TabPy.yml
in Swagger editor. - In case your TabPy server runs not on
localhost:9004
updatehost
value inTabPy.yml
accordingly.
On github repo for merge request pycodestyle
is used to check Python code
against our style conventions. You can run install it and run locally for
file where modifications were made:
pip install pycodestyle
And then run it for file where modifications were made, e.g.:
pycodestyle tabpy-server/server_tests/test_pwd_file.py
For reported errors and warnings either fix them manually or auto-format files with
autopep8
.
To install autopep8
run the next command:
pip install autopep8
And then you can run the tool for a file. In the example below -i
option tells autopep8
to update the file. Without the option it
outputs formated code to console.
autopep8 -i tabpy-server/server_tests/test_pwd_file.py