lightning/tests
Adrian Wälchli 97e52619ea
Fix typing in `pl.overrides.data_parallel` (#10796)
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2021-11-29 10:58:23 +01:00
..
accelerators Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
base Deprecate `DistributedType` in favor of `StrategyType` (#10505) 2021-11-15 17:10:08 +00:00
benchmarks Move benchmarks into the test directory (#10614) 2021-11-19 03:07:33 +01:00
callbacks Mark outputs as protected in the evaluation loops (#10781) 2021-11-28 20:09:30 +00:00
checkpointing Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
core Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
deprecated_api Deprecate `DeviceType` in favor of `_AcceleratorType` (#10503) 2021-11-25 16:41:03 +01:00
helpers Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
lite Consolidate state when retrieving sharded state dict in Lite (#10746) 2021-11-27 04:54:45 +00:00
loggers Delete TensorBoardLogger experiment before spawning the processes. (#10777) 2021-11-26 17:07:57 +00:00
loops Mark outputs as protected in the evaluation loops (#10781) 2021-11-28 20:09:30 +00:00
models Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
overrides Fix typing in `pl.overrides.data_parallel` (#10796) 2021-11-29 10:58:23 +01:00
plugins Fix typing in `pl.overrides.data_parallel` (#10796) 2021-11-29 10:58:23 +01:00
profiler Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
trainer Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
tuner Update tests to avoid the deprecated `weights_summary` (#10446) 2021-11-11 18:15:18 +01:00
utilities Fault Tolerant: Add support for fault tolerant dataloader validator (#10465) 2021-11-26 19:33:47 +00:00
README.md CI: add mdformat (#8673) 2021-08-03 18:19:09 +00:00
__init__.py Replace `yapf` with `black` (#7783) 2021-07-26 13:37:35 +02:00
conftest.py Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00
mnode_tests.txt Mnodes (#5020) 2021-02-04 20:55:40 +01:00
standalone_tests.sh Rename special to standalone (#10779) 2021-11-26 17:13:14 +00:00

README.md

PyTorch-Lightning Tests

Most PL tests train a full MNIST model under various trainer conditions (ddp, ddp2+amp, etc...). This provides testing for most combinations of important settings. The tests expect the model to perform to a reasonable degree of testing accuracy to pass.

Running tests

git clone https://github.com/PyTorchLightning/pytorch-lightning
cd pytorch-lightning

# install dev deps
pip install -r requirements/devel.txt

# run tests
py.test -v

To test models that require GPU make sure to run the above command on a GPU machine. The GPU machine must have at least 2 GPUs to run distributed tests.

Note that this setup will not run tests that require specific packages installed such as Horovod, FairScale, NVIDIA/apex, NVIDIA/DALI, etc. You can rely on our CI to make sure all these tests pass.

Running Coverage

Make sure to run coverage on a GPU machine with at least 2 GPUs and NVIDIA apex installed.

cd pytorch-lightning

# generate coverage (coverage is also installed as part of dev dependencies under requirements/devel.txt)
coverage run --source pytorch_lightning -m py.test pytorch_lightning tests examples -v

# print coverage stats
coverage report -m

# exporting results
coverage xml

Building test image

You can build it on your own, note it takes lots of time, be prepared.

git clone <git-repository>
docker image build -t pytorch_lightning:devel-torch1.9 -f dockers/cuda-extras/Dockerfile --build-arg TORCH_VERSION=1.9 .

To build other versions, select different Dockerfile.

docker image list
docker run --rm -it pytorch_lightning:devel-torch1.9 bash
docker image rm pytorch_lightning:devel-torch1.9