summaryrefslogtreecommitdiff
path: root/worker.go
diff options
context:
space:
mode:
Diffstat (limited to 'worker.go')
-rw-r--r--worker.go14
1 files changed, 8 insertions, 6 deletions
diff --git a/worker.go b/worker.go
index cc37b69d..a29e514a 100644
--- a/worker.go
+++ b/worker.go
@@ -11,6 +11,7 @@ import (
"strconv"
"strings"
"sync"
+ "time"
)
// Worker - supervised process with api over goridge.Relay.
@@ -19,6 +20,9 @@ type Worker struct {
// can be nil while process is not started.
Pid *int
+ // Created indicates at what time worker has been created.
+ Created time.Time
+
// state holds information about current worker state,
// number of worker executions, last status change time.
// publicly this object is receive-only and protected using Mutex
@@ -26,7 +30,7 @@ type Worker struct {
state *state
// underlying command with associated process, command must be
- // provided to worker from outside in non-started form. Cmd
+ // provided to worker from outside in non-started form. Command
// stdErr direction will be handled by worker to aggregate error message.
cmd *exec.Cmd
@@ -54,6 +58,7 @@ func newWorker(cmd *exec.Cmd) (*Worker, error) {
}
w := &Worker{
+ Created: time.Now(),
cmd: cmd,
err: new(bytes.Buffer),
waitDone: make(chan interface{}),
@@ -134,15 +139,12 @@ func (w *Worker) Stop() error {
}
// Kill kills underlying process, make sure to call Wait() func to gather
-// error log from the stderr. Waits for process completion.
+// error log from the stderr. Does not waits for process completion!
func (w *Worker) Kill() error {
select {
case <-w.waitDone:
return nil
default:
- w.mu.Lock()
- defer w.mu.Unlock()
-
w.state.set(StateInactive)
err := w.cmd.Process.Signal(os.Kill)
@@ -163,7 +165,7 @@ func (w *Worker) Exec(rqs *Payload) (rsp *Payload, err error) {
}
if w.state.Value() != StateReady {
- return nil, fmt.Errorf("worker is not ready (%s)", w.state.Value())
+ return nil, fmt.Errorf("worker is not ready (%s)", w.state.String())
}
w.state.set(StateWorking)