Merge pull request #1370 from crosbymichael/daemon-lock
Defer unlock for testing daemon
This commit is contained in:
commit
89daacfe3f
@ -60,7 +60,7 @@ func (d *daemon) waitForStart(ctx context.Context) (*Client, error) {
|
|||||||
|
|
||||||
func (d *daemon) Stop() error {
|
func (d *daemon) Stop() error {
|
||||||
d.Lock()
|
d.Lock()
|
||||||
d.Unlock()
|
defer d.Unlock()
|
||||||
if d.cmd == nil {
|
if d.cmd == nil {
|
||||||
return errors.New("daemon is not running")
|
return errors.New("daemon is not running")
|
||||||
}
|
}
|
||||||
@ -69,7 +69,7 @@ func (d *daemon) Stop() error {
|
|||||||
|
|
||||||
func (d *daemon) Kill() error {
|
func (d *daemon) Kill() error {
|
||||||
d.Lock()
|
d.Lock()
|
||||||
d.Unlock()
|
defer d.Unlock()
|
||||||
if d.cmd == nil {
|
if d.cmd == nil {
|
||||||
return errors.New("daemon is not running")
|
return errors.New("daemon is not running")
|
||||||
}
|
}
|
||||||
@ -78,7 +78,7 @@ func (d *daemon) Kill() error {
|
|||||||
|
|
||||||
func (d *daemon) Wait() error {
|
func (d *daemon) Wait() error {
|
||||||
d.Lock()
|
d.Lock()
|
||||||
d.Unlock()
|
defer d.Unlock()
|
||||||
if d.cmd == nil {
|
if d.cmd == nil {
|
||||||
return errors.New("daemon is not running")
|
return errors.New("daemon is not running")
|
||||||
}
|
}
|
||||||
@ -87,7 +87,7 @@ func (d *daemon) Wait() error {
|
|||||||
|
|
||||||
func (d *daemon) Restart() error {
|
func (d *daemon) Restart() error {
|
||||||
d.Lock()
|
d.Lock()
|
||||||
d.Unlock()
|
defer d.Unlock()
|
||||||
if d.cmd == nil {
|
if d.cmd == nil {
|
||||||
return errors.New("daemon is not running")
|
return errors.New("daemon is not running")
|
||||||
}
|
}
|
||||||
|
10
io_unix.go
10
io_unix.go
@ -36,6 +36,7 @@ func copyIO(fifos *FIFOSet, ioset *ioSet, tty bool) (_ *wgCloser, err error) {
|
|||||||
var (
|
var (
|
||||||
f io.ReadWriteCloser
|
f io.ReadWriteCloser
|
||||||
set []io.Closer
|
set []io.Closer
|
||||||
|
cwg sync.WaitGroup
|
||||||
ctx, cancel = context.WithCancel(context.Background())
|
ctx, cancel = context.WithCancel(context.Background())
|
||||||
wg = &sync.WaitGroup{}
|
wg = &sync.WaitGroup{}
|
||||||
)
|
)
|
||||||
@ -52,9 +53,13 @@ func copyIO(fifos *FIFOSet, ioset *ioSet, tty bool) (_ *wgCloser, err error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
set = append(set, f)
|
set = append(set, f)
|
||||||
|
cwg.Add(1)
|
||||||
|
wg.Add(1)
|
||||||
go func(w io.WriteCloser) {
|
go func(w io.WriteCloser) {
|
||||||
|
cwg.Done()
|
||||||
io.Copy(w, ioset.in)
|
io.Copy(w, ioset.in)
|
||||||
w.Close()
|
w.Close()
|
||||||
|
wg.Done()
|
||||||
}(f)
|
}(f)
|
||||||
|
|
||||||
if f, err = fifo.OpenFifo(ctx, fifos.Out, syscall.O_RDONLY|syscall.O_CREAT|syscall.O_NONBLOCK, 0700); err != nil {
|
if f, err = fifo.OpenFifo(ctx, fifos.Out, syscall.O_RDONLY|syscall.O_CREAT|syscall.O_NONBLOCK, 0700); err != nil {
|
||||||
@ -62,7 +67,9 @@ func copyIO(fifos *FIFOSet, ioset *ioSet, tty bool) (_ *wgCloser, err error) {
|
|||||||
}
|
}
|
||||||
set = append(set, f)
|
set = append(set, f)
|
||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
|
cwg.Add(1)
|
||||||
go func(r io.ReadCloser) {
|
go func(r io.ReadCloser) {
|
||||||
|
cwg.Done()
|
||||||
io.Copy(ioset.out, r)
|
io.Copy(ioset.out, r)
|
||||||
r.Close()
|
r.Close()
|
||||||
wg.Done()
|
wg.Done()
|
||||||
@ -75,12 +82,15 @@ func copyIO(fifos *FIFOSet, ioset *ioSet, tty bool) (_ *wgCloser, err error) {
|
|||||||
|
|
||||||
if !tty {
|
if !tty {
|
||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
|
cwg.Add(1)
|
||||||
go func(r io.ReadCloser) {
|
go func(r io.ReadCloser) {
|
||||||
|
cwg.Done()
|
||||||
io.Copy(ioset.err, r)
|
io.Copy(ioset.err, r)
|
||||||
r.Close()
|
r.Close()
|
||||||
wg.Done()
|
wg.Done()
|
||||||
}(f)
|
}(f)
|
||||||
}
|
}
|
||||||
|
cwg.Wait()
|
||||||
return &wgCloser{
|
return &wgCloser{
|
||||||
wg: wg,
|
wg: wg,
|
||||||
dir: fifos.Dir,
|
dir: fifos.Dir,
|
||||||
|
Loading…
Reference in New Issue
Block a user