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

Print a completion message when all tests are done #192

Open
wants to merge 11 commits into
base: main
Choose a base branch
from

Conversation

nickrobinson251
Copy link
Collaborator

@nickrobinson251 nickrobinson251 commented Oct 17, 2024

To make it clear when tests are done (in case there's a problem after this point but before we print a test summary).

This is mainly helpful when running with multiple workers, as in that case the last test to finish and print a DONE log may not be the last test-item started, i.e. the final log before all tests are done may be `DONE (33/37) test item ...".

Also adds more @debug logs, for helping diagnose issues after tests are all run.

Before:

julia> runtests("test/testfiles/_happy_tests.jl", nworkers=2)
  Activating project at `~/repos/ReTestItems.jl`
[ Info: Scanning for test items in project `ReTestItems` at paths: test/testfiles/_happy_tests.jl
[ Info: Finished scanning for test items in 0.67 seconds. Scheduling 3 tests on pid 71250 with 2 worker processes and 2 threads per worker.
[ Info: Starting test workers
  Worker 71406:  [ Info: Starting test worker 1 on pid = 71406, with 2 threads
  Worker 71405:  [ Info: Starting test worker 2 on pid = 71405, with 2 threads
[ Info: Starting running test items
  Worker 71406:  12:53:53 | START (1/3) test item "happy 1" at test/testfiles/_happy_tests.jl:1
  Worker 71405:  12:53:53 | START (2/3) test item "happy 2" at test/testfiles/_happy_tests.jl:5
  Worker 71405:  12:53:53 | DONE  (2/3) test item "happy 2" <0.1 secs (90.8% compile), 17.24 K allocs (1.255 MB)
  Worker 71406:  12:53:53 | DONE  (1/3) test item "happy 1" <0.1 secs (91.0% compile), 17.24 K allocs (1.255 MB)
  Worker 71405:  12:53:53 | START (3/3) test item "happy 3" at test/testfiles/_happy_tests.jl:9
  Worker 71405:  12:53:53 | DONE  (3/3) test item "happy 3" <0.1 secs (<0.1% compile), 1.62 K allocs (116.776 KB)
Test Summary:                        | Pass  Total  Time
ReTestItems                          |    3      3  3.2s
  test                               |    3      3
    test/testfiles                   |    3      3
      test/testfiles/_happy_tests.jl |    3      3
        happy 1                      |    1      1  0.0s
        happy 2                      |    1      1  0.0s
        happy 3                      |    1      1  0.0s

Now:

julia> runtests("test/testfiles/_happy_tests.jl", nworkers=2)
  Activating project at `~/repos/ReTestItems.jl`
[ Info: Scanning for test items in project `ReTestItems` at paths: test/testfiles/_happy_tests.jl
[ Info: Finished scanning for test items in 0.67 seconds. Scheduling 3 tests on pid 66797 with 2 worker processes and 2 threads per worker.
[ Info: Starting test workers
  Worker 67159:  [ Info: Starting test worker 2 on pid = 67159, with 2 threads
  Worker 67160:  [ Info: Starting test worker 1 on pid = 67160, with 2 threads
[ Info: Starting running test items
  Worker 67160:  14:27:23 | START (1/3) test item "happy 1" at test/testfiles/_happy_tests.jl:1
  Worker 67159:  14:27:23 | START (2/3) test item "happy 2" at test/testfiles/_happy_tests.jl:5
  Worker 67160:  14:27:23 | DONE  (1/3) test item "happy 1" <0.1 secs (91.5% compile), 17.24 K allocs (1.255 MB)
  Worker 67159:  14:27:23 | DONE  (2/3) test item "happy 2" <0.1 secs (91.1% compile), 17.24 K allocs (1.255 MB)
  Worker 67160:  14:27:23 | START (3/3) test item "happy 3" at test/testfiles/_happy_tests.jl:9
[ Info: All tests on worker 2 completed. Closing Worker(pid=67159).
  Worker 67160:  14:27:23 | DONE  (3/3) test item "happy 3" <0.1 secs (<0.1% compile), 1.62 K allocs (116.776 KB)
[ Info: All tests on worker 1 completed. Closing Worker(pid=67160).
[ Tests Completed: 3/3 test items were run.
Test Summary:                        | Pass  Total  Time
ReTestItems                          |    3      3  3.1s
  test                               |    3      3
    test/testfiles                   |    3      3
      test/testfiles/_happy_tests.jl |    3      3
        happy 1                      |    1      1  0.0s
        happy 2                      |    1      1  0.0s
        happy 3                      |    1      1  0.0s

@nickrobinson251 nickrobinson251 enabled auto-merge (squash) October 17, 2024 16:44
Copy link
Collaborator

@Drvi Drvi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Before I look at the changes here, I wanted to point out that you were right that we're waiting for the workers to terminate -- the @sync block where we @spawn each of the manage-workers tasks will block since we're closing them which waits for the tasks on the worker to finish (in response to it being terminated). This place does feel like a good spot for the hang to happen to me... Maybe we could use a timedwait instead of wait to be on the safer side?

# Print this above the final report as there might have been other logs printed
# since a failfast-cancellation was printed, but print it ASAP after tests finish
# in case any of the recording/reporting steps have an issue.
print_completion_summary(testitems; failedfast=(cfg.failfast && is_cancelled(testitems)))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, so @Drvi this would be maybe too late already, since we hang before shutting down the workers?

Maybe we actually just want a log in manage_worker, here?:

close(worker)

We could basically say

@info "Finished all tests. Closing Worker $workerid."

?

Copy link
Collaborator Author

@nickrobinson251 nickrobinson251 Oct 21, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added. I just added a log for each worker, so they don't have to coordinate to know if they're the last worker to complete, and also because i suppose any of them could be the one to hang here.

@nickrobinson251 nickrobinson251 force-pushed the npr-log-when-all-tests-done branch from c32464f to 0420a84 Compare October 21, 2024 11:47
* Replace LoggingExtras.jl dep with our own debug macro

* Update debug log syntax in tests

* fixup! Replace LoggingExtras.jl dep with our own debug macro

* fixup! Replace LoggingExtras.jl dep with our own debug macro
@nickrobinson251 nickrobinson251 requested review from NHDaly and removed request for NHDaly January 10, 2025 11:26
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants