minio-rs/tests/s3/bucket_versioning.rs
Henk-Jan Lebbink c450081b2e
Refactor string parameters to typed wrapper structs (#200)
- Replaced raw string parameters with validated wrapper types (BucketName, ObjectName, Region, VersionId, etc.) following the "parse, don't validate" pattern
- Bucket and object names are now validated at construction time, ensuring compile-time correctness
- Added both relaxed (MinIO-compatible) and strict (AWS S3-compliant) validation modes for bucket names
2026-01-27 14:12:49 +01:00

104 lines
3.4 KiB
Rust

// MinIO Rust Library for Amazon S3 Compatible Cloud Storage
// Copyright 2025 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.
use minio::s3::builders::VersioningStatus;
use minio::s3::client::DEFAULT_REGION;
use minio::s3::error::{Error, S3ServerError};
use minio::s3::minio_error_response::MinioErrorCode;
use minio::s3::response::{GetBucketVersioningResponse, PutBucketVersioningResponse};
use minio::s3::response_traits::{HasBucket, HasRegion};
use minio::s3::types::{BucketName, S3Api};
use minio_common::test_context::TestContext;
#[minio_macros::test(skip_if_express)]
async fn bucket_versioning_s3(ctx: TestContext, bucket: BucketName) {
let resp: PutBucketVersioningResponse = ctx
.client
.put_bucket_versioning(&bucket, VersioningStatus::Enabled)
.unwrap()
.build()
.send()
.await
.unwrap();
assert_eq!(resp.bucket(), Some(&bucket));
assert_eq!(resp.region(), &*DEFAULT_REGION);
let resp: GetBucketVersioningResponse = ctx
.client
.get_bucket_versioning(&bucket)
.unwrap()
.build()
.send()
.await
.unwrap();
assert_eq!(resp.status().unwrap(), Some(VersioningStatus::Enabled));
assert_eq!(resp.bucket(), Some(&bucket));
assert_eq!(resp.region(), &*DEFAULT_REGION);
let resp: PutBucketVersioningResponse = ctx
.client
.put_bucket_versioning(&bucket, VersioningStatus::Suspended)
.unwrap()
.build()
.send()
.await
.unwrap();
assert_eq!(resp.bucket(), Some(&bucket));
assert_eq!(resp.region(), &*DEFAULT_REGION);
let resp: GetBucketVersioningResponse = ctx
.client
.get_bucket_versioning(&bucket)
.unwrap()
.build()
.send()
.await
.unwrap();
assert_eq!(resp.status().unwrap(), Some(VersioningStatus::Suspended));
assert_eq!(resp.bucket(), Some(&bucket));
assert_eq!(resp.region(), &*DEFAULT_REGION);
}
#[minio_macros::test(skip_if_not_express)]
async fn bucket_versioning_s3express(ctx: TestContext, bucket: BucketName) {
let resp: Result<PutBucketVersioningResponse, Error> = ctx
.client
.put_bucket_versioning(&bucket, VersioningStatus::Enabled)
.unwrap()
.build()
.send()
.await;
match resp {
Err(Error::S3Server(S3ServerError::S3Error(e))) => {
assert_eq!(e.code(), MinioErrorCode::NotSupported)
}
v => panic!("Expected error S3Error(NotSupported): but got {v:?}"),
}
let resp: Result<GetBucketVersioningResponse, Error> = ctx
.client
.get_bucket_versioning(&bucket)
.unwrap()
.build()
.send()
.await;
match resp {
Err(Error::S3Server(S3ServerError::S3Error(e))) => {
assert_eq!(e.code(), MinioErrorCode::NotSupported)
}
v => panic!("Expected error S3Error(NotSupported): but got {v:?}"),
}
}