mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-05 13:20:47 -06:00
Merge topic 'ctest-timeout-report' into release-3.17
7fda917fa4 CTest: Fix reported duration on timeout when grindchild keeps pipes open
Acked-by: Kitware Robot <kwrobot@kitware.com>
Merge-request: !4530
This commit is contained in:
@@ -249,7 +249,7 @@ void cmProcess::OnRead(ssize_t nread, const uv_buf_t* buf)
|
||||
this->PipeReader.reset();
|
||||
if (this->ProcessHandleClosed) {
|
||||
uv_timer_stop(this->Timer);
|
||||
this->Runner.FinalizeTest();
|
||||
this->Finish();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -291,7 +291,7 @@ void cmProcess::OnTimeout()
|
||||
// Our on-exit handler already ran but did not finish the test
|
||||
// because we were still reading output. We've just dropped
|
||||
// our read handler, so we need to finish the test now.
|
||||
this->Runner.FinalizeTest();
|
||||
this->Finish();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -321,6 +321,16 @@ void cmProcess::OnExit(int64_t exit_status, int term_signal)
|
||||
// Record exit information.
|
||||
this->ExitValue = exit_status;
|
||||
this->Signal = term_signal;
|
||||
|
||||
this->ProcessHandleClosed = true;
|
||||
if (this->ReadHandleClosed) {
|
||||
uv_timer_stop(this->Timer);
|
||||
this->Finish();
|
||||
}
|
||||
}
|
||||
|
||||
void cmProcess::Finish()
|
||||
{
|
||||
this->TotalTime = std::chrono::steady_clock::now() - this->StartTime;
|
||||
// Because of a processor clock scew the runtime may become slightly
|
||||
// negative. If someone changed the system clock while the process was
|
||||
@@ -329,12 +339,7 @@ void cmProcess::OnExit(int64_t exit_status, int term_signal)
|
||||
if (this->TotalTime <= cmDuration::zero()) {
|
||||
this->TotalTime = cmDuration::zero();
|
||||
}
|
||||
|
||||
this->ProcessHandleClosed = true;
|
||||
if (this->ReadHandleClosed) {
|
||||
uv_timer_stop(this->Timer);
|
||||
this->Runner.FinalizeTest();
|
||||
}
|
||||
this->Runner.FinalizeTest();
|
||||
}
|
||||
|
||||
cmProcess::State cmProcess::GetProcessStatus()
|
||||
|
||||
@@ -101,6 +101,7 @@ private:
|
||||
void OnAllocate(size_t suggested_size, uv_buf_t* buf);
|
||||
|
||||
void StartTimer();
|
||||
void Finish();
|
||||
|
||||
class Buffer : public std::vector<char>
|
||||
{
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
Test project [^
|
||||
]*/Tests/RunCMake/CTestTimeout/Basic-build
|
||||
Start 1: TestTimeout
|
||||
1/1 Test #1: TestTimeout ......................\*\*\*Timeout +[0-9.]+ sec
|
||||
1/1 Test #1: TestTimeout ......................\*\*\*Timeout +[1-9][0-9.]* sec
|
||||
+
|
||||
0% tests passed, 1 tests failed out of 1
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
Test project [^
|
||||
]*/Tests/RunCMake/CTestTimeout/Fork-build
|
||||
Start 1: TestTimeout
|
||||
1/1 Test #1: TestTimeout ......................\*\*\*Timeout +[0-9.]+ sec
|
||||
1/1 Test #1: TestTimeout ......................\*\*\*Timeout +[1-9][0-9.]* sec
|
||||
+
|
||||
0% tests passed, 1 tests failed out of 1
|
||||
|
||||
Reference in New Issue
Block a user