From 2256c527669af6910e04b5c717763ff1c89e2f14 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Manuel=20de=20la=20Pe=C3=B1a?= Date: Tue, 19 Jan 2021 20:42:15 +0100 Subject: [PATCH] chore: increase timeout for Ceph (#618) (#622) * chore: simplify sleep parameter, using a Duration * chore: wait longer for Ceph service --- e2e/_suites/metricbeat/metricbeat_test.go | 10 ++++++++-- e2e/elasticsearch.go | 2 +- e2e/utils.go | 17 +++++------------ 3 files changed, 14 insertions(+), 15 deletions(-) diff --git a/e2e/_suites/metricbeat/metricbeat_test.go b/e2e/_suites/metricbeat/metricbeat_test.go index 0e403e4c8b..cb3cc77258 100644 --- a/e2e/_suites/metricbeat/metricbeat_test.go +++ b/e2e/_suites/metricbeat/metricbeat_test.go @@ -314,8 +314,14 @@ func (mts *MetricbeatTestSuite) installedUsingConfiguration(configuration string // runMetricbeatService runs a metricbeat service entity for a service to monitor it func (mts *MetricbeatTestSuite) runMetricbeatService() error { // this is needed because, in general, the target service (apache, mysql, redis) does not have a healthcheck - waitForService := time.Duration(timeoutFactor) * 10 - e2e.Sleep(fmt.Sprintf("%d", waitForService)) + waitForService := time.Duration(timeoutFactor) * 10 * time.Second + if mts.ServiceName == "ceph" { + // see https://github.com/elastic/beats/blob/ef6274d0d1e36308a333cbed69846a1bd63528ae/metricbeat/module/ceph/mgr_osd_tree/mgr_osd_tree_integration_test.go#L35 + // Ceph service needs more time to start up + waitForService = waitForService * 4 + } + + e2e.Sleep(waitForService) serviceManager := services.NewServiceManager() diff --git a/e2e/elasticsearch.go b/e2e/elasticsearch.go index d3791251db..4acd31dfa6 100644 --- a/e2e/elasticsearch.go +++ b/e2e/elasticsearch.go @@ -123,7 +123,7 @@ func RetrySearch(indexName string, esQuery map[string]interface{}, maxAttempts i "retryAttempts": maxAttempts, "retryTimeout": retryTimeout, }).Tracef("Waiting %d seconds for the index to be ready", retryTimeout) - time.Sleep(time.Duration(retryTimeout) * time.Second) + Sleep(time.Duration(retryTimeout) * time.Second) } } diff --git a/e2e/utils.go b/e2e/utils.go index 05b3345b96..350cd708fb 100644 --- a/e2e/utils.go +++ b/e2e/utils.go @@ -13,7 +13,6 @@ import ( "net/http" "os" "path" - "strconv" "strings" "time" @@ -444,20 +443,14 @@ func RandomString(length int) string { return randomStringWithCharset(length, charset) } -// Sleep sleeps a number of seconds, including logs -func Sleep(seconds string) error { +// Sleep sleeps a duration, including logs +func Sleep(duration time.Duration) error { fields := log.Fields{ - "seconds": seconds, + "duration": duration, } - s, err := strconv.Atoi(seconds) - if err != nil { - log.WithFields(fields).Errorf("Cannot convert %s to seconds", seconds) - return err - } - - log.WithFields(fields).Tracef("Waiting %s seconds", seconds) - time.Sleep(time.Duration(s) * time.Second) + log.WithFields(fields).Tracef("Waiting %v", duration) + time.Sleep(duration) return nil }