Allow RebootNow() to wait for disconnection
This commit is contained in:
parent
f24f697a3d
commit
964e1d713e
|
@ -1,6 +1,9 @@
|
||||||
package reach
|
package reach
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"sync"
|
||||||
|
|
||||||
|
"forge.cadoles.com/Pyxis/golang-socketio"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -9,9 +12,21 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
// RebootNow asks the ReachRS module to reboot now
|
// RebootNow asks the ReachRS module to reboot now
|
||||||
func (u *Updater) RebootNow() error {
|
func (u *Updater) RebootNow(waitDisconnect bool) error {
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
|
||||||
|
if waitDisconnect {
|
||||||
|
wg.Add(1)
|
||||||
|
err = u.conn.On(gosocketio.OnDisconnection, func(h *gosocketio.Channel) {
|
||||||
|
u.conn.Off(gosocketio.OnDisconnection)
|
||||||
|
wg.Done()
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrapf(err, "error while binding to '%s' event", gosocketio.OnDisconnection)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
u.logf("sending '%s' event", eventReboot)
|
u.logf("sending '%s' event", eventReboot)
|
||||||
if err = u.conn.Emit(eventReboot, nil); err != nil {
|
if err = u.conn.Emit(eventReboot, nil); err != nil {
|
||||||
|
@ -19,6 +34,10 @@ func (u *Updater) RebootNow() error {
|
||||||
}
|
}
|
||||||
u.logf("'%s' event sent", eventReboot)
|
u.logf("'%s' event sent", eventReboot)
|
||||||
|
|
||||||
|
if waitDisconnect {
|
||||||
|
wg.Wait()
|
||||||
|
}
|
||||||
|
|
||||||
return err
|
return err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ func TestClientReboutNow(t *testing.T) {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := client.RebootNow(); err != nil {
|
if err := client.RebootNow(true); err != nil {
|
||||||
t.Error(err)
|
t.Error(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Reference in New Issue