diff --git a/command/agent/local.go b/command/agent/local.go index 310b055ab4..3dd8f64717 100644 --- a/command/agent/local.go +++ b/command/agent/local.go @@ -114,7 +114,10 @@ func (l *localState) Pause() { // Resume is used to resume state synchronization func (l *localState) Resume() { - atomic.AddInt32(&l.paused, -1) + paused := atomic.AddInt32(&l.paused, -1) + if paused < 0 { + panic("unbalanced localState.Resume() detected") + } l.changeMade() } diff --git a/command/agent/local_test.go b/command/agent/local_test.go index bc525d2784..47d8f8f3ee 100644 --- a/command/agent/local_test.go +++ b/command/agent/local_test.go @@ -685,6 +685,15 @@ func TestAgent_nestedPauseResume(t *testing.T) { if l.isPaused() != false { t.Fatal("localState should NOT be Paused after SECOND call to Resume()") } + + defer func() { + err := recover() + if err == nil { + t.Fatal("unbalanced Resume() should cause a panic()") + } + }() + l.Resume() + } var testRegisterRules = `