mirror of
https://github.com/minio/minio.git
synced 2025-11-09 05:34:56 -05:00
Support bucket versioning (#9377)
- Implement a new xl.json 2.0.0 format to support, this moves the entire marshaling logic to POSIX layer, top layer always consumes a common FileInfo construct which simplifies the metadata reads. - Implement list object versions - Migrate to siphash from crchash for new deployments for object placements. Fixes #2111
This commit is contained in:
@@ -24,7 +24,7 @@ import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
// Wrapper for calling DeleteObject tests for both XL multiple disks and single node setup.
|
||||
// Wrapper for calling DeleteObject tests for both Erasure multiple disks and single node setup.
|
||||
func TestDeleteObject(t *testing.T) {
|
||||
ExecObjectLayerTest(t, testDeleteObject)
|
||||
}
|
||||
@@ -74,7 +74,7 @@ func testDeleteObject(obj ObjectLayer, instanceType string, t TestErrHandler) {
|
||||
"dir/",
|
||||
[]string{"dir/object1", "object0"},
|
||||
},
|
||||
// Test 4: Remove an empty directory and checks it is really removed
|
||||
// Test 5: Remove an empty directory and checks it is really removed
|
||||
{
|
||||
"bucket5",
|
||||
[]objectUpload{{"object0", "content"}, {"dir/", ""}},
|
||||
@@ -84,8 +84,7 @@ func testDeleteObject(obj ObjectLayer, instanceType string, t TestErrHandler) {
|
||||
}
|
||||
|
||||
for i, testCase := range testCases {
|
||||
|
||||
err := obj.MakeBucketWithLocation(context.Background(), testCase.bucketName, "", false)
|
||||
err := obj.MakeBucketWithLocation(context.Background(), testCase.bucketName, BucketOptions{})
|
||||
if err != nil {
|
||||
t.Fatalf("%s : %s", instanceType, err.Error())
|
||||
}
|
||||
@@ -99,16 +98,17 @@ func testDeleteObject(obj ObjectLayer, instanceType string, t TestErrHandler) {
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: check the error in the future
|
||||
_ = obj.DeleteObject(context.Background(), testCase.bucketName, testCase.pathToDelete)
|
||||
_, _ = obj.DeleteObject(context.Background(), testCase.bucketName, testCase.pathToDelete, ObjectOptions{})
|
||||
|
||||
result, err := obj.ListObjects(context.Background(), testCase.bucketName, "", "", "", 1000)
|
||||
if err != nil {
|
||||
t.Errorf("Test %d: %s: Expected to pass, but failed with: <ERROR> %s", i+1, instanceType, err.Error())
|
||||
continue
|
||||
}
|
||||
|
||||
if len(result.Objects) != len(testCase.objectsAfterDelete) {
|
||||
t.Errorf("Test %d: %s: mismatch number of objects after delete, expected = %d, found = %d", i+1, instanceType, len(testCase.objectsAfterDelete), len(result.Objects))
|
||||
t.Errorf("Test %d: %s: mismatch number of objects after delete, expected = %v, found = %v", i+1, instanceType, testCase.objectsAfterDelete, result.Objects)
|
||||
continue
|
||||
}
|
||||
|
||||
for idx := range result.Objects {
|
||||
|
||||
Reference in New Issue
Block a user