XL: Implement new ReadAll API for files which are read in single call. (#1974)
Add a unit test as well.master
parent
ed2fdd90b0
commit
42286cba70
@ -0,0 +1,92 @@ |
|||||||
|
/* |
||||||
|
* Minio Cloud Storage, (C) 2016 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 main |
||||||
|
|
||||||
|
import ( |
||||||
|
"io/ioutil" |
||||||
|
"os" |
||||||
|
"testing" |
||||||
|
) |
||||||
|
|
||||||
|
// Tests the functionality implemented by ReadAll storage API.
|
||||||
|
func TestReadAll(t *testing.T) { |
||||||
|
path, err := ioutil.TempDir(os.TempDir(), "minio-") |
||||||
|
if err != nil { |
||||||
|
t.Fatalf("Unable to create a temporary directory, %s", err) |
||||||
|
} |
||||||
|
defer removeAll(path) |
||||||
|
|
||||||
|
// Initialize posix storage layer.
|
||||||
|
posix, err := newPosix(path) |
||||||
|
if err != nil { |
||||||
|
t.Fatalf("Unable to initialize posix, %s", err) |
||||||
|
} |
||||||
|
|
||||||
|
// Create files for the test cases.
|
||||||
|
if err = posix.MakeVol("exists"); err != nil { |
||||||
|
t.Fatalf("Unable to create a volume \"exists\", %s", err) |
||||||
|
} |
||||||
|
if err = posix.AppendFile("exists", "as-directory/as-file", []byte("Hello, World")); err != nil { |
||||||
|
t.Fatalf("Unable to create a file \"as-directory/as-file\", %s", err) |
||||||
|
} |
||||||
|
if err = posix.AppendFile("exists", "as-file", []byte("Hello, World")); err != nil { |
||||||
|
t.Fatalf("Unable to create a file \"as-file\", %s", err) |
||||||
|
} |
||||||
|
|
||||||
|
// Testcases to validate different conditions for ReadAll API.
|
||||||
|
testCases := []struct { |
||||||
|
volume string |
||||||
|
path string |
||||||
|
err error |
||||||
|
}{ |
||||||
|
// Validate volume does not exist.
|
||||||
|
{ |
||||||
|
"i-dont-exist", |
||||||
|
"", |
||||||
|
errVolumeNotFound, |
||||||
|
}, |
||||||
|
// Validate bad condition file does not exist.
|
||||||
|
{ |
||||||
|
"exists", |
||||||
|
"as-file-not-found", |
||||||
|
errFileNotFound, |
||||||
|
}, |
||||||
|
// Validate bad condition file exists as prefix/directory and
|
||||||
|
// we are attempting to read it.
|
||||||
|
{ |
||||||
|
"exists", |
||||||
|
"as-directory", |
||||||
|
errFileNotFound, |
||||||
|
}, |
||||||
|
// Validate the good condition file exists and we are able to
|
||||||
|
// read it.
|
||||||
|
{ |
||||||
|
"exists", |
||||||
|
"as-file", |
||||||
|
nil, |
||||||
|
}, |
||||||
|
// Add more cases here.
|
||||||
|
} |
||||||
|
|
||||||
|
// Run through all the test cases and validate for ReadAll.
|
||||||
|
for i, testCase := range testCases { |
||||||
|
_, err = posix.ReadAll(testCase.volume, testCase.path) |
||||||
|
if err != testCase.err { |
||||||
|
t.Errorf("Test %d expected err %s, got err %s", i+1, testCase.err, err) |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue