mirror of
https://github.com/containers/podman
synced 2024-10-19 16:54:07 +00:00
69ac054ae6
- fix the bud podman not using specified --directory as signature storage. - use manifest and image referce to set repo@digest. close #6994 close #6993 Signed-off-by: Qi Wang <qiwan@redhat.com>
63 lines
1.5 KiB
Go
63 lines
1.5 KiB
Go
// +build !remote
|
|
|
|
package integration
|
|
|
|
import (
|
|
"os"
|
|
"os/exec"
|
|
"path/filepath"
|
|
|
|
. "github.com/containers/podman/v2/test/utils"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
)
|
|
|
|
var _ = Describe("Podman image sign", func() {
|
|
var (
|
|
origGNUPGHOME string
|
|
tempdir string
|
|
err error
|
|
podmanTest *PodmanTestIntegration
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
tempdir, err = CreateTempDirInTempDir()
|
|
if err != nil {
|
|
os.Exit(1)
|
|
}
|
|
podmanTest = PodmanTestCreate(tempdir)
|
|
podmanTest.Setup()
|
|
podmanTest.SeedImages()
|
|
|
|
tempGNUPGHOME := filepath.Join(podmanTest.TempDir, "tmpGPG")
|
|
err := os.Mkdir(tempGNUPGHOME, os.ModePerm)
|
|
Expect(err).To(BeNil())
|
|
|
|
origGNUPGHOME = os.Getenv("GNUPGHOME")
|
|
err = os.Setenv("GNUPGHOME", tempGNUPGHOME)
|
|
Expect(err).To(BeNil())
|
|
|
|
})
|
|
|
|
AfterEach(func() {
|
|
podmanTest.Cleanup()
|
|
f := CurrentGinkgoTestDescription()
|
|
processTestResult(f)
|
|
os.Setenv("GNUPGHOME", origGNUPGHOME)
|
|
})
|
|
|
|
It("podman sign image", func() {
|
|
cmd := exec.Command("gpg", "--import", "sign/secret-key.asc")
|
|
err := cmd.Run()
|
|
Expect(err).To(BeNil())
|
|
sigDir := filepath.Join(podmanTest.TempDir, "test-sign")
|
|
err = os.MkdirAll(sigDir, os.ModePerm)
|
|
Expect(err).To(BeNil())
|
|
session := podmanTest.Podman([]string{"image", "sign", "--directory", sigDir, "--sign-by", "foo@bar.com", "docker://library/alpine"})
|
|
session.WaitWithDefaultTimeout()
|
|
Expect(session.ExitCode()).To(Equal(0))
|
|
_, err = os.Stat(filepath.Join(sigDir, "library"))
|
|
Expect(err).To(BeNil())
|
|
})
|
|
})
|