chia-blockchain/tests
Almog De Paz f85bc15d4b
setup services refactor (#13905)
* always return service

* adjust setup_simulators_and_wallets

* adjust setup_simulators_and_wallets

* refactor setup_simulators_and_wallets
add setup_simulators_and_wallets_service

* revert unneeded change

* fix broken fixtures

* lint, fix data_rpc init_wallet_and_node

* fix two_wallet_nodes fixture

* fix two_nodes_sim_and_wallets_services fixture

* fix one_wallet_node_and_rpc fixture

* lint
2022-11-16 20:40:03 -06:00
..
blockchain Refactor test utils for import availability outside of repo (#13880) 2022-11-15 18:51:05 -06:00
clvm configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
core Make WSChiaConnection a dataclass (#13906) 2022-11-16 13:38:28 -06:00
db add a transactional reader as DBWrapper2.reader() (#13468) 2022-09-30 17:41:33 -05:00
farmer_harvester configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
fee_estimation Don't hold removals twice in mempool items as they're already part of the underlying spend bundle. (#13694) 2022-11-01 15:41:23 -05:00
generator configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
plot_sync server: Enable and fix mypy in ws_connection.py (#13878) 2022-11-12 14:18:11 -06:00
plotting configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
pools setup services refactor (#13905) 2022-11-16 20:40:03 -06:00
simulation setup services refactor (#13905) 2022-11-16 20:40:03 -06:00
tools configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
util Refactor test utils for import availability outside of repo (#13880) 2022-11-15 18:51:05 -06:00
wallet catch up test_complex_nft_offer() with return type change (#13926) 2022-11-16 10:41:49 -06:00
weight_proof configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
__init__.py Added tests, improved serialization 2019-08-05 14:38:16 +09:00
build-init-files.py Merge commit with main (9ff3fc993f) (#11137) 2022-04-14 12:02:42 -07:00
build-job-matrix.py configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
check_pytest_monitor_output.py configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
check_sql_statements.py configure isort to add the future annotations import (#13327) 2022-09-30 03:40:22 -05:00
chia-start-sim Rename src to chia. 2021-04-04 21:41:39 -07:00
conftest.py setup services refactor (#13905) 2022-11-16 20:40:03 -06:00
connection_utils.py Make WSChiaConnection a dataclass (#13906) 2022-11-16 13:38:28 -06:00
README.md Improve style consistency in root directory docs files (#4493) 2021-05-12 13:12:30 -07:00
testconfig.py reusable workflow for a single test workflow (#11722) 2022-06-03 16:56:52 -05:00

Test CI Job generation

The CI jobs for these tests are managed by build-workflows.py.

If you add a test file, or move one to another directory, please run build-workflows.py. Tests are recognized by the file glob test_*.py. Changing the contents of a file does not require running build-workflows.py.

We currently use github actions. Default runners have two vcpus. The workflows are located in ../.github/workflows/.

The inputs to build-workflows.py are the templates in runner-templates, the file testconfig.py in this directory, and the optional config.py files in some test subdirectories. Files in the template directory ending in include.yml are included in jobs based on the per-directory settings.

The generated workflows are output to ../.github/workflows/.

Each subdirectory below the directories root_test_dirs in testconfig.py becomes a job in the github workflow matrix. If your jobs run too long, simply move some tests into new subdirectories and run build-workflows.py. A workflow built from a parent directory does not include the tests in its subdirectories. The subdirectory jobs do not include the tests from their parents.

testconfig.py

In the top tests directory, testconfig.py contains the application settings and the per-directory default settings.

config.py

Each directory has an optional config.py file, which can override the per-directory default settings.

Per directory settings defaults:

parallel = False
checkout_blocks_and_plots = True
install_timelord = True
job_timeout = 30

Parallel test execution

If you are certain that all the tests in a directory can run in parallel, set parallel = True in config.py inside that directory.

Optional job stages

Set checkout_blocks_and_plots to False to omit checking out the test-cache repo.

Set install_timelord to False to omit the step of installing a Time Lord for your directory's job.

Job Timeout

Set job_timeout to the number of minutes you want the CI system to wait before it kills your job. Add two or three minutes to allow for job setup.