forked from TrueCloudLab/restic
3f878aa8e7
Fix error handling bug + clean up error messages
76 lines
1.9 KiB
Go
76 lines
1.9 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/restic/restic/internal/errors"
|
|
rtest "github.com/restic/restic/internal/test"
|
|
)
|
|
|
|
func Test_PrintFunctionsRespectsGlobalStdout(t *testing.T) {
|
|
for _, p := range []func(){
|
|
func() { Println("message") },
|
|
func() { Print("message\n") },
|
|
func() { Printf("mes%s\n", "sage") },
|
|
} {
|
|
buf, _ := withCaptureStdout(func() error {
|
|
p()
|
|
return nil
|
|
})
|
|
rtest.Equals(t, "message\n", buf.String())
|
|
}
|
|
}
|
|
|
|
type errorReader struct{ err error }
|
|
|
|
func (r *errorReader) Read([]byte) (int, error) { return 0, r.err }
|
|
|
|
func TestReadPassword(t *testing.T) {
|
|
want := errors.New("foo")
|
|
_, err := readPassword(&errorReader{want})
|
|
rtest.Assert(t, errors.Is(err, want), "wrong error %v", err)
|
|
}
|
|
|
|
func TestReadRepo(t *testing.T) {
|
|
tempDir := rtest.TempDir(t)
|
|
|
|
// test --repo option
|
|
var opts GlobalOptions
|
|
opts.Repo = tempDir
|
|
repo, err := ReadRepo(opts)
|
|
rtest.OK(t, err)
|
|
rtest.Equals(t, tempDir, repo)
|
|
|
|
// test --repository-file option
|
|
foo := filepath.Join(tempDir, "foo")
|
|
err = os.WriteFile(foo, []byte(tempDir+"\n"), 0666)
|
|
rtest.OK(t, err)
|
|
|
|
var opts2 GlobalOptions
|
|
opts2.RepositoryFile = foo
|
|
repo, err = ReadRepo(opts2)
|
|
rtest.OK(t, err)
|
|
rtest.Equals(t, tempDir, repo)
|
|
|
|
var opts3 GlobalOptions
|
|
opts3.RepositoryFile = foo + "-invalid"
|
|
_, err = ReadRepo(opts3)
|
|
if err == nil {
|
|
t.Fatal("must not read repository path from invalid file path")
|
|
}
|
|
}
|
|
|
|
func TestReadEmptyPassword(t *testing.T) {
|
|
opts := GlobalOptions{InsecureNoPassword: true}
|
|
password, err := ReadPassword(context.TODO(), opts, "test")
|
|
rtest.OK(t, err)
|
|
rtest.Equals(t, "", password, "got unexpected password")
|
|
|
|
opts.password = "invalid"
|
|
_, err = ReadPassword(context.TODO(), opts, "test")
|
|
rtest.Assert(t, strings.Contains(err.Error(), "must not be specified together with providing a password via a cli option or environment variable"), "unexpected error message, got %v", err)
|
|
}
|