mirror of
https://github.com/minio/minio.git
synced 2025-01-12 15:33:22 -05:00
tests: Fix test server init - cleanup (#3806)
This commit is contained in:
parent
472fa4a6ca
commit
2b0ed21f08
@ -28,25 +28,9 @@ import (
|
|||||||
humanize "github.com/dustin/go-humanize"
|
humanize "github.com/dustin/go-humanize"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Prepare benchmark backend
|
// Prepare XL/FS backend for benchmark.
|
||||||
func prepareBenchmarkBackend(instanceType string) (ObjectLayer, []string, error) {
|
func prepareBenchmarkBackend(instanceType string) (ObjectLayer, []string, error) {
|
||||||
switch instanceType {
|
return prepareTestBackend(instanceType)
|
||||||
// Total number of disks for FS backend is set to 1.
|
|
||||||
case FSTestStr:
|
|
||||||
obj, disk, err := prepareFS()
|
|
||||||
if err != nil {
|
|
||||||
return nil, nil, err
|
|
||||||
}
|
|
||||||
return obj, []string{disk}, nil
|
|
||||||
// Total number of disks for XL backend is set to 16.
|
|
||||||
case XLTestStr:
|
|
||||||
return prepareXL()
|
|
||||||
}
|
|
||||||
obj, disk, err := prepareFS()
|
|
||||||
if err != nil {
|
|
||||||
return nil, nil, err
|
|
||||||
}
|
|
||||||
return obj, []string{disk}, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Benchmark utility functions for ObjectLayer.PutObject().
|
// Benchmark utility functions for ObjectLayer.PutObject().
|
||||||
|
@ -50,7 +50,6 @@ func (fsi *fsIOPool) Open(path string) (*lock.RLockedFile, error) {
|
|||||||
|
|
||||||
fsi.Lock()
|
fsi.Lock()
|
||||||
rlkFile, ok := fsi.readersMap[path]
|
rlkFile, ok := fsi.readersMap[path]
|
||||||
|
|
||||||
// File reference exists on map, validate if its
|
// File reference exists on map, validate if its
|
||||||
// really closed and we are safe to purge it.
|
// really closed and we are safe to purge it.
|
||||||
if ok && rlkFile != nil {
|
if ok && rlkFile != nil {
|
||||||
@ -76,8 +75,9 @@ func (fsi *fsIOPool) Open(path string) (*lock.RLockedFile, error) {
|
|||||||
// read lock mode.
|
// read lock mode.
|
||||||
if !ok {
|
if !ok {
|
||||||
var err error
|
var err error
|
||||||
|
var newRlkFile *lock.RLockedFile
|
||||||
// Open file for reading.
|
// Open file for reading.
|
||||||
rlkFile, err = lock.RLockedOpenFile(preparePath(path))
|
newRlkFile, err = lock.RLockedOpenFile(preparePath(path))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
return nil, errFileNotFound
|
return nil, errFileNotFound
|
||||||
@ -95,6 +95,30 @@ func (fsi *fsIOPool) Open(path string) (*lock.RLockedFile, error) {
|
|||||||
|
|
||||||
// Save new reader on the map.
|
// Save new reader on the map.
|
||||||
fsi.Lock()
|
fsi.Lock()
|
||||||
|
rlkFile, ok = fsi.readersMap[path]
|
||||||
|
if ok && rlkFile != nil {
|
||||||
|
// If the file is closed and not removed from map is a bug.
|
||||||
|
if rlkFile.IsClosed() {
|
||||||
|
// Log this as an error.
|
||||||
|
errorIf(errUnexpected, "Unexpected entry found on the map %s", path)
|
||||||
|
|
||||||
|
// Purge the cached lock path from map.
|
||||||
|
delete(fsi.readersMap, path)
|
||||||
|
|
||||||
|
// Save the newly acquired read locked file.
|
||||||
|
rlkFile = newRlkFile
|
||||||
|
} else {
|
||||||
|
// Increment the lock ref, since the file is not closed yet
|
||||||
|
// and caller requested to read the file again.
|
||||||
|
rlkFile.IncLockRef()
|
||||||
|
newRlkFile.Close()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Save the newly acquired read locked file.
|
||||||
|
rlkFile = newRlkFile
|
||||||
|
}
|
||||||
|
|
||||||
|
// Save the rlkFile back on the map.
|
||||||
fsi.readersMap[path] = rlkFile
|
fsi.readersMap[path] = rlkFile
|
||||||
fsi.Unlock()
|
fsi.Unlock()
|
||||||
}
|
}
|
||||||
|
@ -75,19 +75,11 @@ func prepareFS() (ObjectLayer, string, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, "", err
|
return nil, "", err
|
||||||
}
|
}
|
||||||
endpoints, err := parseStorageEndpoints(fsDirs)
|
obj, err := newFSObjectLayer(fsDirs[0])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, "", err
|
return nil, "", err
|
||||||
}
|
}
|
||||||
fsPath, err := url.QueryUnescape(endpoints[0].String())
|
return obj, fsDirs[0], nil
|
||||||
if err != nil {
|
|
||||||
return nil, "", err
|
|
||||||
}
|
|
||||||
obj, err := newFSObjectLayer(fsPath)
|
|
||||||
if err != nil {
|
|
||||||
return nil, "", err
|
|
||||||
}
|
|
||||||
return obj, endpoints[0].Path, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func prepareXL() (ObjectLayer, []string, error) {
|
func prepareXL() (ObjectLayer, []string, error) {
|
||||||
@ -193,16 +185,18 @@ type TestServer struct {
|
|||||||
SrvCmdCfg serverCmdConfig
|
SrvCmdCfg serverCmdConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UnstartedTestServer - Configures a temp FS/XL backend,
|
||||||
|
// initializes the endpoints and configures the test server.
|
||||||
|
// The server should be started using the Start() method.
|
||||||
func UnstartedTestServer(t TestErrHandler, instanceType string) TestServer {
|
func UnstartedTestServer(t TestErrHandler, instanceType string) TestServer {
|
||||||
// create an instance of TestServer.
|
// create an instance of TestServer.
|
||||||
testServer := TestServer{}
|
testServer := TestServer{}
|
||||||
// create temporary backend for the test server.
|
// return FS/XL object layer and temp backend.
|
||||||
nDisks := 16
|
objLayer, disks, err := prepareTestBackend(instanceType)
|
||||||
disks, err := getRandomDisks(nDisks)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal("Failed to create disks for the backend")
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
// set the server configuration.
|
||||||
root, err := newTestConfig(globalMinioDefaultRegion)
|
root, err := newTestConfig(globalMinioDefaultRegion)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("%s", err)
|
t.Fatalf("%s", err)
|
||||||
@ -212,19 +206,15 @@ func UnstartedTestServer(t TestErrHandler, instanceType string) TestServer {
|
|||||||
// Get credential.
|
// Get credential.
|
||||||
credentials := serverConfig.GetCredential()
|
credentials := serverConfig.GetCredential()
|
||||||
|
|
||||||
testServer.Root = root
|
testServer.Obj = objLayer
|
||||||
testServer.Disks, err = parseStorageEndpoints(disks)
|
testServer.Disks, err = parseStorageEndpoints(disks)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unexpected error %s", err)
|
t.Fatalf("Unexpected error %v", err)
|
||||||
}
|
}
|
||||||
|
testServer.Root = root
|
||||||
testServer.AccessKey = credentials.AccessKey
|
testServer.AccessKey = credentials.AccessKey
|
||||||
testServer.SecretKey = credentials.SecretKey
|
testServer.SecretKey = credentials.SecretKey
|
||||||
|
|
||||||
objLayer, _, err := initObjectLayer(testServer.Disks)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Failed obtaining Temp Backend: <ERROR> %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
srvCmdCfg := serverCmdConfig{
|
srvCmdCfg := serverCmdConfig{
|
||||||
endpoints: testServer.Disks,
|
endpoints: testServer.Disks,
|
||||||
}
|
}
|
||||||
@ -238,10 +228,9 @@ func UnstartedTestServer(t TestErrHandler, instanceType string) TestServer {
|
|||||||
|
|
||||||
// Run TestServer.
|
// Run TestServer.
|
||||||
testServer.Server = httptest.NewUnstartedServer(httpHandler)
|
testServer.Server = httptest.NewUnstartedServer(httpHandler)
|
||||||
|
// obtain server address.
|
||||||
srvCmdCfg.serverAddr = testServer.Server.Listener.Addr().String()
|
srvCmdCfg.serverAddr = testServer.Server.Listener.Addr().String()
|
||||||
|
|
||||||
testServer.Obj = objLayer
|
|
||||||
globalObjLayerMutex.Lock()
|
globalObjLayerMutex.Lock()
|
||||||
globalObjectAPI = objLayer
|
globalObjectAPI = objLayer
|
||||||
globalObjLayerMutex.Unlock()
|
globalObjLayerMutex.Unlock()
|
||||||
@ -1774,6 +1763,24 @@ func initAPIHandlerTest(obj ObjectLayer, endpoints []string) (string, http.Handl
|
|||||||
return bucketName, f, nil
|
return bucketName, f, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// prepare test backend.
|
||||||
|
// create FS/XL bankend.
|
||||||
|
// return object layer, backend disks.
|
||||||
|
func prepareTestBackend(instanceType string) (ObjectLayer, []string, error) {
|
||||||
|
switch instanceType {
|
||||||
|
// Total number of disks for XL backend is set to 16.
|
||||||
|
case XLTestStr:
|
||||||
|
return prepareXL()
|
||||||
|
default:
|
||||||
|
// return FS backend by default.
|
||||||
|
obj, disk, err := prepareFS()
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, err
|
||||||
|
}
|
||||||
|
return obj, []string{disk}, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ExecObjectLayerAPIAnonTest - Helper function to validate object Layer API handler
|
// ExecObjectLayerAPIAnonTest - Helper function to validate object Layer API handler
|
||||||
// response for anonymous/unsigned and unknown signature type HTTP request.
|
// response for anonymous/unsigned and unknown signature type HTTP request.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user