From fec2c271c20be882d0aa1658b2f65d0f675a5846 Mon Sep 17 00:00:00 2001 From: Erik Wilson Date: Wed, 22 Apr 2020 09:58:41 -0700 Subject: [PATCH] Check modification time before deploying manifests --- pkg/deploy/controller.go | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/pkg/deploy/controller.go b/pkg/deploy/controller.go index 6b241281f3..785ab5879e 100644 --- a/pkg/deploy/controller.go +++ b/pkg/deploy/controller.go @@ -41,6 +41,7 @@ func WatchFiles(ctx context.Context, apply apply.Apply, addons v1.AddonControlle addons: addons, bases: bases, disables: disables, + modTime: map[string]time.Time{}, } addons.Enqueue("", startKey) @@ -60,6 +61,7 @@ type watcher struct { addons v1.AddonClient bases []string disables map[string]bool + modTime map[string]time.Time } func (w *watcher) start(ctx context.Context) { @@ -84,7 +86,6 @@ func (w *watcher) listFiles(force bool) error { if err := w.listFilesIn(base, force); err != nil { errs = append(errs, err) } - } return merr.NewErrors(errs...) } @@ -124,8 +125,14 @@ func (w *watcher) listFilesIn(base string, force bool) error { if skipFile(files[path].Name(), skips) { continue } + modTime := files[path].ModTime() + if !force && modTime.Equal(w.modTime[path]) { + continue + } if err := w.deploy(path, !force); err != nil { errs = append(errs, errors2.Wrapf(err, "failed to process %s", path)) + } else { + w.modTime[path] = modTime } }