mirror of https://github.com/docker/compose.git
Introduce ergonomic API for handling multiple container events
Signed-off-by: Nikhil Benesch <nikhil.benesch@gmail.com>
This commit is contained in:
parent
5eb314a4ca
commit
ee586e7f1e
|
@ -261,6 +261,14 @@ func getContainerProgressName(container moby.Container) string {
|
|||
return "Container " + getCanonicalContainerName(container)
|
||||
}
|
||||
|
||||
func containerEvents(containers Containers, eventFunc func(string) progress.Event) []progress.Event {
|
||||
events := []progress.Event{}
|
||||
for _, container := range containers {
|
||||
events = append(events, eventFunc(getContainerProgressName(container)))
|
||||
}
|
||||
return events
|
||||
}
|
||||
|
||||
// ServiceConditionRunningOrHealthy is a service condition on statys running or healthy
|
||||
const ServiceConditionRunningOrHealthy = "running_or_healthy"
|
||||
|
||||
|
@ -277,9 +285,7 @@ func (s *composeService) waitDependencies(ctx context.Context, project *types.Pr
|
|||
if err != nil {
|
||||
return err
|
||||
}
|
||||
for _, container := range containers {
|
||||
w.Event(progress.Waiting(getContainerProgressName(container)))
|
||||
}
|
||||
w.Events(containerEvents(containers, progress.Waiting))
|
||||
|
||||
dep, config := dep, config
|
||||
eg.Go(func() error {
|
||||
|
@ -294,9 +300,7 @@ func (s *composeService) waitDependencies(ctx context.Context, project *types.Pr
|
|||
return err
|
||||
}
|
||||
if healthy {
|
||||
for _, container := range containers {
|
||||
w.Event(progress.Healthy(getContainerProgressName(container)))
|
||||
}
|
||||
w.Events(containerEvents(containers, progress.Healthy))
|
||||
return nil
|
||||
}
|
||||
case types.ServiceConditionHealthy:
|
||||
|
@ -305,9 +309,7 @@ func (s *composeService) waitDependencies(ctx context.Context, project *types.Pr
|
|||
return err
|
||||
}
|
||||
if healthy {
|
||||
for _, container := range containers {
|
||||
w.Event(progress.Healthy(getContainerProgressName(container)))
|
||||
}
|
||||
w.Events(containerEvents(containers, progress.Healthy))
|
||||
return nil
|
||||
}
|
||||
case types.ServiceConditionCompletedSuccessfully:
|
||||
|
@ -316,9 +318,7 @@ func (s *composeService) waitDependencies(ctx context.Context, project *types.Pr
|
|||
return err
|
||||
}
|
||||
if exited {
|
||||
for _, container := range containers {
|
||||
w.Event(progress.Exited(getContainerProgressName(container)))
|
||||
}
|
||||
w.Events(containerEvents(containers, progress.Exited))
|
||||
if code != 0 {
|
||||
return fmt.Errorf("service %q didn't completed successfully: exit %d", dep, code)
|
||||
}
|
||||
|
|
|
@ -27,7 +27,10 @@ func (p *noopWriter) Start(ctx context.Context) error {
|
|||
return nil
|
||||
}
|
||||
|
||||
func (p *noopWriter) Event(e Event) {
|
||||
func (p *noopWriter) Event(Event) {
|
||||
}
|
||||
|
||||
func (p *noopWriter) Events([]Event) {
|
||||
}
|
||||
|
||||
func (p *noopWriter) TailMsgf(_ string, _ ...interface{}) {
|
||||
|
|
|
@ -40,6 +40,12 @@ func (p *plainWriter) Event(e Event) {
|
|||
fmt.Fprintln(p.out, e.ID, e.Text, e.StatusText)
|
||||
}
|
||||
|
||||
func (p *plainWriter) Events(events []Event) {
|
||||
for _, e := range events {
|
||||
p.Event(e)
|
||||
}
|
||||
}
|
||||
|
||||
func (p *plainWriter) TailMsgf(m string, args ...interface{}) {
|
||||
fmt.Fprintln(p.out, append([]interface{}{m}, args...)...)
|
||||
}
|
||||
|
|
|
@ -95,6 +95,12 @@ func (w *ttyWriter) Event(e Event) {
|
|||
}
|
||||
}
|
||||
|
||||
func (w *ttyWriter) Events(events []Event) {
|
||||
for _, e := range events {
|
||||
w.Event(e)
|
||||
}
|
||||
}
|
||||
|
||||
func (w *ttyWriter) TailMsgf(msg string, args ...interface{}) {
|
||||
w.mtx.Lock()
|
||||
defer w.mtx.Unlock()
|
||||
|
|
|
@ -31,6 +31,7 @@ type Writer interface {
|
|||
Start(context.Context) error
|
||||
Stop()
|
||||
Event(Event)
|
||||
Events([]Event)
|
||||
TailMsgf(string, ...interface{})
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue