From bb7b0aad0eb7874c97911d8a27532100f1a32232 Mon Sep 17 00:00:00 2001 From: Qi Wang Date: Thu, 23 May 2019 14:30:02 -0400 Subject: fix bug dest path of copying tar when podman cp tar without --extract flag, if the destination already exists, or ends with path seprator, cp the tar under the directory, otherwise copy the tar named with the destination Signed-off-by: Qi Wang --- test/e2e/cp_test.go | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'test') diff --git a/test/e2e/cp_test.go b/test/e2e/cp_test.go index 1dfa8f50d..16e03472e 100644 --- a/test/e2e/cp_test.go +++ b/test/e2e/cp_test.go @@ -143,4 +143,31 @@ var _ = Describe("Podman cp", func() { os.Remove("file.tar.gz") os.RemoveAll(testDirPath) }) + + It("podman cp tar", func() { + path, err := os.Getwd() + Expect(err).To(BeNil()) + testDirPath := filepath.Join(path, "TestDir") + err = os.Mkdir(testDirPath, 0777) + Expect(err).To(BeNil()) + cmd := exec.Command("tar", "-cvf", "file.tar", testDirPath) + _, err = cmd.Output() + Expect(err).To(BeNil()) + + session := podmanTest.Podman([]string{"create", "--name", "testctr", ALPINE, "ls", "-l", "foo"}) + session.WaitWithDefaultTimeout() + Expect(session.ExitCode()).To(Equal(0)) + + session = podmanTest.Podman([]string{"cp", "file.tar", "testctr:/foo/"}) + session.WaitWithDefaultTimeout() + Expect(session.ExitCode()).To(Equal(0)) + + session = podmanTest.Podman([]string{"start", "-a", "testctr"}) + session.WaitWithDefaultTimeout() + Expect(session.ExitCode()).To(Equal(0)) + Expect(session.OutputToString()).To(ContainSubstring("file.tar")) + + os.Remove("file.tar") + os.RemoveAll(testDirPath) + }) }) -- cgit v1.2.3-54-g00ecf