1 package trust
2
3 import (
4 "fmt"
5 "testing"
6
7 "github.com/docker/cli/e2e/internal/fixtures"
8 "github.com/docker/cli/internal/test/environment"
9 "gotest.tools/v3/assert"
10 is "gotest.tools/v3/assert/cmp"
11 "gotest.tools/v3/fs"
12 "gotest.tools/v3/icmd"
13 "gotest.tools/v3/skip"
14 )
15
16 const (
17 localImage = "registry:5000/signlocal:v1"
18 signImage = "registry:5000/sign:v1"
19 )
20
21 func TestSignLocalImage(t *testing.T) {
22 skip.If(t, environment.RemoteDaemon())
23
24
25 environment.SkipIfNotPlatform(t, "linux/amd64")
26
27 dir := fixtures.SetupConfigFile(t)
28 defer dir.Remove()
29 icmd.RunCmd(icmd.Command("docker", "pull", fixtures.AlpineImage)).Assert(t, icmd.Success)
30 icmd.RunCommand("docker", "tag", fixtures.AlpineImage, signImage).Assert(t, icmd.Success)
31 result := icmd.RunCmd(
32 icmd.Command("docker", "trust", "sign", signImage),
33 fixtures.WithPassphrase("root_password", "repo_password"),
34 fixtures.WithConfig(dir.Path()), fixtures.WithNotary)
35 result.Assert(t, icmd.Success)
36 assert.Check(t, is.Contains(result.Stdout(), fmt.Sprintf("v1: digest: sha256:%s", fixtures.AlpineSha)))
37 }
38
39 func TestSignWithLocalFlag(t *testing.T) {
40 skip.If(t, environment.RemoteDaemon())
41
42
43 environment.SkipIfNotPlatform(t, "linux/amd64")
44
45 dir := fixtures.SetupConfigFile(t)
46 defer dir.Remove()
47 setupTrustedImageForOverwrite(t, dir)
48 result := icmd.RunCmd(
49 icmd.Command("docker", "trust", "sign", "--local", localImage),
50 fixtures.WithPassphrase("root_password", "repo_password"),
51 fixtures.WithConfig(dir.Path()), fixtures.WithNotary)
52 result.Assert(t, icmd.Success)
53 assert.Check(t, is.Contains(result.Stdout(), fmt.Sprintf("v1: digest: sha256:%s", fixtures.BusyboxSha)))
54 }
55
56 func setupTrustedImageForOverwrite(t *testing.T, dir fs.Dir) {
57 t.Helper()
58 icmd.RunCmd(icmd.Command("docker", "pull", fixtures.AlpineImage)).Assert(t, icmd.Success)
59 icmd.RunCommand("docker", "tag", fixtures.AlpineImage, localImage).Assert(t, icmd.Success)
60 result := icmd.RunCmd(
61 icmd.Command("docker", "-D", "trust", "sign", localImage),
62 fixtures.WithPassphrase("root_password", "repo_password"),
63 fixtures.WithConfig(dir.Path()), fixtures.WithNotary)
64 result.Assert(t, icmd.Success)
65 assert.Check(t, is.Contains(result.Stdout(), fmt.Sprintf("v1: digest: sha256:%s", fixtures.AlpineSha)))
66 icmd.RunCmd(icmd.Command("docker", "pull", fixtures.BusyboxImage)).Assert(t, icmd.Success)
67 icmd.RunCommand("docker", "tag", fixtures.BusyboxImage, localImage).Assert(t, icmd.Success)
68 }
69
View as plain text