diff options
-rw-r--r-- | libpod/runtime_img.go | 5 | ||||
-rw-r--r-- | test/e2e/load_test.go | 20 |
2 files changed, 24 insertions, 1 deletions
diff --git a/libpod/runtime_img.go b/libpod/runtime_img.go index 8d2c3a1d6..06bd474d6 100644 --- a/libpod/runtime_img.go +++ b/libpod/runtime_img.go @@ -606,7 +606,10 @@ func (r *Runtime) getPullListFromRef(srcRef types.ImageReference, imgName string // supports pulling from docker-archive, oci, and registries if srcRef.Transport().Name() == DockerArchive { - tarSource := tarfile.NewSource(archFile) + tarSource, err := tarfile.NewSourceFromFile(archFile) + if err != nil { + return nil, err + } manifest, err := tarSource.LoadTarManifest() if err != nil { return nil, errors.Errorf("error retrieving manifest.json: %v", err) diff --git a/test/e2e/load_test.go b/test/e2e/load_test.go index e36883b16..e9c2d94ab 100644 --- a/test/e2e/load_test.go +++ b/test/e2e/load_test.go @@ -44,6 +44,26 @@ var _ = Describe("Podman load", func() { Expect(result.ExitCode()).To(Equal(0)) }) + It("podman load compressed tar file", func() { + outfile := filepath.Join(podmanTest.TempDir, "alpine.tar") + + save := podmanTest.Podman([]string{"save", "-o", outfile, ALPINE}) + save.WaitWithDefaultTimeout() + Expect(save.ExitCode()).To(Equal(0)) + + compress := podmanTest.SystemExec("gzip", []string{outfile}) + compress.WaitWithDefaultTimeout() + outfile = outfile + ".gz" + + rmi := podmanTest.Podman([]string{"rmi", ALPINE}) + rmi.WaitWithDefaultTimeout() + Expect(rmi.ExitCode()).To(Equal(0)) + + result := podmanTest.Podman([]string{"load", "-i", outfile}) + result.WaitWithDefaultTimeout() + Expect(result.ExitCode()).To(Equal(0)) + }) + It("podman load oci-archive image", func() { outfile := filepath.Join(podmanTest.TempDir, "alpine.tar") |