## Coding Standards ### Unit Tests We use [PyTest](https://docs.pytest.org/en/latest/) to execute tests. You can install pytest by `pip install pytest`. As some of the tests require initialization of the distributed backend, GPUs are needed to execute these tests. To set up the environment for unit testing, first change your current directory to the root directory of your local ColossalAI repository, then run ```bash pip install -r requirements/requirements-test.txt ``` If you encounter an error telling "Could not find a version that satisfies the requirement fbgemm-gpu==0.2.0", please downgrade your python version to 3.8 or 3.9 and try again. If you only want to run CPU tests, you can run ```bash pytest -m cpu tests/ ``` If you have 8 GPUs on your machine, you can run the full test ```bash pytest tests/ ``` If you do not have 8 GPUs on your machine, do not worry. Unit testing will be automatically conducted when you put up a pull request to the main branch. ### Code Style We have some static checks when you commit your code change, please make sure you can pass all the tests and make sure the coding style meets our requirements. We use pre-commit hook to make sure the code is aligned with the writing standard. To set up the code style checking, you need to follow the steps below. ```shell # these commands are executed under the Colossal-AI directory pip install pre-commit pre-commit install ``` Code format checking will be automatically executed when you commit your changes.