forked from TrueCloudLab/restic
s3: Run integration test with minio server
This commit is contained in:
parent
8562a1bb2f
commit
edfb31f4fe
3 changed files with 117 additions and 3 deletions
|
@ -12,7 +12,11 @@ type deleter interface {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestS3Backend(t *testing.T) {
|
func TestS3Backend(t *testing.T) {
|
||||||
be, err := s3.Open("127.0.0.1:9000", "restictestbucket")
|
if TestS3Server == "" {
|
||||||
|
t.Skip("s3 test server not available")
|
||||||
|
}
|
||||||
|
|
||||||
|
be, err := s3.Open(TestS3Server, "restictestbucket")
|
||||||
OK(t, err)
|
OK(t, err)
|
||||||
|
|
||||||
testBackend(be, t)
|
testBackend(be, t)
|
||||||
|
|
|
@ -4,6 +4,7 @@ package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -21,6 +22,10 @@ type TravisEnvironment struct {
|
||||||
goxOS []string
|
goxOS []string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var envVendorExperiment = map[string]string{
|
||||||
|
"GO15VENDOREXPERIMENT": "1",
|
||||||
|
}
|
||||||
|
|
||||||
func (env *TravisEnvironment) Prepare() {
|
func (env *TravisEnvironment) Prepare() {
|
||||||
msg("preparing environment for Travis CI\n")
|
msg("preparing environment for Travis CI\n")
|
||||||
|
|
||||||
|
@ -28,6 +33,7 @@ func (env *TravisEnvironment) Prepare() {
|
||||||
run("go", "get", "github.com/mattn/goveralls")
|
run("go", "get", "github.com/mattn/goveralls")
|
||||||
run("go", "get", "github.com/pierrre/gotestcover")
|
run("go", "get", "github.com/pierrre/gotestcover")
|
||||||
run("go", "get", "github.com/mitchellh/gox")
|
run("go", "get", "github.com/mitchellh/gox")
|
||||||
|
runWithEnv(envVendorExperiment, "go", "get", "github.com/minio/minio")
|
||||||
|
|
||||||
if runtime.GOOS == "darwin" {
|
if runtime.GOOS == "darwin" {
|
||||||
// install the libraries necessary for fuse
|
// install the libraries necessary for fuse
|
||||||
|
@ -79,8 +85,20 @@ func (env *TravisEnvironment) RunTests() {
|
||||||
// run the build script
|
// run the build script
|
||||||
run("go", "run", "build.go")
|
run("go", "run", "build.go")
|
||||||
|
|
||||||
// run tests and gather coverage information
|
minioCmd, err := runMinio()
|
||||||
run("gotestcover", "-coverprofile", "all.cov", "./...")
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "error running minio server: %v", err)
|
||||||
|
os.Exit(4)
|
||||||
|
}
|
||||||
|
|
||||||
|
// run the tests and gather coverage information
|
||||||
|
runWithEnv(minioEnv, "gotestcover", "-coverprofile", "all.cov", "./...")
|
||||||
|
|
||||||
|
err = minioCmd.Process.Kill()
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "error stopping minio server: %v", err)
|
||||||
|
os.Exit(4)
|
||||||
|
}
|
||||||
|
|
||||||
runGofmt()
|
runGofmt()
|
||||||
}
|
}
|
||||||
|
@ -89,6 +107,7 @@ type AppveyorEnvironment struct{}
|
||||||
|
|
||||||
func (env *AppveyorEnvironment) Prepare() {
|
func (env *AppveyorEnvironment) Prepare() {
|
||||||
msg("preparing environment for Appveyor CI\n")
|
msg("preparing environment for Appveyor CI\n")
|
||||||
|
runWithEnv(envVendorExperiment, "go", "get", "github.com/minio/minio")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (env *AppveyorEnvironment) RunTests() {
|
func (env *AppveyorEnvironment) RunTests() {
|
||||||
|
@ -121,6 +140,26 @@ func msg(format string, args ...interface{}) {
|
||||||
fmt.Printf("CI: "+format, args...)
|
fmt.Printf("CI: "+format, args...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func updateEnv(env []string, override map[string]string) []string {
|
||||||
|
var newEnv []string
|
||||||
|
for _, s := range env {
|
||||||
|
d := strings.SplitN(s, "=", 2)
|
||||||
|
key := d[0]
|
||||||
|
|
||||||
|
if _, ok := override[key]; ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
newEnv = append(newEnv, s)
|
||||||
|
}
|
||||||
|
|
||||||
|
for k, v := range override {
|
||||||
|
newEnv = append(newEnv, k+"="+v)
|
||||||
|
}
|
||||||
|
|
||||||
|
return newEnv
|
||||||
|
}
|
||||||
|
|
||||||
func runGofmt() {
|
func runGofmt() {
|
||||||
dir, err := os.Getwd()
|
dir, err := os.Getwd()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -155,9 +194,19 @@ func runGofmt() {
|
||||||
|
|
||||||
func run(command string, args ...string) {
|
func run(command string, args ...string) {
|
||||||
msg("run %v %v\n", command, strings.Join(args, " "))
|
msg("run %v %v\n", command, strings.Join(args, " "))
|
||||||
|
runWithEnv(nil, command, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// runWithEnv calls a command with the current environment, except the entries
|
||||||
|
// of the env map are set additionally.
|
||||||
|
func runWithEnv(env map[string]string, command string, args ...string) {
|
||||||
|
msg("runWithEnv %v %v\n", command, strings.Join(args, " "))
|
||||||
cmd := exec.Command(command, args...)
|
cmd := exec.Command(command, args...)
|
||||||
cmd.Stdout = os.Stdout
|
cmd.Stdout = os.Stdout
|
||||||
cmd.Stderr = os.Stderr
|
cmd.Stderr = os.Stderr
|
||||||
|
if env != nil {
|
||||||
|
cmd.Env = updateEnv(os.Environ(), env)
|
||||||
|
}
|
||||||
err := cmd.Run()
|
err := cmd.Run()
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -167,6 +216,66 @@ func run(command string, args ...string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var minioConfig = `
|
||||||
|
{
|
||||||
|
"version": "2",
|
||||||
|
"credentials": {
|
||||||
|
"accessKeyId": "KEBIYDZ87HCIH5D17YCN",
|
||||||
|
"secretAccessKey": "bVX1KhipSBPopEfmhc7rGz8ooxx27xdJ7Gkh1mVe"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
var minioEnv = map[string]string{
|
||||||
|
"RESTIC_TEST_S3_SERVER": "127.0.0.1:9000",
|
||||||
|
"AWS_ACCESS_KEY_ID": "KEBIYDZ87HCIH5D17YCN",
|
||||||
|
"AWS_SECRET_ACCESS_KEY": "bVX1KhipSBPopEfmhc7rGz8ooxx27xdJ7Gkh1mVe",
|
||||||
|
}
|
||||||
|
|
||||||
|
// runMinio prepares and runs a minio server for the s3 backend tests in a
|
||||||
|
// temporary directory.
|
||||||
|
func runMinio() (*exec.Cmd, error) {
|
||||||
|
cfgdir, err := ioutil.TempDir("", "minio-config-")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg, err := os.Create(filepath.Join(cfgdir, "config.json"))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = cfg.Write([]byte(minioConfig))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = cfg.Close()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
dir, err := ioutil.TempDir("", "minio-root")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
logfile, err := os.Create(filepath.Join(cfgdir, "output"))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd := exec.Command("minio", "--config-folder", cfgdir, "server", dir)
|
||||||
|
cmd.Stdout = logfile
|
||||||
|
cmd.Stderr = logfile
|
||||||
|
err = cmd.Start()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return cmd, nil
|
||||||
|
}
|
||||||
|
|
||||||
func isTravis() bool {
|
func isTravis() bool {
|
||||||
return os.Getenv("TRAVIS_BUILD_DIR") != ""
|
return os.Getenv("TRAVIS_BUILD_DIR") != ""
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ var (
|
||||||
TestSFTPPath = getStringVar("RESTIC_TEST_SFTPPATH", "/usr/lib/ssh:/usr/lib/openssh")
|
TestSFTPPath = getStringVar("RESTIC_TEST_SFTPPATH", "/usr/lib/ssh:/usr/lib/openssh")
|
||||||
TestWalkerPath = getStringVar("RESTIC_TEST_PATH", ".")
|
TestWalkerPath = getStringVar("RESTIC_TEST_PATH", ".")
|
||||||
BenchArchiveDirectory = getStringVar("RESTIC_BENCH_DIR", ".")
|
BenchArchiveDirectory = getStringVar("RESTIC_BENCH_DIR", ".")
|
||||||
|
TestS3Server = getStringVar("RESTIC_TEST_S3_SERVER", "")
|
||||||
)
|
)
|
||||||
|
|
||||||
func getStringVar(name, defaultValue string) string {
|
func getStringVar(name, defaultValue string) string {
|
||||||
|
|
Loading…
Reference in a new issue