move test to bsutil package and refactor the test to use tmp
parent
fe5b5ab7cd
commit
14b81faeac
|
|
@ -0,0 +1,87 @@
|
|||
/*
|
||||
Copyright 2016 The Kubernetes Authors All rights reserved.
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
|
||||
package bsutil
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"testing"
|
||||
|
||||
"k8s.io/minikube/pkg/minikube/assets"
|
||||
"k8s.io/minikube/pkg/minikube/command"
|
||||
)
|
||||
|
||||
type copyFailRunner struct {
|
||||
command.Runner
|
||||
}
|
||||
|
||||
func (copyFailRunner) Copy(_ assets.CopyableFile) error {
|
||||
return fmt.Errorf("test error during copy file")
|
||||
}
|
||||
|
||||
func newFakeCommandRunnerCopyFail() command.Runner {
|
||||
return copyFailRunner{command.NewFakeCommandRunner()}
|
||||
}
|
||||
|
||||
func TestCopyBinary(t *testing.T) {
|
||||
tmpDir := t.TempDir()
|
||||
srcFile := filepath.Join(tmpDir, "source")
|
||||
if err := os.WriteFile(srcFile, []byte("data"), 0o644); err != nil {
|
||||
t.Fatalf("failed to create source file: %v", err)
|
||||
}
|
||||
|
||||
tests := []struct {
|
||||
name string
|
||||
runner command.Runner
|
||||
src string
|
||||
dst string
|
||||
wantErr bool
|
||||
}{
|
||||
{
|
||||
name: "missing source",
|
||||
runner: command.NewFakeCommandRunner(),
|
||||
src: filepath.Join(tmpDir, "missing"),
|
||||
dst: filepath.Join(tmpDir, "dest"),
|
||||
wantErr: true,
|
||||
},
|
||||
{
|
||||
name: "success",
|
||||
runner: command.NewFakeCommandRunner(),
|
||||
src: srcFile,
|
||||
dst: filepath.Join(tmpDir, "dest"),
|
||||
wantErr: false,
|
||||
},
|
||||
{
|
||||
name: "copy failure",
|
||||
runner: newFakeCommandRunnerCopyFail(),
|
||||
src: srcFile,
|
||||
dst: filepath.Join(tmpDir, "dest"),
|
||||
wantErr: true,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range tests {
|
||||
tc := tc
|
||||
t.Run(tc.name, func(t *testing.T) {
|
||||
err := copyBinary(tc.runner, tc.src, tc.dst)
|
||||
if (err != nil) != tc.wantErr {
|
||||
t.Fatalf("copyBinary() error = %v, wantErr %v", err, tc.wantErr)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
|
@ -17,70 +17,13 @@ limitations under the License.
|
|||
package machine
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"k8s.io/minikube/pkg/minikube/assets"
|
||||
"k8s.io/minikube/pkg/minikube/bootstrapper"
|
||||
"k8s.io/minikube/pkg/minikube/command"
|
||||
"k8s.io/minikube/pkg/minikube/download"
|
||||
)
|
||||
|
||||
type copyFailRunner struct {
|
||||
command.Runner
|
||||
}
|
||||
|
||||
func (copyFailRunner) Copy(_ assets.CopyableFile) error {
|
||||
return fmt.Errorf("test error during copy file")
|
||||
}
|
||||
|
||||
func newFakeCommandRunnerCopyFail() command.Runner {
|
||||
return copyFailRunner{command.NewFakeCommandRunner()}
|
||||
}
|
||||
|
||||
func TestCopyBinary(t *testing.T) {
|
||||
var tc = []struct {
|
||||
lastUpdateCheckFilePath string
|
||||
src, dst, desc string
|
||||
err bool
|
||||
runner command.Runner
|
||||
}{
|
||||
{
|
||||
desc: "not existing src",
|
||||
dst: "/tmp/testCopyBinary1",
|
||||
src: "/tmp/testCopyBinary2",
|
||||
err: true,
|
||||
runner: command.NewFakeCommandRunner(),
|
||||
},
|
||||
{
|
||||
desc: "src /etc/hosts",
|
||||
dst: "/tmp/testCopyBinary1",
|
||||
src: "/etc/hosts",
|
||||
err: false,
|
||||
runner: command.NewFakeCommandRunner(),
|
||||
},
|
||||
{
|
||||
desc: "existing src, copy fail",
|
||||
dst: "/etc/passwd",
|
||||
src: "/etc/hosts",
|
||||
err: true,
|
||||
runner: newFakeCommandRunnerCopyFail(),
|
||||
},
|
||||
}
|
||||
for _, test := range tc {
|
||||
t.Run(test.desc, func(t *testing.T) {
|
||||
err := CopyBinary(test.runner, test.src, test.dst)
|
||||
if err != nil && !test.err {
|
||||
t.Fatalf("Got unexpected error %v", err)
|
||||
}
|
||||
if err == nil && test.err {
|
||||
t.Fatal("Expected error but got nil")
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestCacheBinariesForBootstrapper(t *testing.T) {
|
||||
download.DownloadMock = download.CreateDstDownloadMock
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue