From 37647bc60041bde77c1fbd514c6678aec5d3cb50 Mon Sep 17 00:00:00 2001 From: Nick Santos Date: Mon, 15 Jul 2019 18:57:15 -0400 Subject: [PATCH] watch: skip setup if nothing is being watched (#1861) --- pkg/watch/notify_test.go | 12 ++++++++++++ pkg/watch/watcher_darwin.go | 4 ++++ pkg/watch/watcher_naive.go | 4 ++++ 3 files changed, 20 insertions(+) diff --git a/pkg/watch/notify_test.go b/pkg/watch/notify_test.go index 69ff0787a..432247b7e 100644 --- a/pkg/watch/notify_test.go +++ b/pkg/watch/notify_test.go @@ -28,6 +28,14 @@ func TestNoEvents(t *testing.T) { f.assertEvents() } +func TestNoWatches(t *testing.T) { + f := newNotifyFixture(t) + defer f.tearDown() + f.paths = nil + f.rebuildWatcher() + f.assertEvents() +} + func TestEventOrdering(t *testing.T) { f := newNotifyFixture(t) defer f.tearDown() @@ -586,6 +594,10 @@ func (f *notifyFixture) consumeEventsInBackground(ctx context.Context) chan erro } func (f *notifyFixture) fsync() { + if len(f.paths) == 0 { + return + } + syncPathBase := fmt.Sprintf("sync-%d.txt", time.Now().UnixNano()) syncPath := filepath.Join(f.paths[0], syncPathBase) anySyncPath := filepath.Join(f.paths[0], "sync-") diff --git a/pkg/watch/watcher_darwin.go b/pkg/watch/watcher_darwin.go index ae757f1a4..69a5be50a 100644 --- a/pkg/watch/watcher_darwin.go +++ b/pkg/watch/watcher_darwin.go @@ -89,6 +89,10 @@ func (d *darwinNotify) initAdd(name string) { } func (d *darwinNotify) Start() error { + if len(d.stream.Paths) == 0 { + return nil + } + numberOfWatches.Add(int64(len(d.stream.Paths))) d.stream.Start() diff --git a/pkg/watch/watcher_naive.go b/pkg/watch/watcher_naive.go index b543a140a..569b68080 100644 --- a/pkg/watch/watcher_naive.go +++ b/pkg/watch/watcher_naive.go @@ -35,6 +35,10 @@ type naiveNotify struct { } func (d *naiveNotify) Start() error { + if len(d.notifyList) == 0 { + return nil + } + for name := range d.notifyList { fi, err := os.Stat(name) if err != nil && !os.IsNotExist(err) {