mirror of
				https://github.com/minio/minio.git
				synced 2025-11-04 10:11:09 +01:00 
			
		
		
		
	* Provide information on *actively* healing, buckets healed/queued, objects healed/failed. * Add concurrent healing of multiple sets (typically on startup). * Add bucket level resume, so restarts will only heal non-healed buckets. * Print summary after healing a disk is done.
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
 * MinIO Cloud Storage, (C) 2016, 2017 MinIO, Inc.
 | 
						|
 *
 | 
						|
 * 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 cmd
 | 
						|
 | 
						|
import (
 | 
						|
	"os"
 | 
						|
	"reflect"
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/minio/minio/pkg/madmin"
 | 
						|
)
 | 
						|
 | 
						|
// Tests if we generate storage info.
 | 
						|
func TestStorageInfoMsg(t *testing.T) {
 | 
						|
	infoStorage := StorageInfo{}
 | 
						|
	infoStorage.Disks = []madmin.Disk{
 | 
						|
		{Endpoint: "http://127.0.0.1:9000/data/1/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9000/data/2/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9000/data/3/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9000/data/4/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9001/data/1/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9001/data/2/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9001/data/3/", State: madmin.DriveStateOk},
 | 
						|
		{Endpoint: "http://127.0.0.1:9001/data/4/", State: madmin.DriveStateOffline},
 | 
						|
	}
 | 
						|
	infoStorage.Backend.Type = madmin.Erasure
 | 
						|
 | 
						|
	if msg := getStorageInfoMsg(infoStorage); !strings.Contains(msg, "7 Online, 1 Offline") {
 | 
						|
		t.Fatal("Unexpected storage info message, found:", msg)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Tests stripping standard ports from apiEndpoints.
 | 
						|
func TestStripStandardPorts(t *testing.T) {
 | 
						|
	apiEndpoints := []string{"http://127.0.0.1:9000", "http://127.0.0.2:80", "https://127.0.0.3:443"}
 | 
						|
	expectedAPIEndpoints := []string{"http://127.0.0.1:9000", "http://127.0.0.2", "https://127.0.0.3"}
 | 
						|
	newAPIEndpoints := stripStandardPorts(apiEndpoints)
 | 
						|
 | 
						|
	if !reflect.DeepEqual(expectedAPIEndpoints, newAPIEndpoints) {
 | 
						|
		t.Fatalf("Expected %#v, got %#v", expectedAPIEndpoints, newAPIEndpoints)
 | 
						|
	}
 | 
						|
 | 
						|
	apiEndpoints = []string{"http://%%%%%:9000"}
 | 
						|
	newAPIEndpoints = stripStandardPorts(apiEndpoints)
 | 
						|
	if !reflect.DeepEqual([]string{""}, newAPIEndpoints) {
 | 
						|
		t.Fatalf("Expected %#v, got %#v", apiEndpoints, newAPIEndpoints)
 | 
						|
	}
 | 
						|
 | 
						|
	apiEndpoints = []string{"http://127.0.0.1:443", "https://127.0.0.1:80"}
 | 
						|
	newAPIEndpoints = stripStandardPorts(apiEndpoints)
 | 
						|
	if !reflect.DeepEqual(apiEndpoints, newAPIEndpoints) {
 | 
						|
		t.Fatalf("Expected %#v, got %#v", apiEndpoints, newAPIEndpoints)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Test printing server common message.
 | 
						|
func TestPrintServerCommonMessage(t *testing.T) {
 | 
						|
	obj, fsDir, err := prepareFS()
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer os.RemoveAll(fsDir)
 | 
						|
	if err = newTestConfig(globalMinioDefaultRegion, obj); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
 | 
						|
	apiEndpoints := []string{"http://127.0.0.1:9000"}
 | 
						|
	printServerCommonMsg(apiEndpoints)
 | 
						|
}
 | 
						|
 | 
						|
// Tests print cli access message.
 | 
						|
func TestPrintCLIAccessMsg(t *testing.T) {
 | 
						|
	obj, fsDir, err := prepareFS()
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer os.RemoveAll(fsDir)
 | 
						|
	if err = newTestConfig(globalMinioDefaultRegion, obj); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
 | 
						|
	apiEndpoints := []string{"http://127.0.0.1:9000"}
 | 
						|
	printCLIAccessMsg(apiEndpoints[0], "myminio")
 | 
						|
}
 | 
						|
 | 
						|
// Test print startup message.
 | 
						|
func TestPrintStartupMessage(t *testing.T) {
 | 
						|
	obj, fsDir, err := prepareFS()
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer os.RemoveAll(fsDir)
 | 
						|
	if err = newTestConfig(globalMinioDefaultRegion, obj); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
 | 
						|
	apiEndpoints := []string{"http://127.0.0.1:9000"}
 | 
						|
	printStartupMessage(apiEndpoints, nil)
 | 
						|
}
 |