From 037bac458c421f7a3ecfe15a5101df12a1417df7 Mon Sep 17 00:00:00 2001 From: Matthew Heon Date: Fri, 24 Aug 2018 17:39:37 -0400 Subject: [PATCH 1/2] Fix handling of multiple filters in podman ps Docker expects multiple filters to be passed with multiple uses of the --filter flag (e.g. --filter=label=a=b --filter=label=c=d) and not a single comma-separated list of filters as we expected. Convert to the Docker format, and make some small cleanups to our handling of filters along the way. Signed-off-by: Matthew Heon --- cmd/podman/ps.go | 9 ++++----- cmd/podman/shared/container.go | 1 - test/e2e/ps_test.go | 19 +++++++++++++++++++ 3 files changed, 23 insertions(+), 6 deletions(-) diff --git a/cmd/podman/ps.go b/cmd/podman/ps.go index 82309c2ef8..0b59b24b75 100644 --- a/cmd/podman/ps.go +++ b/cmd/podman/ps.go @@ -134,7 +134,7 @@ var ( Name: "all, a", Usage: "Show all the containers, default is only running containers", }, - cli.StringFlag{ + cli.StringSliceFlag{ Name: "filter, f", Usage: "Filter output based on conditions given", }, @@ -222,7 +222,6 @@ func psCmd(c *cli.Context) error { opts := shared.PsOptions{ All: c.Bool("all"), - Filter: c.String("filter"), Format: format, Last: c.Int("last"), Latest: c.Bool("latest"), @@ -246,8 +245,8 @@ func psCmd(c *cli.Context) error { }) } - if opts.Filter != "" { - filters := strings.Split(opts.Filter, ",") + filters := c.StringSlice("filter") + if len(filters) > 0 { for _, f := range filters { filterSplit := strings.SplitN(f, "=", 2) if len(filterSplit) < 2 { @@ -317,7 +316,7 @@ func generateContainerFilterFuncs(filter, filterValue string, runtime *libpod.Ru return strings.Contains(c.ID(), filterValue) }, nil case "label": - var filterArray []string = strings.Split(filterValue, "=") + var filterArray []string = strings.SplitN(filterValue, "=", 2) var filterKey string = filterArray[0] if len(filterArray) > 1 { filterValue = filterArray[1] diff --git a/cmd/podman/shared/container.go b/cmd/podman/shared/container.go index 7a54550460..f44d0f7c93 100644 --- a/cmd/podman/shared/container.go +++ b/cmd/podman/shared/container.go @@ -20,7 +20,6 @@ import ( // PsOptions describes the struct being formed for ps type PsOptions struct { All bool - Filter string Format string Last int Latest bool diff --git a/test/e2e/ps_test.go b/test/e2e/ps_test.go index f5d79193b8..a873b57bba 100644 --- a/test/e2e/ps_test.go +++ b/test/e2e/ps_test.go @@ -181,6 +181,25 @@ var _ = Describe("Podman ps", func() { Expect(result.OutputToStringArray()[0]).To(Equal(fullCid)) }) + It("podman ps multiple filters", func() { + session := podmanTest.Podman([]string{"run", "-d", "--name", "test1", "--label", "key1=value1", ALPINE, "top"}) + session.WaitWithDefaultTimeout() + Expect(session.ExitCode()).To(Equal(0)) + fullCid := session.OutputToString() + + session2 := podmanTest.Podman([]string{"run", "-d", "--name", "test2", "--label", "key1=value1", ALPINE, "top"}) + session2.WaitWithDefaultTimeout() + Expect(session2.ExitCode()).To(Equal(0)) + + result := podmanTest.Podman([]string{"ps", "-aq", "--no-trunc", "--filter", "name=test1", "--filter", "label=key1=value1"}) + result.WaitWithDefaultTimeout() + Expect(result.ExitCode()).To(Equal(0)) + + output := result.OutputToStringArray() + Expect(len(output)).To(Equal(1)) + Expect(output[0]).To(Equal(fullCid)) + }) + It("podman ps mutually exclusive flags", func() { session := podmanTest.Podman([]string{"ps", "-aqs"}) session.WaitWithDefaultTimeout() From 9c5f809863be8b53b0f7ebcdf4e159932a2247a3 Mon Sep 17 00:00:00 2001 From: Matthew Heon Date: Mon, 27 Aug 2018 09:14:19 -0400 Subject: [PATCH 2/2] Fix manpage to note how multiple filters are combined Signed-off-by: Matthew Heon --- docs/podman-ps.1.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/podman-ps.1.md b/docs/podman-ps.1.md index 72bb69ca6a..a8a2b8700e 100644 --- a/docs/podman-ps.1.md +++ b/docs/podman-ps.1.md @@ -81,7 +81,9 @@ Display namespace information **--filter, -f** -Filter output based on conditions given +Filter what containers are shown in the output. +Multiple filters can be given with multiple uses of the --filter flag. +If multiple filters are given, only containers which match all of the given filters will be shown. Valid filters are listed below: