From 4ad1243fb72f187be315374ce0baaac5dbb74632 Mon Sep 17 00:00:00 2001 From: "agent-platform-auto-pr[bot]" <153269286+agent-platform-auto-pr[bot]@users.noreply.github.com> Date: Thu, 31 Oct 2024 18:04:27 +0000 Subject: [PATCH] [Backport 7.58.x] discovery: Allow delta for create time check (#30664) Co-authored-by: vitkyrka --- .../servicediscovery/module/impl_linux_test.go | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/pkg/collector/corechecks/servicediscovery/module/impl_linux_test.go b/pkg/collector/corechecks/servicediscovery/module/impl_linux_test.go index ba93cf883c9336..38d7564ac8ceb8 100644 --- a/pkg/collector/corechecks/servicediscovery/module/impl_linux_test.go +++ b/pkg/collector/corechecks/servicediscovery/module/impl_linux_test.go @@ -551,7 +551,19 @@ func assertStat(t assert.TestingT, svc model.Service) { return } - assert.Equal(t, uint64(createTimeMs/1000), svc.StartTimeSecs) + // The value returned by proc.CreateTime() can vary between invocations + // since the BootTime (used internally in proc.CreateTime()) can vary when + // the version of BootTimeWithContext which uses /proc/uptime is active in + // gopsutil (either on Docker, or even outside of it due to a bug fixed in + // v4.24.8: + // https://github.com/shirou/gopsutil/commit/aa0b73dc6d5669de5bc9483c0655b1f9446317a9). + // + // This is due to an inherent race since the code in BootTimeWithContext + // substracts the uptime of the host from the current time, and there can be + // in theory an unbounded amount of time between the read of /proc/uptime + // and the retrieval of the current time. Allow a 10 second diff as a + // reasonable value. + assert.InDelta(t, uint64(createTimeMs/1000), svc.StartTimeSecs, 10) } func assertCPU(t *testing.T, url string, pid int) {