s3: Run integration test with minio server

This commit is contained in:
Alexander Neumann 2015-12-19 17:21:45 +01:00
parent 8562a1bb2f
commit edfb31f4fe
3 changed files with 117 additions and 3 deletions

View file

@ -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)

View file

@ -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") != ""
} }

View file

@ -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 {