From a361f1e35cfa19b0091c6e9bc0862210c5550581 Mon Sep 17 00:00:00 2001 From: Travis Ralston Date: Sat, 25 Nov 2023 17:03:01 -0700 Subject: [PATCH] Cache internal MMR build until all test suites have been run (#511) --- test/test_internals/deps_mmr.go | 13 +++++++++++++ test/upload_suite_test.go | 4 ++++ 2 files changed, 17 insertions(+) diff --git a/test/test_internals/deps_mmr.go b/test/test_internals/deps_mmr.go index ea537c83..0c321fd2 100644 --- a/test/test_internals/deps_mmr.go +++ b/test/test_internals/deps_mmr.go @@ -10,6 +10,7 @@ import ( "path" "strconv" "strings" + "sync/atomic" "text/template" "github.com/docker/docker/api/types" @@ -41,6 +42,12 @@ type mmrContainer struct { var mmrCachedImage string var mmrCachedContext *os.File +var mmrCachedSuites atomic.Int32 + +func MarkUsingCachedMmrBuild() { + mmrCachedSuites.Add(1) + log.Println("+1 cached build usage") +} func reuseMmrBuild(ctx context.Context) (string, error) { if mmrCachedImage != "" { @@ -188,6 +195,12 @@ func (c *mmrContainer) Logs() (io.ReadCloser, error) { } func TeardownMmrCaches() { + mmrCachedSuites.Add(-1) + if mmrCachedSuites.Load() > 0 { + log.Println("Not cleaning up MMR cached images: image still in use") + return + } + if mmrCachedContext != nil { _ = mmrCachedContext.Close() // ignore errors because testcontainers might have already closed it if err := os.Remove(mmrCachedContext.Name()); err != nil && !os.IsNotExist(err) { diff --git a/test/upload_suite_test.go b/test/upload_suite_test.go index 157192a7..49b8094d 100644 --- a/test/upload_suite_test.go +++ b/test/upload_suite_test.go @@ -18,6 +18,10 @@ import ( "github.com/turt2live/matrix-media-repo/util" ) +func init() { + test_internals.MarkUsingCachedMmrBuild() +} + type UploadTestSuite struct { suite.Suite deps *test_internals.ContainerDeps