Add support for services on ps command

Signed-off-by: Ulysses Souza <ulyssessouza@gmail.com>
This commit is contained in:
Ulysses Souza 2021-05-03 19:59:07 -03:00
parent de8834d434
commit 36d6c40e52
3 changed files with 7 additions and 5 deletions

View File

@ -268,7 +268,8 @@ type ListOptions struct {
// PsOptions group options of the Ps API
type PsOptions struct {
All bool
All bool
Services []string
}
// PortPublisher hold status about published port

View File

@ -47,7 +47,7 @@ func psCommand(p *projectOptions, backend compose.Service) *cobra.Command {
Use: "ps",
Short: "List containers",
RunE: Adapt(func(ctx context.Context, args []string) error {
return runPs(ctx, backend, opts)
return runPs(ctx, backend, args, opts)
}),
}
psCmd.Flags().StringVar(&opts.Format, "format", "pretty", "Format the output. Values: [pretty | json].")
@ -57,13 +57,14 @@ func psCommand(p *projectOptions, backend compose.Service) *cobra.Command {
return psCmd
}
func runPs(ctx context.Context, backend compose.Service, opts psOptions) error {
func runPs(ctx context.Context, backend compose.Service, services []string, opts psOptions) error {
projectName, err := opts.toProjectName()
if err != nil {
return err
}
containers, err := backend.Ps(ctx, projectName, compose.PsOptions{
All: opts.All,
All: opts.All,
Services: services,
})
if err != nil {
return err

View File

@ -26,7 +26,7 @@ import (
)
func (s *composeService) Ps(ctx context.Context, projectName string, options compose.PsOptions) ([]compose.ContainerSummary, error) {
containers, err := s.getContainers(ctx, projectName, oneOffInclude, options.All)
containers, err := s.getContainers(ctx, projectName, oneOffInclude, options.All, options.Services...)
if err != nil {
return nil, err
}