Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tests are too slow #340

Open
Luthaf opened this issue Sep 23, 2024 · 2 comments · May be fixed by #430
Open

Tests are too slow #340

Luthaf opened this issue Sep 23, 2024 · 2 comments · May be fixed by #430
Labels
Priority: Medium Important issues to address after high priority.

Comments

@Luthaf
Copy link
Member

Luthaf commented Sep 23, 2024

Running the full test suite already takes more than 90s, which is long enough to get distracted between tests runs. Ideally we should cut these down to enable faster development!

Here is a list of 20 slowest tests: tox -e tests -- --durations=20

47.99s call     tests/cli/test_train_model.py::test_train_issue_290
20.10s call     tests/cli/test_train_model.py::test_train_explicit_validation_test[True-True-2]
18.95s call     tests/cli/test_train_model.py::test_continue_different_dataset
18.35s call     tests/cli/test_train_model.py::test_empty_test_set
18.15s call     tests/cli/test_train_model.py::test_train[None]
17.69s call     tests/cli/test_train_model.py::test_model_consistency_with_seed[None]
16.96s call     tests/cli/test_train_model.py::test_train_explicit_validation_test[True-True-1]
15.92s call     tests/cli/test_train_model.py::test_train_multiple_datasets
14.87s call     tests/cli/test_train_model.py::test_continue
14.32s call     tests/cli/test_eval_model.py::test_eval_multi_dataset
13.99s call     tests/cli/test_train_model.py::test_train_explicit_validation_test[False-False-2]
13.20s call     tests/cli/test_eval_model.py::test_eval_no_targets
12.74s call     tests/cli/test_train_model.py::test_command_line_override[architecture.training.num_epochs=2]
12.56s call     tests/cli/test_train_model.py::test_train[mymodel.pt]
11.99s call     tests/cli/test_train_model.py::test_model_consistency_with_seed[1234]
11.96s call     tests/cli/test_train_model.py::test_train_from_options_restart_yaml
11.89s call     tests/cli/test_eval_model.py::test_eval_cli
9.54s call     tests/cli/test_eval_model.py::test_eval_export
9.45s call     tests/cli/test_train_model.py::test_train_explicit_validation_test[True-False-2]
9.39s call     tests/cli/test_train_model.py::test_command_line_override[architecture.training.num_epochs=2 architecture.training.batch_size=3]

Ideally, no single test should take longer than 5s. If needed, we could add a new dummy architecture which is only used for tests (maybe just a CompositionModel).

@Luthaf Luthaf added the Priority: Medium Important issues to address after high priority. label Sep 23, 2024
@PicoCentauri
Copy link
Contributor

Yes, I agree. A good dummy model could be composition plus ZBL!

@frostedoyster
Copy link
Collaborator

A few observations:

  • torch.cuda.is_available() can take between 1 and 2 seconds on my laptop and it's being called at every training run
  • training and evaluation are slowed down by the fact that training is done with a batch size of 2 (should be changed) while evaluation is done with a batch size of 1 (can be changed after Add batch size for evaluation #417)
  • the test for issue Dataset split fails #290 is too long, it should be simplified
  • SOAP-BPNN is slow-ish, let's make the hypers smaller

@frostedoyster frostedoyster linked a pull request Dec 16, 2024 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Priority: Medium Important issues to address after high priority.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants