From a6f3926f99004b9ae3dadef1e67c741a3382e041 Mon Sep 17 00:00:00 2001 From: Justin Pattarukuzhyil Jose Date: Wed, 13 Jul 2022 13:46:21 +0100 Subject: [PATCH] use time.NewTimer instead of time.After() --- event/producer_test.go | 16 ++++++++++++++-- handler/handler_test.go | 32 ++++++++++++++++++++++++++++---- 2 files changed, 42 insertions(+), 6 deletions(-) diff --git a/event/producer_test.go b/event/producer_test.go index 09317e0..c6e2f1b 100644 --- a/event/producer_test.go +++ b/event/producer_test.go @@ -93,10 +93,16 @@ func TestProducer_SearchDataImport(t *testing.T) { var avroBytes []byte var testTimeout = time.Second * 5 + delay := time.NewTimer(testTimeout) select { case avroBytes = <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.Fatalf("failing test due to timing out after %v seconds", testTimeout) t.FailNow() } @@ -180,10 +186,16 @@ func TestProducer_SearchDatasetVersionMetadataImport(t *testing.T) { var avroBytes []byte var testTimeout = time.Second * 5 + delay := time.NewTimer(testTimeout) select { case avroBytes = <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.Fatalf("failing test due to timing out after %v seconds", testTimeout) t.FailNow() } diff --git a/handler/handler_test.go b/handler/handler_test.go index 6d56f7f..657adf0 100644 --- a/handler/handler_test.go +++ b/handler/handler_test.go @@ -134,10 +134,16 @@ func TestHandlerForZebedeeReturningMandatoryFields(t *testing.T) { }) var avroBytes []byte + delay := time.NewTimer(testTimeout) select { case avroBytes = <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.FailNow() } Convey("And then the expected bytes are sent to producer.output", func() { @@ -172,10 +178,16 @@ func TestHandlerForZebedeeReturningMandatoryFields(t *testing.T) { So(len(datasetMock.GetVersionMetadataCalls()), ShouldEqual, 0) }) + delay := time.NewTimer(testTimeout) select { case <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.FailNow() } }) @@ -246,10 +258,16 @@ func TestHandlerForZebedeeReturningAllFields(t *testing.T) { err := eventHandler.Handle(ctx, &testZebedeeEvent, *cfg) var avroBytes []byte + delay := time.NewTimer(testTimeout) select { case avroBytes = <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.FailNow() } Convey("Then no error is reported", func() { @@ -327,10 +345,16 @@ func TestHandlerForDatasetVersionMetadata(t *testing.T) { err := eventHandler.Handle(ctx, &testDatasetEvent, *cfg) var avroBytes []byte + delay := time.NewTimer(testTimeout) select { case avroBytes = <-pChannels.Output: + // Ensure timer is stopped and its resources are freed + if !delay.Stop() { + // if the timer has been stopped then read from the channel + <-delay.C + } t.Log("avro byte sent to producer output") - case <-time.After(testTimeout): + case <-delay.C: t.FailNow() }