- Environment Setup
- Prerequisites
- Cloning TabPy Repository
- Tests
- Code Coverage
- TabPy in Python Virtual Environment
- Documentation Updates
- TabPy with Swagger
- Code styling
- Publishing TabPy Package
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
- PIP packages - install all with
pip install pytest pycodestyle autopep8 twine coverage --upgrade
command - Node.js for npm packages - install from https://nodejs.org.
- NPM packages - install all with
npm install markdown-toc markdownlint
command.
-
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
-
Register TabPy repo as a pip package:
pip install -e .
-
Install all dependencies:
python setup.py install
To run the whole test suite execute the following command:
pytest
Unit tests suite can be executed with the following command:
pytest tests/unit
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-based markdownlint or npm markdownlint-cli.
TOC for markdown file is built with markdown-toc:
markdown-toc -i docs/server-startup.md
To check markdown style for all the documentation use markdownlint
:
markdownlint .
These checks will run as part of the build if you submit a pull request.
You can invoke the TabPy Server API against a running TabPy instance with Swagger.
- Make CORS related changes in TabPy configuration file: update
tabpy/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 a local instance of TabPy server following TabPy Server Startup Guide.
- Run a 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 does not run on
localhost:9004
updatehost
value inTabPy.yml
accordingly.
pycodestyle
is used to check Python code against our style conventions:
pycodestyle .
For reported errors and warnings either fix them manually or auto-format files with
autopep8
.
Run the tool for a file. In the example below -i
option tells autopep8
to update the file. Without the option it
outputs formatted code to the console.
autopep8 -i tabpy-server/server_tests/test_pwd_file.py
Execute the following commands to build and publish a new version of TabPy package:
python setup.py sdist bdist_wheel
python -m twine upload dist/*
To publish test version of the package use the following command:
python -m twine upload --repository-url https://test.pypi.org/legacy/ dist/*
To install package from TestPyPi use the command:
pip install -i https://test.pypi.org/simple/ tabpy