mirror of
https://github.com/minio/minio.git
synced 2025-01-23 12:43:16 -05:00
1e5fb4b79a
- Update startup banner to print storage class in capitals. This makes it easier to identify different storage classes available. - Update response metadata to not send STANDARD storage class. This is in accordance with AWS S3 behaviour. - Update minio-go library to bring in storage class related changes. This is needed to make transparent translation of storage class headers for Minio S3 Gateway.
252 lines
6.9 KiB
Go
252 lines
6.9 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 (
|
|
"crypto/x509"
|
|
"crypto/x509/pkix"
|
|
"fmt"
|
|
"os"
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
humanize "github.com/dustin/go-humanize"
|
|
)
|
|
|
|
// Tests if we generate storage info.
|
|
func TestStorageInfoMsg(t *testing.T) {
|
|
infoStorage := StorageInfo{
|
|
Total: 10 * humanize.GiByte,
|
|
Free: 2 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 7, 1, 4, 5},
|
|
}
|
|
|
|
if msg := getStorageInfoMsg(infoStorage); !strings.Contains(msg, "2.0 GiB Free, 10 GiB Total") || !strings.Contains(msg, "7 Online, 1 Offline") {
|
|
t.Fatal("Unexpected storage info message, found:", msg)
|
|
}
|
|
}
|
|
|
|
// Tests if certificate expiry warning will be printed
|
|
func TestCertificateExpiryInfo(t *testing.T) {
|
|
// given
|
|
var expiredDate = time.Now().Add(time.Hour * 24 * (30 - 1)) // 29 days.
|
|
|
|
var fakeCerts = []*x509.Certificate{
|
|
{
|
|
NotAfter: expiredDate,
|
|
Subject: pkix.Name{
|
|
CommonName: "Test cert",
|
|
},
|
|
},
|
|
}
|
|
|
|
expectedMsg := colorBlue("\nCertificate expiry info:\n") +
|
|
colorBold(fmt.Sprintf("#1 Test cert will expire on %s\n", expiredDate))
|
|
|
|
// When
|
|
msg := getCertificateChainMsg(fakeCerts)
|
|
|
|
// Then
|
|
if msg != expectedMsg {
|
|
t.Fatalf("Expected message was: %s, got: %s", expectedMsg, msg)
|
|
}
|
|
}
|
|
|
|
// Tests if certificate expiry warning will not be printed if certificate not expired
|
|
func TestCertificateNotExpired(t *testing.T) {
|
|
// given
|
|
var expiredDate = time.Now().Add(time.Hour * 24 * (30 + 1)) // 31 days.
|
|
|
|
var fakeCerts = []*x509.Certificate{
|
|
{
|
|
NotAfter: expiredDate,
|
|
Subject: pkix.Name{
|
|
CommonName: "Test cert",
|
|
},
|
|
},
|
|
}
|
|
|
|
// when
|
|
msg := getCertificateChainMsg(fakeCerts)
|
|
|
|
// then
|
|
if msg != "" {
|
|
t.Fatalf("Expected empty message was: %s", 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(apiEndpoints, 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) {
|
|
root, err := newTestConfig(globalMinioDefaultRegion)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer os.RemoveAll(root)
|
|
|
|
apiEndpoints := []string{"http://127.0.0.1:9000"}
|
|
printServerCommonMsg(apiEndpoints)
|
|
}
|
|
|
|
// Tests print cli access message.
|
|
func TestPrintCLIAccessMsg(t *testing.T) {
|
|
root, err := newTestConfig(globalMinioDefaultRegion)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer os.RemoveAll(root)
|
|
|
|
apiEndpoints := []string{"http://127.0.0.1:9000"}
|
|
printCLIAccessMsg(apiEndpoints[0], "myminio")
|
|
}
|
|
|
|
// Test print startup message.
|
|
func TestPrintStartupMessage(t *testing.T) {
|
|
root, err := newTestConfig(globalMinioDefaultRegion)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer os.RemoveAll(root)
|
|
|
|
apiEndpoints := []string{"http://127.0.0.1:9000"}
|
|
printStartupMessage(apiEndpoints)
|
|
}
|
|
|
|
func TestGetStandardStorageClassInfoMsg(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
args StorageInfo
|
|
want string
|
|
}{
|
|
{"1", StorageInfo{
|
|
Total: 20 * humanize.GiByte,
|
|
Free: 2 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 15, 1, 5, 3},
|
|
}, "Objects with " + standardStorageClass + " class can withstand [4] drive failure(s).\n"},
|
|
{"2", StorageInfo{
|
|
Total: 30 * humanize.GiByte,
|
|
Free: 3 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 10, 0, 5, 3},
|
|
}, "Objects with " + standardStorageClass + " class can withstand [5] drive failure(s).\n"},
|
|
{"3", StorageInfo{
|
|
Total: 15 * humanize.GiByte,
|
|
Free: 2 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 12, 3, 6, 2},
|
|
}, "Objects with " + standardStorageClass + " class can withstand [3] drive failure(s).\n"},
|
|
}
|
|
for _, tt := range tests {
|
|
if got := getStandardStorageClassInfoMsg(tt.args); got != tt.want {
|
|
t.Errorf("Test %s failed, expected %v, got %v", tt.name, tt.want, got)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestGetRRSStorageClassInfoMsg(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
args StorageInfo
|
|
want string
|
|
}{
|
|
{"1", StorageInfo{
|
|
Total: 20 * humanize.GiByte,
|
|
Free: 2 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 15, 1, 5, 3},
|
|
}, "Objects with " + reducedRedundancyStorageClass + " class can withstand [2] drive failure(s).\n"},
|
|
{"2", StorageInfo{
|
|
Total: 30 * humanize.GiByte,
|
|
Free: 3 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 16, 0, 5, 3},
|
|
}, "Objects with " + reducedRedundancyStorageClass + " class can withstand [3] drive failure(s).\n"},
|
|
{"3", StorageInfo{
|
|
Total: 15 * humanize.GiByte,
|
|
Free: 2 * humanize.GiByte,
|
|
Backend: struct {
|
|
Type BackendType
|
|
OnlineDisks int
|
|
OfflineDisks int
|
|
standardSCParity int
|
|
rrSCParity int
|
|
}{Erasure, 12, 3, 6, 5},
|
|
}, "Objects with " + reducedRedundancyStorageClass + " class can withstand [2] drive failure(s).\n"},
|
|
}
|
|
for _, tt := range tests {
|
|
if got := getRRSStorageClassInfoMsg(tt.args); got != tt.want {
|
|
t.Errorf("Test %s failed, expected %v, got %v", tt.name, tt.want, got)
|
|
}
|
|
}
|
|
}
|