mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
fix: Better printing of XL config init error (#5284)
This commit is contained in:
parent
e3d841ffd1
commit
2244adff07
@ -193,7 +193,7 @@ func (atb *adminXLTestBed) TearDown() {
|
|||||||
// initTestObjLayer - Helper function to initialize an XL-based object
|
// initTestObjLayer - Helper function to initialize an XL-based object
|
||||||
// layer and set globalObjectAPI.
|
// layer and set globalObjectAPI.
|
||||||
func initTestXLObjLayer() (ObjectLayer, []string, error) {
|
func initTestXLObjLayer() (ObjectLayer, []string, error) {
|
||||||
objLayer, xlDirs, xlErr := prepareXL()
|
objLayer, xlDirs, xlErr := prepareXL16()
|
||||||
if xlErr != nil {
|
if xlErr != nil {
|
||||||
return nil, nil, xlErr
|
return nil, nil, xlErr
|
||||||
}
|
}
|
||||||
|
@ -317,7 +317,7 @@ func TestFormatXLHealFreshDisks(t *testing.T) {
|
|||||||
// a given disk to test healing a corrupted disk
|
// a given disk to test healing a corrupted disk
|
||||||
func TestFormatXLHealCorruptedDisks(t *testing.T) {
|
func TestFormatXLHealCorruptedDisks(t *testing.T) {
|
||||||
// Create an instance of xl backend.
|
// Create an instance of xl backend.
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -391,7 +391,7 @@ func TestFormatXLHealCorruptedDisks(t *testing.T) {
|
|||||||
// some of format.json
|
// some of format.json
|
||||||
func TestFormatXLReorderByInspection(t *testing.T) {
|
func TestFormatXLReorderByInspection(t *testing.T) {
|
||||||
// Create an instance of xl backend.
|
// Create an instance of xl backend.
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -125,17 +125,6 @@ func printFormatMsg(endpoints EndpointList, storageDisks []StorageAPI, fn printO
|
|||||||
fn(msg)
|
fn(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func printConfigErrMsg(storageDisks []StorageAPI, sErrs []error, fn printOnceFunc) {
|
|
||||||
msg := getConfigErrMsg(storageDisks, sErrs)
|
|
||||||
fn(msg)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Generate a formatted message when cluster is misconfigured.
|
|
||||||
func getConfigErrMsg(storageDisks []StorageAPI, sErrs []error) string {
|
|
||||||
msg := colorBlue("\nDetected configuration inconsistencies in the cluster. Please fix following servers.")
|
|
||||||
return msg + combineDiskErrs(storageDisks, sErrs)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Combines each disk errors in a newline formatted string.
|
// Combines each disk errors in a newline formatted string.
|
||||||
// this is a helper function in printing messages across
|
// this is a helper function in printing messages across
|
||||||
// all disks.
|
// all disks.
|
||||||
|
@ -52,8 +52,6 @@ func TestHealMsg(t *testing.T) {
|
|||||||
{endpoints, storageDisks, errs},
|
{endpoints, storageDisks, errs},
|
||||||
// Test - 2 for one of the disks is nil.
|
// Test - 2 for one of the disks is nil.
|
||||||
{endpoints, nilDisks, errs},
|
{endpoints, nilDisks, errs},
|
||||||
// Test - 3 for one of the errs is authentication.
|
|
||||||
{endpoints, nilDisks, authErrs},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, testCase := range testCases {
|
for i, testCase := range testCases {
|
||||||
@ -65,10 +63,6 @@ func TestHealMsg(t *testing.T) {
|
|||||||
if msg == "" {
|
if msg == "" {
|
||||||
t.Fatalf("Test: %d Unable to get regular message.", i+1)
|
t.Fatalf("Test: %d Unable to get regular message.", i+1)
|
||||||
}
|
}
|
||||||
msg = getConfigErrMsg(testCase.storageDisks, testCase.serrs)
|
|
||||||
if msg == "" {
|
|
||||||
t.Fatalf("Test: %d Unable to get config error message.", i+1)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,23 +98,48 @@ const (
|
|||||||
Abort
|
Abort
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// configErrs contains the list of configuration errors.
|
||||||
|
var configErrs = []error{
|
||||||
|
errInvalidAccessKeyID,
|
||||||
|
errAuthentication,
|
||||||
|
errServerVersionMismatch,
|
||||||
|
errServerTimeMismatch,
|
||||||
|
}
|
||||||
|
|
||||||
// Quick error to actions converts looking for specific errors
|
// Quick error to actions converts looking for specific errors
|
||||||
// which need to be returned quickly and server should wait instead.
|
// which need to be returned quickly and server should wait instead.
|
||||||
func quickErrToActions(errMap map[error]int) InitActions {
|
func quickErrToActions(errMap map[error]int) InitActions {
|
||||||
var action InitActions
|
var action InitActions
|
||||||
switch {
|
for _, configErr := range configErrs {
|
||||||
case errMap[errInvalidAccessKeyID] > 0:
|
if errMap[configErr] > 0 {
|
||||||
fallthrough
|
action = WaitForConfig
|
||||||
case errMap[errAuthentication] > 0:
|
break
|
||||||
fallthrough
|
}
|
||||||
case errMap[errServerVersionMismatch] > 0:
|
|
||||||
fallthrough
|
|
||||||
case errMap[errServerTimeMismatch] > 0:
|
|
||||||
action = WaitForConfig
|
|
||||||
}
|
}
|
||||||
return action
|
return action
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// reduceInitXLErrs reduces errors found in distributed XL initialization
|
||||||
|
func reduceInitXLErrs(storageDisks []StorageAPI, sErrs []error) error {
|
||||||
|
var foundErrs int
|
||||||
|
for i := range sErrs {
|
||||||
|
if sErrs[i] != nil {
|
||||||
|
foundErrs++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if foundErrs == 0 {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
// Early quit if there is a config error
|
||||||
|
for i := range sErrs {
|
||||||
|
if contains(configErrs, sErrs[i]) {
|
||||||
|
return fmt.Errorf("%s: %s", storageDisks[i], sErrs[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Combine all disk errors otherwise for user inspection
|
||||||
|
return fmt.Errorf("%s", combineDiskErrs(storageDisks, sErrs))
|
||||||
|
}
|
||||||
|
|
||||||
// Preparatory initialization stage for XL validates known errors.
|
// Preparatory initialization stage for XL validates known errors.
|
||||||
// Converts them into specific actions. These actions have special purpose
|
// Converts them into specific actions. These actions have special purpose
|
||||||
// which caller decides on what needs to be done.
|
// which caller decides on what needs to be done.
|
||||||
@ -262,7 +287,7 @@ func retryFormattingXLDisks(firstDisk bool, endpoints EndpointList, storageDisks
|
|||||||
// Check if this is a XL or distributed XL, anything > 1 is considered XL backend.
|
// Check if this is a XL or distributed XL, anything > 1 is considered XL backend.
|
||||||
switch prepForInitXL(firstDisk, sErrs, len(storageDisks)) {
|
switch prepForInitXL(firstDisk, sErrs, len(storageDisks)) {
|
||||||
case Abort:
|
case Abort:
|
||||||
return fmt.Errorf("%s", combineDiskErrs(storageDisks, sErrs))
|
return reduceInitXLErrs(storageDisks, sErrs)
|
||||||
case FormatDisks:
|
case FormatDisks:
|
||||||
console.Eraseline()
|
console.Eraseline()
|
||||||
printFormatMsg(endpoints, storageDisks, printOnceFn())
|
printFormatMsg(endpoints, storageDisks, printOnceFn())
|
||||||
@ -289,7 +314,7 @@ func retryFormattingXLDisks(firstDisk bool, endpoints EndpointList, storageDisks
|
|||||||
)
|
)
|
||||||
case WaitForConfig:
|
case WaitForConfig:
|
||||||
// Print configuration errors.
|
// Print configuration errors.
|
||||||
printConfigErrMsg(storageDisks, sErrs, printOnceFn())
|
return reduceInitXLErrs(storageDisks, sErrs)
|
||||||
case WaitForAll:
|
case WaitForAll:
|
||||||
console.Printf("Initializing data volume for first time. Waiting for other servers to come online (elapsed %s)\n", getElapsedTime())
|
console.Printf("Initializing data volume for first time. Waiting for other servers to come online (elapsed %s)\n", getElapsedTime())
|
||||||
case WaitForFormatting:
|
case WaitForFormatting:
|
||||||
|
@ -16,7 +16,10 @@
|
|||||||
|
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import "testing"
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
func (action InitActions) String() string {
|
func (action InitActions) String() string {
|
||||||
switch action {
|
switch action {
|
||||||
@ -41,6 +44,42 @@ func (action InitActions) String() string {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestReduceInitXLErrs(t *testing.T) {
|
||||||
|
_, fsDirs, err := prepareXL(4)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Unable to initialize 'XL' object layer.")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove all dirs.
|
||||||
|
for _, dir := range fsDirs {
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
}
|
||||||
|
|
||||||
|
storageDisks, err := initStorageDisks(mustGetNewEndpointList(fsDirs...))
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal("Unexpected error: ", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
testCases := []struct {
|
||||||
|
sErrs []error
|
||||||
|
expectedErr string
|
||||||
|
}{
|
||||||
|
{[]error{nil, nil, nil, nil}, ""},
|
||||||
|
{[]error{errUnformattedDisk, nil, nil, nil}, "\n[01/04] " + storageDisks[0].String() + " : unformatted disk found"},
|
||||||
|
{[]error{errUnformattedDisk, errUnformattedDisk, nil, nil}, "\n[01/04] " + storageDisks[0].String() + " : unformatted disk found" + "\n[02/04] " + storageDisks[1].String() + " : unformatted disk found"},
|
||||||
|
{[]error{errUnformattedDisk, errUnformattedDisk, errServerVersionMismatch, nil}, storageDisks[2].String() + ": Server versions do not match"},
|
||||||
|
}
|
||||||
|
for i, test := range testCases {
|
||||||
|
actual := reduceInitXLErrs(storageDisks, test.sErrs)
|
||||||
|
if test.expectedErr == "" && actual != nil {
|
||||||
|
t.Errorf("Test %d expected no error but received `%s`", i+1, actual.Error())
|
||||||
|
}
|
||||||
|
if test.expectedErr != "" && actual.Error() != test.expectedErr {
|
||||||
|
t.Errorf("Test %d expected `%s` but received `%s`", i+1, test.expectedErr, actual.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestPrepForInitXL(t *testing.T) {
|
func TestPrepForInitXL(t *testing.T) {
|
||||||
// All disks are unformatted, a fresh setup.
|
// All disks are unformatted, a fresh setup.
|
||||||
allUnformatted := []error{
|
allUnformatted := []error{
|
||||||
|
@ -169,8 +169,7 @@ func prepareFS() (ObjectLayer, string, error) {
|
|||||||
return obj, fsDirs[0], nil
|
return obj, fsDirs[0], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func prepareXL() (ObjectLayer, []string, error) {
|
func prepareXL(nDisks int) (ObjectLayer, []string, error) {
|
||||||
nDisks := 16
|
|
||||||
fsDirs, err := getRandomDisks(nDisks)
|
fsDirs, err := getRandomDisks(nDisks)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
@ -183,6 +182,10 @@ func prepareXL() (ObjectLayer, []string, error) {
|
|||||||
return obj, fsDirs, nil
|
return obj, fsDirs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func prepareXL16() (ObjectLayer, []string, error) {
|
||||||
|
return prepareXL(16)
|
||||||
|
}
|
||||||
|
|
||||||
// Initialize FS objects.
|
// Initialize FS objects.
|
||||||
func initFSObjects(disk string, t *testing.T) (obj ObjectLayer) {
|
func initFSObjects(disk string, t *testing.T) (obj ObjectLayer) {
|
||||||
newTestConfig(globalMinioDefaultRegion)
|
newTestConfig(globalMinioDefaultRegion)
|
||||||
@ -1748,7 +1751,7 @@ func prepareTestBackend(instanceType string) (ObjectLayer, []string, error) {
|
|||||||
switch instanceType {
|
switch instanceType {
|
||||||
// Total number of disks for XL backend is set to 16.
|
// Total number of disks for XL backend is set to 16.
|
||||||
case XLTestStr:
|
case XLTestStr:
|
||||||
return prepareXL()
|
return prepareXL16()
|
||||||
default:
|
default:
|
||||||
// return FS backend by default.
|
// return FS backend by default.
|
||||||
obj, disk, err := prepareFS()
|
obj, disk, err := prepareFS()
|
||||||
@ -1955,7 +1958,7 @@ func ExecObjectLayerAPITest(t *testing.T, objAPITest objAPITestType, endpoints [
|
|||||||
// Executing the object layer tests for single node setup.
|
// Executing the object layer tests for single node setup.
|
||||||
objAPITest(objLayer, FSTestStr, bucketFS, fsAPIRouter, credentials, t)
|
objAPITest(objLayer, FSTestStr, bucketFS, fsAPIRouter, credentials, t)
|
||||||
|
|
||||||
objLayer, xlDisks, err := prepareXL()
|
objLayer, xlDisks, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
@ -2001,7 +2004,7 @@ func ExecObjectLayerTest(t TestErrHandler, objTest objTestType) {
|
|||||||
// Executing the object layer tests for single node setup.
|
// Executing the object layer tests for single node setup.
|
||||||
objTest(objLayer, FSTestStr, t)
|
objTest(objLayer, FSTestStr, t)
|
||||||
|
|
||||||
objLayer, fsDirs, err := prepareXL()
|
objLayer, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
@ -2026,7 +2029,7 @@ func ExecObjectLayerTestWithDirs(t TestErrHandler, objTest objTestTypeWithDirs)
|
|||||||
t.Fatalf("Initialization of object layer failed for single node setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for single node setup: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
objLayer, fsDirs, err := prepareXL()
|
objLayer, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
@ -2044,7 +2047,7 @@ func ExecObjectLayerDiskAlteredTest(t *testing.T, objTest objTestDiskNotFoundTyp
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(configPath)
|
defer os.RemoveAll(configPath)
|
||||||
|
|
||||||
objLayer, fsDirs, err := prepareXL()
|
objLayer, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
@ -2255,7 +2258,7 @@ func StartTestS3PeerRPCServer(t TestErrHandler) (TestServer, []string) {
|
|||||||
testRPCServer.SecretKey = credentials.SecretKey
|
testRPCServer.SecretKey = credentials.SecretKey
|
||||||
|
|
||||||
// init disks
|
// init disks
|
||||||
objLayer, fsDirs, err := prepareXL()
|
objLayer, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("%s", err)
|
t.Fatalf("%s", err)
|
||||||
}
|
}
|
||||||
|
12
cmd/utils.go
12
cmd/utils.go
@ -29,6 +29,7 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
"reflect"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -132,10 +133,13 @@ func isMaxPartID(partID int) bool {
|
|||||||
return partID > globalMaxPartID
|
return partID > globalMaxPartID
|
||||||
}
|
}
|
||||||
|
|
||||||
func contains(stringList []string, element string) bool {
|
func contains(slice interface{}, elem interface{}) bool {
|
||||||
for _, e := range stringList {
|
v := reflect.ValueOf(slice)
|
||||||
if e == element {
|
if v.Kind() == reflect.Slice {
|
||||||
return true
|
for i := 0; i < v.Len(); i++ {
|
||||||
|
if v.Index(i).Interface() == elem {
|
||||||
|
return true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
|
@ -18,6 +18,7 @@ package cmd
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"reflect"
|
"reflect"
|
||||||
@ -312,3 +313,38 @@ func TestToS3ETag(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Test contains
|
||||||
|
func TestContains(t *testing.T) {
|
||||||
|
|
||||||
|
testErr := errors.New("test err")
|
||||||
|
|
||||||
|
testCases := []struct {
|
||||||
|
slice interface{}
|
||||||
|
elem interface{}
|
||||||
|
found bool
|
||||||
|
}{
|
||||||
|
{nil, nil, false},
|
||||||
|
{"1", "1", false},
|
||||||
|
{nil, "1", false},
|
||||||
|
{[]string{"1"}, nil, false},
|
||||||
|
{[]string{}, "1", false},
|
||||||
|
{[]string{"1"}, "1", true},
|
||||||
|
{[]string{"2"}, "1", false},
|
||||||
|
{[]string{"1", "2"}, "1", true},
|
||||||
|
{[]string{"2", "1"}, "1", true},
|
||||||
|
{[]string{"2", "1", "3"}, "1", true},
|
||||||
|
{[]int{1, 2, 3}, "1", false},
|
||||||
|
{[]int{1, 2, 3}, 2, true},
|
||||||
|
{[]int{1, 2, 3, 4, 5, 6}, 7, false},
|
||||||
|
{[]error{errors.New("new err")}, testErr, false},
|
||||||
|
{[]error{errors.New("new err"), testErr}, testErr, true},
|
||||||
|
}
|
||||||
|
|
||||||
|
for i, testCase := range testCases {
|
||||||
|
found := contains(testCase.slice, testCase.elem)
|
||||||
|
if found != testCase.found {
|
||||||
|
t.Fatalf("Test %v: expected: %v, got: %v", i+1, testCase.found, found)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1363,7 +1363,7 @@ func testWebSetBucketPolicyHandler(obj ObjectLayer, instanceType string, t TestE
|
|||||||
// TestWebCheckAuthorization - Test Authorization for all web handlers
|
// TestWebCheckAuthorization - Test Authorization for all web handlers
|
||||||
func TestWebCheckAuthorization(t *testing.T) {
|
func TestWebCheckAuthorization(t *testing.T) {
|
||||||
// Prepare XL backend
|
// Prepare XL backend
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
@ -1542,7 +1542,7 @@ func TestWebObjectLayerFaultyDisks(t *testing.T) {
|
|||||||
defer os.RemoveAll(root)
|
defer os.RemoveAll(root)
|
||||||
|
|
||||||
// Prepare XL backend
|
// Prepare XL backend
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
t.Fatalf("Initialization of object layer failed for XL setup: %s", err)
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ func TestXLParentDirIsObject(t *testing.T) {
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
obj, fsDisks, err := prepareXL()
|
obj, fsDisks, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unable to initialize 'XL' object layer.")
|
t.Fatalf("Unable to initialize 'XL' object layer.")
|
||||||
}
|
}
|
||||||
|
@ -130,7 +130,7 @@ func TestListOnlineDisks(t *testing.T) {
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
obj, disks, err := prepareXL()
|
obj, disks, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Prepare XL backend failed - %v", err)
|
t.Fatalf("Prepare XL backend failed - %v", err)
|
||||||
}
|
}
|
||||||
@ -339,7 +339,7 @@ func TestDisksWithAllParts(t *testing.T) {
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
obj, disks, err := prepareXL()
|
obj, disks, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Prepare XL backend failed - %v", err)
|
t.Fatalf("Prepare XL backend failed - %v", err)
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,7 @@ func TestListObjectsHeal(t *testing.T) {
|
|||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
// Create an instance of xl backend
|
// Create an instance of xl backend
|
||||||
xl, fsDirs, err := prepareXL()
|
xl, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -155,7 +155,7 @@ func TestListUploadsHeal(t *testing.T) {
|
|||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
// Create an instance of XL backend.
|
// Create an instance of XL backend.
|
||||||
xl, fsDirs, err := prepareXL()
|
xl, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,7 @@ func TestXLCleanupMultipartUploadsInRoutine(t *testing.T) {
|
|||||||
defer os.RemoveAll(root)
|
defer os.RemoveAll(root)
|
||||||
|
|
||||||
// Create an instance of xl backend
|
// Create an instance of xl backend
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -84,7 +84,7 @@ func TestXLCleanupMultipartUpload(t *testing.T) {
|
|||||||
defer os.RemoveAll(root)
|
defer os.RemoveAll(root)
|
||||||
|
|
||||||
// Create an instance of xl backend
|
// Create an instance of xl backend
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -128,7 +128,7 @@ func TestUpdateUploadJSON(t *testing.T) {
|
|||||||
defer os.RemoveAll(root)
|
defer os.RemoveAll(root)
|
||||||
|
|
||||||
// Create an instance of xl backend
|
// Create an instance of xl backend
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ func TestRepeatPutObjectPart(t *testing.T) {
|
|||||||
var disks []string
|
var disks []string
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
objLayer, disks, err = prepareXL()
|
objLayer, disks, err = prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -81,7 +81,7 @@ func TestXLDeleteObjectBasic(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create an instance of xl backend
|
// Create an instance of xl backend
|
||||||
xl, fsDirs, err := prepareXL()
|
xl, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -113,7 +113,7 @@ func TestXLDeleteObjectBasic(t *testing.T) {
|
|||||||
|
|
||||||
func TestXLDeleteObjectDiskNotFound(t *testing.T) {
|
func TestXLDeleteObjectDiskNotFound(t *testing.T) {
|
||||||
// Create an instance of xl backend.
|
// Create an instance of xl backend.
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -164,7 +164,7 @@ func TestXLDeleteObjectDiskNotFound(t *testing.T) {
|
|||||||
|
|
||||||
func TestGetObjectNoQuorum(t *testing.T) {
|
func TestGetObjectNoQuorum(t *testing.T) {
|
||||||
// Create an instance of xl backend.
|
// Create an instance of xl backend.
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -216,7 +216,7 @@ func TestGetObjectNoQuorum(t *testing.T) {
|
|||||||
|
|
||||||
func TestPutObjectNoQuorum(t *testing.T) {
|
func TestPutObjectNoQuorum(t *testing.T) {
|
||||||
// Create an instance of xl backend.
|
// Create an instance of xl backend.
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
@ -273,7 +273,7 @@ func TestHealing(t *testing.T) {
|
|||||||
}
|
}
|
||||||
defer os.RemoveAll(rootPath)
|
defer os.RemoveAll(rootPath)
|
||||||
|
|
||||||
obj, fsDirs, err := prepareXL()
|
obj, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,7 @@ import (
|
|||||||
|
|
||||||
// TestStorageInfo - tests storage info.
|
// TestStorageInfo - tests storage info.
|
||||||
func TestStorageInfo(t *testing.T) {
|
func TestStorageInfo(t *testing.T) {
|
||||||
objLayer, fsDirs, err := prepareXL()
|
objLayer, fsDirs, err := prepareXL16()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unable to initialize 'XL' object layer.")
|
t.Fatalf("Unable to initialize 'XL' object layer.")
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user