mirror of https://github.com/containers/podman.git
				
				
				
			fix bug in podman images list all images with same name
Signed-off-by: Qi Wang <qiwan@redhat.com>
This commit is contained in:
		
							parent
							
								
									614409f644
								
							
						
					
					
						commit
						15971689e8
					
				|  | @ -2,6 +2,7 @@ package main | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"fmt" | ||||||
| 	"reflect" | 	"reflect" | ||||||
| 	"sort" | 	"sort" | ||||||
| 	"strings" | 	"strings" | ||||||
|  | @ -127,7 +128,7 @@ func init() { | ||||||
| func imagesCmd(c *cliconfig.ImagesValues) error { | func imagesCmd(c *cliconfig.ImagesValues) error { | ||||||
| 	var ( | 	var ( | ||||||
| 		filterFuncs []imagefilters.ResultFilter | 		filterFuncs []imagefilters.ResultFilter | ||||||
| 		newImage    *adapter.ContainerImage | 		image       string | ||||||
| 	) | 	) | ||||||
| 
 | 
 | ||||||
| 	runtime, err := adapter.GetRuntime(&c.PodmanCommand) | 	runtime, err := adapter.GetRuntime(&c.PodmanCommand) | ||||||
|  | @ -136,23 +137,23 @@ func imagesCmd(c *cliconfig.ImagesValues) error { | ||||||
| 	} | 	} | ||||||
| 	defer runtime.Shutdown(false) | 	defer runtime.Shutdown(false) | ||||||
| 	if len(c.InputArgs) == 1 { | 	if len(c.InputArgs) == 1 { | ||||||
| 		newImage, err = runtime.NewImageFromLocal(c.InputArgs[0]) | 		image = c.InputArgs[0] | ||||||
| 		if err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	if len(c.InputArgs) > 1 { | 	if len(c.InputArgs) > 1 { | ||||||
| 		return errors.New("'podman images' requires at most 1 argument") | 		return errors.New("'podman images' requires at most 1 argument") | ||||||
| 	} | 	} | ||||||
| 
 | 	if len(c.Filter) > 0 && image != "" { | ||||||
|  | 		return errors.New("can not specify an image and a filter") | ||||||
|  | 	} | ||||||
| 	ctx := getContext() | 	ctx := getContext() | ||||||
| 
 | 
 | ||||||
| 	if len(c.Filter) > 0 || newImage != nil { | 	if len(c.Filter) > 0 { | ||||||
| 		filterFuncs, err = CreateFilterFuncs(ctx, runtime, c.Filter, newImage) | 		filterFuncs, err = CreateFilterFuncs(ctx, runtime, c.Filter, nil) | ||||||
| 		if err != nil { | 	} else { | ||||||
| 			return err | 		filterFuncs, err = CreateFilterFuncs(ctx, runtime, []string{fmt.Sprintf("reference=%s", image)}, nil) | ||||||
| 		} | 	} | ||||||
|  | 	if err != nil { | ||||||
|  | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	opts := imagesOptions{ | 	opts := imagesOptions{ | ||||||
|  | @ -173,7 +174,7 @@ func imagesCmd(c *cliconfig.ImagesValues) error { | ||||||
| 
 | 
 | ||||||
| 	var filteredImages []*adapter.ContainerImage | 	var filteredImages []*adapter.ContainerImage | ||||||
| 	//filter the images
 | 	//filter the images
 | ||||||
| 	if len(c.Filter) > 0 || newImage != nil { | 	if len(c.Filter) > 0 || len(c.InputArgs) == 1 { | ||||||
| 		filteredImages = imagefilters.FilterImages(images, filterFuncs) | 		filteredImages = imagefilters.FilterImages(images, filterFuncs) | ||||||
| 	} else { | 	} else { | ||||||
| 		filteredImages = images | 		filteredImages = images | ||||||
|  |  | ||||||
|  | @ -112,6 +112,18 @@ var _ = Describe("Podman images", func() { | ||||||
| 		session.WaitWithDefaultTimeout() | 		session.WaitWithDefaultTimeout() | ||||||
| 		Expect(session.ExitCode()).To(Equal(0)) | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
| 		Expect(len(session.OutputToStringArray())).To(Equal(1)) | 		Expect(len(session.OutputToStringArray())).To(Equal(1)) | ||||||
|  | 
 | ||||||
|  | 		session = podmanTest.Podman([]string{"tag", ALPINE, "foo:a"}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 		session = podmanTest.Podman([]string{"tag", BB, "foo:b"}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 
 | ||||||
|  | 		session = podmanTest.Podman([]string{"images", "-q", "foo"}) | ||||||
|  | 		session.WaitWithDefaultTimeout() | ||||||
|  | 		Expect(session.ExitCode()).To(Equal(0)) | ||||||
|  | 		Expect(len(session.OutputToStringArray())).To(Equal(2)) | ||||||
| 	}) | 	}) | ||||||
| 
 | 
 | ||||||
| 	It("podman images filter reference", func() { | 	It("podman images filter reference", func() { | ||||||
|  |  | ||||||
|  | @ -190,7 +190,7 @@ var _ = Describe("Podman load", func() { | ||||||
| 		load.WaitWithDefaultTimeout() | 		load.WaitWithDefaultTimeout() | ||||||
| 		Expect(load.ExitCode()).To(Equal(0)) | 		Expect(load.ExitCode()).To(Equal(0)) | ||||||
| 
 | 
 | ||||||
| 		result := podmanTest.Podman([]string{"images", "-f", "label", "hello:world"}) | 		result := podmanTest.Podman([]string{"images", "hello:world"}) | ||||||
| 		result.WaitWithDefaultTimeout() | 		result.WaitWithDefaultTimeout() | ||||||
| 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | ||||||
| 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | ||||||
|  | @ -216,7 +216,7 @@ var _ = Describe("Podman load", func() { | ||||||
| 		load.WaitWithDefaultTimeout() | 		load.WaitWithDefaultTimeout() | ||||||
| 		Expect(load.ExitCode()).To(Equal(0)) | 		Expect(load.ExitCode()).To(Equal(0)) | ||||||
| 
 | 
 | ||||||
| 		result := podmanTest.Podman([]string{"images", "-f", "label", "hello:latest"}) | 		result := podmanTest.Podman([]string{"images", "hello:latest"}) | ||||||
| 		result.WaitWithDefaultTimeout() | 		result.WaitWithDefaultTimeout() | ||||||
| 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | ||||||
| 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | ||||||
|  | @ -241,7 +241,7 @@ var _ = Describe("Podman load", func() { | ||||||
| 		load.WaitWithDefaultTimeout() | 		load.WaitWithDefaultTimeout() | ||||||
| 		Expect(load.ExitCode()).To(Equal(0)) | 		Expect(load.ExitCode()).To(Equal(0)) | ||||||
| 
 | 
 | ||||||
| 		result := podmanTest.Podman([]string{"images", "-f", "label", "load:latest"}) | 		result := podmanTest.Podman([]string{"images", "load:latest"}) | ||||||
| 		result.WaitWithDefaultTimeout() | 		result.WaitWithDefaultTimeout() | ||||||
| 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | 		Expect(result.LineInOutputContains("docker")).To(Not(BeTrue())) | ||||||
| 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | 		Expect(result.LineInOutputContains("localhost")).To(BeTrue()) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue