Commit a05136a5 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 44348ada
...@@ -26,6 +26,7 @@ import ( ...@@ -26,6 +26,7 @@ import (
"os" "os"
"os/exec" "os/exec"
"testing" "testing"
"time"
"lab.nexedi.com/kirr/neo/go/internal/xtesting" "lab.nexedi.com/kirr/neo/go/internal/xtesting"
"lab.nexedi.com/kirr/neo/go/zodb" "lab.nexedi.com/kirr/neo/go/zodb"
...@@ -42,6 +43,8 @@ type ZEOPySrv struct { ...@@ -42,6 +43,8 @@ type ZEOPySrv struct {
pysrv *exec.Cmd // spawned `runzeo -f fs1path` pysrv *exec.Cmd // spawned `runzeo -f fs1path`
fs1path string fs1path string
cancel func() // to stop pysrv cancel func() // to stop pysrv
done chan struct{} // ready after Wait completes
errExit error // error from Wait
} }
...@@ -50,7 +53,7 @@ func StartZEOPySrv(fs1path string) (_ *ZEOPySrv, err error) { ...@@ -50,7 +53,7 @@ func StartZEOPySrv(fs1path string) (_ *ZEOPySrv, err error) {
ctx, cancel := context.WithCancel(context.Background()) ctx, cancel := context.WithCancel(context.Background())
z := &ZEOPySrv{fs1path: fs1path, cancel: cancel} z := &ZEOPySrv{fs1path: fs1path, cancel: cancel, done: make(chan struct{})}
z.pysrv = exec.CommandContext(ctx, "python", "-m", "ZEO.runzeo", "-f", fs1path, "-a", z.zaddr()) z.pysrv = exec.CommandContext(ctx, "python", "-m", "ZEO.runzeo", "-f", fs1path, "-a", z.zaddr())
z.pysrv.Stdin = nil z.pysrv.Stdin = nil
z.pysrv.Stdout = os.Stdout z.pysrv.Stdout = os.Stdout
...@@ -60,6 +63,37 @@ func StartZEOPySrv(fs1path string) (_ *ZEOPySrv, err error) { ...@@ -60,6 +63,37 @@ func StartZEOPySrv(fs1path string) (_ *ZEOPySrv, err error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
go func() {
z.errExit = z.pysrv.Wait()
close(z.done)
}()
defer func() {
if err != nil {
z.Close()
}
}()
// wait till spawned ZEO is ready to serve clients
for {
select {
default:
case <-z.done:
return nil, z.errExit
}
_, err := os.Stat(z.zaddr())
if err == nil {
break // ZEO socket appeared
}
if os.IsNotExist(err) {
err = nil // not yet
}
if err != nil {
return nil, err
}
time.Sleep(100*time.Millisecond)
}
return z, nil return z, nil
} }
...@@ -73,7 +107,8 @@ func (z *ZEOPySrv) Close() (err error) { ...@@ -73,7 +107,8 @@ func (z *ZEOPySrv) Close() (err error) {
defer xerr.Contextf(&err, "stopzeo %s", z.fs1path) defer xerr.Contextf(&err, "stopzeo %s", z.fs1path)
z.cancel() z.cancel()
err = z.pysrv.Wait() <-z.done
err = z.errExit
if _, ok := err.(*exec.ExitError); ok { if _, ok := err.(*exec.ExitError); ok {
err = nil // ignore exit statue - it is always !0 on kill err = nil // ignore exit statue - it is always !0 on kill
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment