Skip to content

Commit bccd478

Browse files
authored
Merge pull request #5270 from thaJeztah/27.1_backport_test_spring_cleaning
[27.1] test spring-cleaning
2 parents f90273c + ca9636a commit bccd478

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

87 files changed

+677
-373
lines changed

cli/command/builder/prune_test.go

+3
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@ package builder
33
import (
44
"context"
55
"errors"
6+
"io"
67
"testing"
78

89
"github.com/docker/cli/internal/test"
@@ -19,5 +20,7 @@ func TestBuilderPromptTermination(t *testing.T) {
1920
},
2021
})
2122
cmd := NewPruneCommand(cli)
23+
cmd.SetOut(io.Discard)
24+
cmd.SetErr(io.Discard)
2225
test.TerminatePrompt(ctx, t, cmd, cli)
2326
}

cli/command/checkpoint/create_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ func TestCheckpointCreateErrors(t *testing.T) {
4242
cmd := newCreateCommand(cli)
4343
cmd.SetArgs(tc.args)
4444
cmd.SetOut(io.Discard)
45+
cmd.SetErr(io.Discard)
4546
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4647
}
4748
}

cli/command/checkpoint/list_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ func TestCheckpointListErrors(t *testing.T) {
4242
cmd := newListCommand(cli)
4343
cmd.SetArgs(tc.args)
4444
cmd.SetOut(io.Discard)
45+
cmd.SetErr(io.Discard)
4546
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4647
}
4748
}

cli/command/checkpoint/remove_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,7 @@ func TestCheckpointRemoveErrors(t *testing.T) {
4141
cmd := newRemoveCommand(cli)
4242
cmd.SetArgs(tc.args)
4343
cmd.SetOut(io.Discard)
44+
cmd.SetErr(io.Discard)
4445
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4546
}
4647
}

cli/command/config/create_test.go

+12-8
Original file line numberDiff line numberDiff line change
@@ -43,14 +43,18 @@ func TestConfigCreateErrors(t *testing.T) {
4343
},
4444
}
4545
for _, tc := range testCases {
46-
cmd := newConfigCreateCommand(
47-
test.NewFakeCli(&fakeClient{
48-
configCreateFunc: tc.configCreateFunc,
49-
}),
50-
)
51-
cmd.SetArgs(tc.args)
52-
cmd.SetOut(io.Discard)
53-
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
46+
tc := tc
47+
t.Run(tc.expectedError, func(t *testing.T) {
48+
cmd := newConfigCreateCommand(
49+
test.NewFakeCli(&fakeClient{
50+
configCreateFunc: tc.configCreateFunc,
51+
}),
52+
)
53+
cmd.SetArgs(tc.args)
54+
cmd.SetOut(io.Discard)
55+
cmd.SetErr(io.Discard)
56+
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
57+
})
5458
}
5559
}
5660

cli/command/config/inspect_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -61,6 +61,7 @@ func TestConfigInspectErrors(t *testing.T) {
6161
assert.Check(t, cmd.Flags().Set(key, value))
6262
}
6363
cmd.SetOut(io.Discard)
64+
cmd.SetErr(io.Discard)
6465
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
6566
}
6667
}

cli/command/config/ls_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ func TestConfigListErrors(t *testing.T) {
4242
)
4343
cmd.SetArgs(tc.args)
4444
cmd.SetOut(io.Discard)
45+
cmd.SetErr(io.Discard)
4546
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4647
}
4748
}

cli/command/config/remove_test.go

+2
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,7 @@ func TestConfigRemoveErrors(t *testing.T) {
3737
)
3838
cmd.SetArgs(tc.args)
3939
cmd.SetOut(io.Discard)
40+
cmd.SetErr(io.Discard)
4041
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4142
}
4243
}
@@ -74,6 +75,7 @@ func TestConfigRemoveContinueAfterError(t *testing.T) {
7475
cmd := newConfigRemoveCommand(cli)
7576
cmd.SetArgs(names)
7677
cmd.SetOut(io.Discard)
78+
cmd.SetErr(io.Discard)
7779
assert.Error(t, cmd.Execute(), "error removing config: foo")
7880
assert.Check(t, is.DeepEqual(names, removedConfigs))
7981
}

cli/command/container/attach_test.go

+8-4
Original file line numberDiff line numberDiff line change
@@ -69,10 +69,14 @@ func TestNewAttachCommandErrors(t *testing.T) {
6969
},
7070
}
7171
for _, tc := range testCases {
72-
cmd := NewAttachCommand(test.NewFakeCli(&fakeClient{inspectFunc: tc.containerInspectFunc}))
73-
cmd.SetOut(io.Discard)
74-
cmd.SetArgs(tc.args)
75-
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
72+
tc := tc
73+
t.Run(tc.name, func(t *testing.T) {
74+
cmd := NewAttachCommand(test.NewFakeCli(&fakeClient{inspectFunc: tc.containerInspectFunc}))
75+
cmd.SetOut(io.Discard)
76+
cmd.SetErr(io.Discard)
77+
cmd.SetArgs(tc.args)
78+
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
79+
})
7680
}
7781
}
7882

cli/command/container/cp_test.go

+8-7
Original file line numberDiff line numberDiff line change
@@ -178,13 +178,14 @@ func TestSplitCpArg(t *testing.T) {
178178
expectedContainer: "container",
179179
},
180180
}
181-
for _, testcase := range testcases {
182-
t.Run(testcase.doc, func(t *testing.T) {
183-
skip.If(t, testcase.os != "" && testcase.os != runtime.GOOS)
184-
185-
ctr, path := splitCpArg(testcase.path)
186-
assert.Check(t, is.Equal(testcase.expectedContainer, ctr))
187-
assert.Check(t, is.Equal(testcase.expectedPath, path))
181+
for _, tc := range testcases {
182+
tc := tc
183+
t.Run(tc.doc, func(t *testing.T) {
184+
skip.If(t, tc.os == "windows" && runtime.GOOS != "windows" || tc.os == "linux" && runtime.GOOS == "windows")
185+
186+
ctr, path := splitCpArg(tc.path)
187+
assert.Check(t, is.Equal(tc.expectedContainer, ctr))
188+
assert.Check(t, is.Equal(tc.expectedPath, path))
188189
})
189190
}
190191
}

cli/command/container/create_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -236,6 +236,7 @@ func TestNewCreateCommandWithContentTrustErrors(t *testing.T) {
236236
fakeCLI.SetNotaryClient(tc.notaryFunc)
237237
cmd := NewCreateCommand(fakeCLI)
238238
cmd.SetOut(io.Discard)
239+
cmd.SetErr(io.Discard)
239240
cmd.SetArgs(tc.args)
240241
err := cmd.Execute()
241242
assert.ErrorContains(t, err, tc.expectedError)

cli/command/container/export_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,7 @@ func TestContainerExportOutputToIrregularFile(t *testing.T) {
3939
})
4040
cmd := NewExportCommand(cli)
4141
cmd.SetOut(io.Discard)
42+
cmd.SetErr(io.Discard)
4243
cmd.SetArgs([]string{"-o", "/dev/random", "container"})
4344

4445
err := cmd.Execute()

cli/command/container/list_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -163,6 +163,7 @@ func TestContainerListErrors(t *testing.T) {
163163
assert.Check(t, cmd.Flags().Set(key, value))
164164
}
165165
cmd.SetOut(io.Discard)
166+
cmd.SetErr(io.Discard)
166167
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
167168
}
168169
}

cli/command/container/prune_test.go

+3
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ package container
22

33
import (
44
"context"
5+
"io"
56
"testing"
67

78
"github.com/docker/cli/internal/test"
@@ -20,5 +21,7 @@ func TestContainerPrunePromptTermination(t *testing.T) {
2021
},
2122
})
2223
cmd := NewPruneCommand(cli)
24+
cmd.SetOut(io.Discard)
25+
cmd.SetErr(io.Discard)
2326
test.TerminatePrompt(ctx, t, cmd, cli)
2427
}

cli/command/container/rm_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,7 @@ func TestRemoveForce(t *testing.T) {
4545
})
4646
cmd := NewRmCommand(cli)
4747
cmd.SetOut(io.Discard)
48+
cmd.SetErr(io.Discard)
4849
cmd.SetArgs(tc.args)
4950

5051
err := cmd.Execute()

cli/command/container/run_test.go

+21-17
Original file line numberDiff line numberDiff line change
@@ -127,23 +127,27 @@ func TestRunCommandWithContentTrustErrors(t *testing.T) {
127127
},
128128
}
129129
for _, tc := range testCases {
130-
fakeCLI := test.NewFakeCli(&fakeClient{
131-
createContainerFunc: func(config *container.Config,
132-
hostConfig *container.HostConfig,
133-
networkingConfig *network.NetworkingConfig,
134-
platform *specs.Platform,
135-
containerName string,
136-
) (container.CreateResponse, error) {
137-
return container.CreateResponse{}, errors.New("shouldn't try to pull image")
138-
},
139-
}, test.EnableContentTrust)
140-
fakeCLI.SetNotaryClient(tc.notaryFunc)
141-
cmd := NewRunCommand(fakeCLI)
142-
cmd.SetArgs(tc.args)
143-
cmd.SetOut(io.Discard)
144-
err := cmd.Execute()
145-
assert.Assert(t, err != nil)
146-
assert.Assert(t, is.Contains(fakeCLI.ErrBuffer().String(), tc.expectedError))
130+
tc := tc
131+
t.Run(tc.name, func(t *testing.T) {
132+
fakeCLI := test.NewFakeCli(&fakeClient{
133+
createContainerFunc: func(config *container.Config,
134+
hostConfig *container.HostConfig,
135+
networkingConfig *network.NetworkingConfig,
136+
platform *specs.Platform,
137+
containerName string,
138+
) (container.CreateResponse, error) {
139+
return container.CreateResponse{}, errors.New("shouldn't try to pull image")
140+
},
141+
}, test.EnableContentTrust)
142+
fakeCLI.SetNotaryClient(tc.notaryFunc)
143+
cmd := NewRunCommand(fakeCLI)
144+
cmd.SetArgs(tc.args)
145+
cmd.SetOut(io.Discard)
146+
cmd.SetErr(io.Discard)
147+
err := cmd.Execute()
148+
assert.Assert(t, err != nil)
149+
assert.Assert(t, is.Contains(fakeCLI.ErrBuffer().String(), tc.expectedError))
150+
})
147151
}
148152
}
149153

cli/command/image/build_test.go

+1
Original file line numberDiff line numberDiff line change
@@ -127,6 +127,7 @@ func TestRunBuildFromGitHubSpecialCase(t *testing.T) {
127127
// Clone a small repo that exists so git doesn't prompt for credentials
128128
cmd.SetArgs([]string{"github.com/docker/for-win"})
129129
cmd.SetOut(io.Discard)
130+
cmd.SetErr(io.Discard)
130131
err := cmd.Execute()
131132
assert.ErrorContains(t, err, "unable to prepare context")
132133
assert.ErrorContains(t, err, "docker-build-git")

cli/command/image/history_test.go

+8-4
Original file line numberDiff line numberDiff line change
@@ -35,10 +35,14 @@ func TestNewHistoryCommandErrors(t *testing.T) {
3535
},
3636
}
3737
for _, tc := range testCases {
38-
cmd := NewHistoryCommand(test.NewFakeCli(&fakeClient{imageHistoryFunc: tc.imageHistoryFunc}))
39-
cmd.SetOut(io.Discard)
40-
cmd.SetArgs(tc.args)
41-
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
38+
tc := tc
39+
t.Run(tc.name, func(t *testing.T) {
40+
cmd := NewHistoryCommand(test.NewFakeCli(&fakeClient{imageHistoryFunc: tc.imageHistoryFunc}))
41+
cmd.SetOut(io.Discard)
42+
cmd.SetErr(io.Discard)
43+
cmd.SetArgs(tc.args)
44+
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
45+
})
4246
}
4347
}
4448

cli/command/image/import_test.go

+10-4
Original file line numberDiff line numberDiff line change
@@ -36,6 +36,7 @@ func TestNewImportCommandErrors(t *testing.T) {
3636
for _, tc := range testCases {
3737
cmd := NewImportCommand(test.NewFakeCli(&fakeClient{imageImportFunc: tc.imageImportFunc}))
3838
cmd.SetOut(io.Discard)
39+
cmd.SetErr(io.Discard)
3940
cmd.SetArgs(tc.args)
4041
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
4142
}
@@ -44,6 +45,7 @@ func TestNewImportCommandErrors(t *testing.T) {
4445
func TestNewImportCommandInvalidFile(t *testing.T) {
4546
cmd := NewImportCommand(test.NewFakeCli(&fakeClient{}))
4647
cmd.SetOut(io.Discard)
48+
cmd.SetErr(io.Discard)
4749
cmd.SetArgs([]string{"testdata/import-command-success.unexistent-file"})
4850
assert.ErrorContains(t, cmd.Execute(), "testdata/import-command-success.unexistent-file")
4951
}
@@ -96,9 +98,13 @@ func TestNewImportCommandSuccess(t *testing.T) {
9698
},
9799
}
98100
for _, tc := range testCases {
99-
cmd := NewImportCommand(test.NewFakeCli(&fakeClient{imageImportFunc: tc.imageImportFunc}))
100-
cmd.SetOut(io.Discard)
101-
cmd.SetArgs(tc.args)
102-
assert.NilError(t, cmd.Execute())
101+
tc := tc
102+
t.Run(tc.name, func(t *testing.T) {
103+
cmd := NewImportCommand(test.NewFakeCli(&fakeClient{imageImportFunc: tc.imageImportFunc}))
104+
cmd.SetOut(io.Discard)
105+
cmd.SetErr(io.Discard)
106+
cmd.SetArgs(tc.args)
107+
assert.NilError(t, cmd.Execute())
108+
})
103109
}
104110
}

cli/command/image/inspect_test.go

+8-4
Original file line numberDiff line numberDiff line change
@@ -25,10 +25,14 @@ func TestNewInspectCommandErrors(t *testing.T) {
2525
},
2626
}
2727
for _, tc := range testCases {
28-
cmd := newInspectCommand(test.NewFakeCli(&fakeClient{}))
29-
cmd.SetOut(io.Discard)
30-
cmd.SetArgs(tc.args)
31-
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
28+
tc := tc
29+
t.Run(tc.name, func(t *testing.T) {
30+
cmd := newInspectCommand(test.NewFakeCli(&fakeClient{}))
31+
cmd.SetOut(io.Discard)
32+
cmd.SetErr(io.Discard)
33+
cmd.SetArgs(tc.args)
34+
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
35+
})
3236
}
3337
}
3438

cli/command/image/list_test.go

+20-12
Original file line numberDiff line numberDiff line change
@@ -35,10 +35,14 @@ func TestNewImagesCommandErrors(t *testing.T) {
3535
},
3636
}
3737
for _, tc := range testCases {
38-
cmd := NewImagesCommand(test.NewFakeCli(&fakeClient{imageListFunc: tc.imageListFunc}))
39-
cmd.SetOut(io.Discard)
40-
cmd.SetArgs(tc.args)
41-
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
38+
tc := tc
39+
t.Run(tc.name, func(t *testing.T) {
40+
cmd := NewImagesCommand(test.NewFakeCli(&fakeClient{imageListFunc: tc.imageListFunc}))
41+
cmd.SetOut(io.Discard)
42+
cmd.SetErr(io.Discard)
43+
cmd.SetArgs(tc.args)
44+
assert.ErrorContains(t, cmd.Execute(), tc.expectedError)
45+
})
4246
}
4347
}
4448

@@ -79,14 +83,18 @@ func TestNewImagesCommandSuccess(t *testing.T) {
7983
},
8084
}
8185
for _, tc := range testCases {
82-
cli := test.NewFakeCli(&fakeClient{imageListFunc: tc.imageListFunc})
83-
cli.SetConfigFile(&configfile.ConfigFile{ImagesFormat: tc.imageFormat})
84-
cmd := NewImagesCommand(cli)
85-
cmd.SetOut(io.Discard)
86-
cmd.SetArgs(tc.args)
87-
err := cmd.Execute()
88-
assert.NilError(t, err)
89-
golden.Assert(t, cli.OutBuffer().String(), fmt.Sprintf("list-command-success.%s.golden", tc.name))
86+
tc := tc
87+
t.Run(tc.name, func(t *testing.T) {
88+
cli := test.NewFakeCli(&fakeClient{imageListFunc: tc.imageListFunc})
89+
cli.SetConfigFile(&configfile.ConfigFile{ImagesFormat: tc.imageFormat})
90+
cmd := NewImagesCommand(cli)
91+
cmd.SetOut(io.Discard)
92+
cmd.SetErr(io.Discard)
93+
cmd.SetArgs(tc.args)
94+
err := cmd.Execute()
95+
assert.NilError(t, err)
96+
golden.Assert(t, cli.OutBuffer().String(), fmt.Sprintf("list-command-success.%s.golden", tc.name))
97+
})
9098
}
9199
}
92100

0 commit comments

Comments
 (0)