From 3ef9a88f03ea1002d7874e7f2b0b0ebccb294752 Mon Sep 17 00:00:00 2001 From: Adam Babik Date: Thu, 31 Aug 2017 12:53:45 +0200 Subject: [PATCH] add and move conditions in StopNode --- geth/node/manager.go | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/geth/node/manager.go b/geth/node/manager.go index 1ffc845c959..0e4c9d3be74 100644 --- a/geth/node/manager.go +++ b/geth/node/manager.go @@ -136,17 +136,20 @@ func (m *NodeManager) StopNode() (<-chan struct{}, error) { m.Lock() defer m.Unlock() - return m.stopNode() -} - -// stopNode stop Status node. Stopped node cannot be resumed. -func (m *NodeManager) stopNode() (<-chan struct{}, error) { if err := m.isNodeAvailable(); err != nil { return nil, err } + if m.nodeStopped == nil { + return nil, ErrNoRunningNode + } <-m.nodeStarted // make sure you operate on fully started node + return m.stopNode() +} + +// stopNode stop Status node. Stopped node cannot be resumed. +func (m *NodeManager) stopNode() (<-chan struct{}, error) { // now attempt to stop if err := m.node.Stop(); err != nil { return nil, err