summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-05-19 06:31:25 +0200
committerGitHub <noreply@github.com>2019-05-19 06:31:25 +0200
commitce84c3afdbaad69599a67da80ba3e51f1b91c6ad (patch)
treec32e794337fb3a4ab30c2aa28c186761cb45fd7e
parent00ecbfc1315a62940202574fb45f2ae2f4c48b63 (diff)
parentee3381f8f2471513dd258dcb64568b57ad4e30d5 (diff)
downloadpodman-ce84c3afdbaad69599a67da80ba3e51f1b91c6ad.tar.gz
podman-ce84c3afdbaad69599a67da80ba3e51f1b91c6ad.tar.bz2
podman-ce84c3afdbaad69599a67da80ba3e51f1b91c6ad.zip
Merge pull request #3138 from weirdwiz/env-var
Minor fix splitting env vars in podman-commit
-rw-r--r--libpod/container_commit.go2
-rw-r--r--test/e2e/commit_test.go20
2 files changed, 21 insertions, 1 deletions
diff --git a/libpod/container_commit.go b/libpod/container_commit.go
index ae04f67bb..739fcd80e 100644
--- a/libpod/container_commit.go
+++ b/libpod/container_commit.go
@@ -99,7 +99,7 @@ func (c *Container) Commit(ctx context.Context, destImage string, options Contai
// Should we store the ENV we actually want in the spec separately?
if c.config.Spec.Process != nil {
for _, e := range c.config.Spec.Process.Env {
- splitEnv := strings.Split(e, "=")
+ splitEnv := strings.SplitN(e, "=", 2)
importBuilder.SetEnv(splitEnv[0], splitEnv[1])
}
}
diff --git a/test/e2e/commit_test.go b/test/e2e/commit_test.go
index 3ece4887e..bf20ac999 100644
--- a/test/e2e/commit_test.go
+++ b/test/e2e/commit_test.go
@@ -194,4 +194,24 @@ var _ = Describe("Podman commit", func() {
Expect(r.ExitCode()).To(Equal(0))
})
+ It("podman commit container check env variables", func() {
+ s := podmanTest.Podman([]string{"run", "--name", "test1", "-e", "TEST=1=1-01=9.01", "-it", "alpine", "true"})
+ s.WaitWithDefaultTimeout()
+ Expect(s.ExitCode()).To(Equal(0))
+
+ c := podmanTest.Podman([]string{"commit", "test1", "newimage"})
+ c.WaitWithDefaultTimeout()
+ Expect(c.ExitCode()).To(Equal(0))
+
+ inspect := podmanTest.Podman([]string{"inspect", "newimage"})
+ inspect.WaitWithDefaultTimeout()
+ Expect(inspect.ExitCode()).To(Equal(0))
+ image := inspect.InspectImageJSON()
+
+ envMap := make(map[string]bool)
+ for _, v := range image[0].Config.Env {
+ envMap[v] = true
+ }
+ Expect(envMap["TEST=1=1-01=9.01"]).To(BeTrue())
+ })
})