lightning/tests/README.md

64 lines
1.5 KiB
Markdown
Raw Normal View History

2019-08-01 14:11:26 +00:00
# PyTorch-Lightning Tests
2019-07-24 14:09:47 +00:00
## Running tests
2019-07-25 01:31:43 +00:00
The automatic travis tests ONLY run CPU-based tests. Although these cover most of the use cases,
run on a 2-GPU machine to validate the full test-suite.
2019-07-24 14:09:47 +00:00
To run all tests do the following:
```bash
git clone https://github.com/williamFalcon/pytorch-lightning
cd pytorch-lightning
# install module locally
pip install -e .
# install dev deps
pip install -r requirements.txt
# run tests
2019-08-07 12:32:32 +00:00
py.test -v
2019-07-24 14:09:47 +00:00
```
To test models that require GPU make sure to run the above command on a GPU machine.
The GPU machine must have:
1. At least 2 GPUs.
2. [NVIDIA-apex](https://github.com/NVIDIA/apex#linux) installed.
### test_models.py
This file fits a tiny model on MNIST using these different set-ups.
1. CPU only.
2. Single GPU with DP.
3. Multiple (2) GPUs using DP.
3. Multiple (2) GPUs using DDP.
3. Multiple (2) GPUs using DP + apex (for 16-bit precision).
3. Multiple (2) GPUs using DDP + apex (for 16-bit precision).
2019-07-24 22:16:02 +00:00
For each set up it also tests:
1. model saving.
2. model loading.
3. predicting with a loaded model.
4. simulated save from HPC signal.
5. simulated load from HPC signal.
2019-07-25 01:35:38 +00:00
## Running Coverage
2019-08-06 10:57:31 +00:00
Make sure to run coverage on a GPU machine with at least 2 GPUs and NVIDIA apex installed.
2019-07-25 01:35:38 +00:00
```bash
cd pytorch-lightning
# generate coverage
pip install coverage
2019-08-07 12:32:32 +00:00
coverage run --source pytorch_lightning -m py.test pytorch_lightning tests examples -v --doctest-modules
2019-07-25 01:35:38 +00:00
# print coverage stats
2019-08-07 12:32:32 +00:00
coverage report -m
# exporting resulys
coverage xml
codecov -t 17327163-8cca-4a5d-86c8-ca5f2ef700bc -v
2019-07-25 01:35:38 +00:00
```
2019-07-24 14:09:47 +00:00