From f99747e63f734d0c1128931fb989b849e37649ca Mon Sep 17 00:00:00 2001 From: mitchell Date: Fri, 30 Aug 2024 12:24:45 -0400 Subject: [PATCH] Prevent concurrency errors with envdef loading. --- pkg/runtime/internal/envdef/collection.go | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/pkg/runtime/internal/envdef/collection.go b/pkg/runtime/internal/envdef/collection.go index c260217821..3801ff4ba7 100644 --- a/pkg/runtime/internal/envdef/collection.go +++ b/pkg/runtime/internal/envdef/collection.go @@ -26,10 +26,6 @@ func New() *Collection { } func (c *Collection) Load(path string) (*EnvironmentDefinition, error) { - if envDef, ok := c.raw.EnvDefs[path]; ok { - return envDef, nil - } - envDef, err := NewEnvironmentDefinition(filepath.Join(path, EnvironmentDefinitionFilename)) if err != nil { return nil, errs.Wrap(err, "Failed to initialize environment definition") @@ -44,14 +40,14 @@ func (c *Collection) Load(path string) (*EnvironmentDefinition, error) { } func (c *Collection) Unload(path string) error { + // Prevent concurrent reads and writes + c.mutex.Lock() + defer c.mutex.Unlock() + if _, ok := c.raw.EnvDefs[path]; !ok { return errs.New("Environment definition not found for path: %s", path) } - // Prevent concurrent writes - c.mutex.Lock() - defer c.mutex.Unlock() - delete(c.raw.EnvDefs, path) return nil