The current major version 2 will receive new features and bug fixes on a continuous basis.
Version 4.x will be JDK17 LTS bytecode compatible (maybe JDK21 LTS, depending on the release date), with Docker integration only.
Any JUnit / direct Java usage support will be dropped and only supported on a best-effort basis.
(i.e. the modules will be deleted from the code base and not released anymore. It may be possible to
still run S3Mock directly in Java.)
The S3Mock is a Spring Boot application and currently contains various workarounds to make it possible
to easily to run S3MockApplication#start
from a static context. These workarounds will be deleted.
Once 4.x is released, 3.x will receive bug fixes, new features will be best-effort only.
Once 4.x is released, 2.x support will be best-effort entirely.
- Features and fixes
- TBD
- Refactorings
- Refactor S3Mock to a "standard" Spring Boot application.
- Remove workarounds to use
S3MockApplication#start
from a static context - Remove unit test modules, since S3Mock can't be started directly from Java anymore.
- Remove workarounds to use
- Maybe migration to
Kotlin
- the IntegrationTests were migrated already.
- Refactor S3Mock to a "standard" Spring Boot application.
- Version updates
- Bump java version from 17 to 21 (?)
Version 3.x will be JDK17 LTS bytecode compatible, with Docker and JUnit / direct Java integration. (Best effort, if the workarounds implemented in S3Mock still work for Spring Boot 3 / Spring Framework 6, S3Mock 3.x will still support JUnit / direct Java usage.)
Work will start once Spring Boot 3 is released and all features planned for 2.x are released (see below)
Once 3.x is released, 2.x will receive bug fixes, new features will be best-effort only.
Once 4.x is released, 3.x will receive bug fixes, new features will be best-effort only.
- Features and fixes
- TBD
- Refactorings
- Use various Java features introduced between JDK 8 and JDK 17 in the source code
- Use new Spring Boot 3 features
- Use new Spring Framework 6 features
- Version updates
- Bump spring-boot.version from 2.x to 3.x
- This will update all Spring Boot dependencies as well, including Spring Framework 6.x
- Bump java version from 8 to 17
- Bump spring-boot.version from 2.x to 3.x
Version 2.x is JDK8 LTS bytecode compatible, with Docker and JUnit / direct Java integration.
The current major version 2 will receive new features and bug fixes on a continuous basis.
Once 3.x is released, 2.x will receive bug fixes, new features will be best-effort only.
Once 4.x is released, 2.x support will be best-effort entirely.
- Features and fixes
- Support for BucketLifecycleConfiguration APIs
- Support for GetObjectAttributes API
- Support for Presigned URIs
- Support for Bucket subdomains
- Support for Version APIs
- Refactorings
- TBD
- Version updates
- TBD
2.x is JDK8 LTS bytecode compatible, with Docker and JUnit / direct Java integration.
- Features and fixes
- Add support for ACL APIs (fixes #213 / #290)
- Implement GetObjectACL / PutObjectACL
- Return / accept String instead of a POJO. We need to use JAX-B annotations instead of Jackson annotations because AWS decided to use xsi:type annotations in the XML representation, which are not supported by Jackson. It doesn't seem to be possible to use bot JAX-B and Jackson for (de-)serialization in parallel.
- Add support for ACL APIs (fixes #213 / #290)
- Version updates
- Bump aws-java-sdk-s3 from 1.12.298 to 1.12.309
- Bump aws-v2.version from 2.17.269 to 2.17.281
- Bump spring-boot.version from 2.7.3 to 2.7.4
- Bump maven-jar-plugin from 3.2.2 to 3.3.0
2.x is JDK8 LTS bytecode compatible, with Docker and JUnit / direct Java integration.
- Features and fixes
- Handle all incoming and outgoing ETags according to RFC2616 / RFC7232 (fixes #807)
- Fixes ETag handling in GetObject, HeadObject, CopyObject, UploadPartCopy APIs.
- We are now generating and storing ETags in the "RFC-Format" with enclosing double quotes.
- Incoming ETags are used verbatim to compare against the internally held representation.
- Wildcard ETags are also correctly handled.
- Handle all incoming and outgoing ETags according to RFC2616 / RFC7232 (fixes #807)
2.x is JDK8 LTS bytecode compatible, with Docker and JUnit / direct Java integration.
- Features and fixes
- LastModified must be updated when copying an object onto itself (fixes #811)
- Refactorings
- Split up integration tests by type
2.x is JDK8 LTS bytecode compatible, with Docker and JUnit / direct Java integration.
- Features and fixes
- ETags in requests and responses must comply to RFC-2616 (fixes #801)
- Fixes
ListObjects
andListObjectsV2
APIs. - Whenever S3Mock uses Serialization / Deserialization with Jackson, we must use our custom EtagSerializer / EtagDeserializer that wraps and unwraps the etag for the DTO.
- Fixes
- ETags in requests and responses must comply to RFC-2616 (fixes #801)
- Version updates
- Bump aws-v2.version from 2.17.267 to 2.17.269
- Bump aws-java-sdk-s3 from 1.12.296 to 1.12.298
- Features and fixes
- Add support for LegalHold APIs (fixes #157)
- Implement GetObjectLegalHold / PutObjectLegalHold
- Implement GetObjectLockConfiguration / PutObjectLockConfiguration
- In S3, object locking can only be activated for versioned buckets, versions are currently not supported by S3Mock. S3 enforces LegalHold only for versions, so S3Mock currently can't enforce the legal hold.
- Add support for Retention APIs
- Implement GetObjectRetention / PutObjectRetention
- In S3, object locking can only be activated for versioned buckets, versions are currently not supported by S3Mock. S3 enforces retention only for versions, so S3Mock currently can't enforce the retention.
- Add support for LegalHold APIs (fixes #157)
- Refactorings
- Added support for IntegrationTests to use a dedicated bucket per test method
- Refactored some IntegrationTests to this pattern.
- Use AWS SDK internal Utils for instants and encoding
- Using
software.amazon.awssdk.utils.DateUtils
andsoftware.amazon.awssdk.utils.http.SdkHttpUtils
- These classes are marked as
software.amazon.awssdk.annotations.SdkProtectedApi
which means that SDK users (liek S3Mock) should not use these classes, but S3Mock has to exactly match the behaviour and expectations of the AWS SDKs, and it's easier to depend on internal AWS SDK classes instead of replicating or copying the code. - S3Mock may have violated the AWS SDK license before by including source code without explicitly stating that it's AWS copyrighted code. (In the JavaDoc it did say that this is a copy with a reference to the class, though)
- Using
- Added support for IntegrationTests to use a dedicated bucket per test method
- Version updates
- Bump aws-v2.version from 2.17.263 to 2.17.267
- Bump aws-java-sdk-s3 from 1.12.292 to 1.12.296
- Features and fixes
- Rename local storage files, add file system structure documentation to README.md (fixes #220)
@Configuration
/@ConfigurationProperties
classes now public to enable customers to use@Import
/@ContextConfiguration
on them. (fixes #751)
- Features and fixes
- Remove Spring Component Index from S3Mock (fixes #786)
- Adding a Spring Component Index file is a breaking change for all clients of the s3mock.jar
- If Spring finds even one Component Index file in the classpath, all other configuration in the application is completely ignored by default.
- Remove Spring Component Index from S3Mock (fixes #786)
- Features and fixes
- Correctly detect and use existing root folder (fixes #786)
- Features and fixes
- Use
@SpringBootApplication
to configure S3Mock (fixes #782)
- Use
- Features and fixes
- Add Spring Component Index to S3Mock (fixes #751)
- Bucket lifecycle
- S3Mock now validates incoming Bucket names.
- S3 SDKs (for Java) validated the names before sending, so this should not matter for most use-cases.
- S3Mock now throws errors on duplicate creation (409 Conflict) / deletion (404 Not Found)
- These errors are defined in the S3 API, the S3Mock just never implemented them.
- S3Mock now validates incoming Bucket names.
- DTOs
- Fix names, methods, return values to match AWS API
- Remove internal field "path" from
Bucket
serializations. Fortunately this did not break AWS SDKs in the past, since the "path" field is not expected in those responses.
- Various other fixes like
- Removal of duplicated / simplification of code where possible
- Add (hopefully useful?) logging with all incoming parameters on errors.
- Fix IntelliJ IDEA warnings
- Better assertions in tests
- Fix various JavaDoc issues, add links to S3 API where possible
- Refactorings
- Major refactoring towards smaller classes with well-defined responsibilities.
- Many of the existing lines of code in the S3Mock core were changed, moved or removed.
- All IntegrationTests were/are still green, HTTP API did not change (other than fixed listed above)
- Refactor into layers
Controller -> Service -> Store
- Controllers handle request/response only, Services implement higher level functionality on top of their stores, Stores read and write data from/to disk.
- Handle Multipart requests in
MultipartController
->MultipartService
->MultipartStore
- Handle Bucket requests in
BucketController
->BucketService
->BucketStore
- Handle Object requests in
ObjectController
->ObjectService
->ObjectStore
- Code and documentation cleanup
- Let
BucketStore
storeBucketMetadata
just likeS3ObjectMetadata
locally. For now, only store the "core" metadata like creationDate and name. - Store object keys in
BucketMetadata
, assign UUIDs (fixes #94) - Store objects in UUID folders, clean up name usage
- Extract header helper methods into
HeaderUtil
fromFileStoreController
/ObjectController
.
- Major refactoring towards smaller classes with well-defined responsibilities.
- Version updates
- Bump maven-javadoc-plugin from 3.4.0 to 3.4.1
- Bump aws-v2.version from 2.17.248 to 2.17.263
- Bump aws-java-sdk-s3 from 1.12.278 to 1.12.292
- Bump checkstyle from 10.3.2 to 10.3.3
- Bump maven-checkstyle-plugin from 3.1.2 to 3.2.0
- Bump spring-boot.version from 2.7.2 to 2.7.3
- Features and fixes
- Fix ListMultiPartUploads for Amazon SDK Java v2 (fixes #734)
- Refactorings
- Add Maven Wrapper for reliable builds
- Add Spring Boot "devtools" for better local development
- Add "debug" profile that logs request output and enables JMX and all actuator endpoints
- Version updates
- Bump aws-java-sdk-s3 from 1.12.267 to 1.12.278
- Bump aws-v2.version from 2.17.239 to 2.17.248
- Bump docker-maven-plugin from 0.40.1 to 0.40.2
- Bump alpine from 3.16.1 to 3.16.2 in /docker
- Bump checkstyle from 10.3.1 to 10.3.2
Test release that incremented the version number but was not released to Maven One or Docker Hub. Please refer / update to version 2.4.16, thanks.
- Features and fixes
- Fix broken SSL handshake (fixes #706)
- Fix KMS key handling (fixes #702)
- Allow listing a MultiPartUpload with no parts (fixes #694)
- Update SSL certificate with san=dns:localhost (fixes #228)
- Refactorings
- Add sortpom-maven-plugin, run sortpom
- To run manually, execute
mvn com.github.ekryd.sortpom:sortpom-maven-plugin:sort
- To run manually, execute
- Enable Kotlin compiler for integration-tests only.
- Add sortpom-maven-plugin, run sortpom
- Version updates
- Bump alpine from 3.16.0 to 3.16.1 in /docker
- Bump aws-java-sdk-s3 from 1.12.240 to 1.12.267
- Bump aws-v2.version from 2.17.211 to 2.17.239
- Bump spring-boot.version from 2.7.0 to 2.7.2
- Bump kotlin.version from 1.7.0 to 1.7.10
- Bump testng from 7.6.0 to 7.6.1
- Bump testcontainers.version from 1.17.2 to 1.17.3
- Bump checkstyle from 10.3 to 10.3.1
- Bump maven-deploy-plugin from 3.0.0-M2 to 3.0.0
- Bump docker-maven-plugin from 0.40.0 to 0.40.1
- Bump sortpom-maven-plugin from 3.1.3 to 3.2.0
- Bump maven-install-plugin from 3.0.0-M1 to 3.0.1
- Bump maven-resources-plugin from 3.2.0 to 3.3.0
- Bump exec-maven-plugin from 3.0.0 to 3.1.0
- Features and fixes
- Adds missing x-amz-server-side-encryption and x-amz-server-side-encryption-aws-kms-key-id header (fixes #639)
- Version updates
- Bump alpine from 3.15.4 to 3.16.0 in /docker
- Bump aws-java-sdk-s3 from 1.12.212 to 1.12.240
- Bump aws-v2.version from 2.17.182 to 2.17.211
- Bump spring-boot.version from 2.6.7 to 2.7.0
- Bump kotlin.version from 1.6.21 to 1.7.0
- Bump testng from 7.5 to 7.6.0
- Bump docker/setup-qemu-action from 1 to 2
- Bump checkstyle from 10.2 to 10.3
- Bump docker-maven-plugin from 0.39.1 to 0.40.0
- Bump maven-failsafe-plugin from 3.0.0-M6 to 3.0.0-M7
- Bump maven-surefire-plugin from 3.0.0-M6 to 3.0.0-M7
- Bump maven-release-plugin from 3.0.0-M5 to 3.0.0-M6
- Bump maven-enforcer-plugin from 3.0.0 to 3.1.0
Test releases that incremented the version number but were not released to Maven One or Docker Hub. Please refer / update to version 2.4.13, thanks.
- Features and fixes
- ListParts returns 404 on unknown upload id (fixes #475)
- Allow CopyObject of key to same key in the same bucket (fixes #468)
- Fix handling of userMetadata in CopyObject REPLACE and COPY cases (fixes #468 again, fixes #569)
- Add multipart tests for "small" last part (fixes #524)
- Refactorings
- Migrate integration tests to kotlin
- Version updates
- Bump alpine from 3.15.0 to 3.15.4 in /docker
- Bump aws-java-sdk-s3 from 1.12.170 to 1.12.212
- Bump aws-v2.version from 2.17.141 to 2.17.182
- Bump spring-boot.version from 2.6.3 to 2.6.7
- Bump spring-security-oauth2 from 2.5.1.RELEASE to 2.5.2.RELEASE
- Bump testcontainers.version from 1.16.3 to 1.17.1
- Bump maven-surefire-plugin from 3.0.0-M5 to 3.0.0-M6
- Bump maven-failsafe-plugin from 3.0.0-M5 to 3.0.0-M6
- Bump maven-compiler-plugin from 3.10.0 to 3.10.1
- Bump maven-clean-plugin from 3.1.0 to 3.2.0
- Bump maven-dependency-plugin from 3.2.0 to 3.3.0
- Bump kotlin.version from 1.6.10 to 1.6.21
- Bump maven-javadoc-plugin from 3.3.2 to 3.4.0
- Bump checkstyle from 9.3 to 10.2
- Features and fixes
- Verify source key exists on CopyObject and CopyObjectPart (fixes #459)
- Refactorings
- Tagging does not have a "versionId" property in S3 API.
- CompleteMultipartUpload children are of type "CompletedPart".
- BatchDeleteResponse children are of type "DeletedObject".
- DeleteResult contains Error elements for failed deletes.
- Fixed JavaDoc of various classes and methods
- Add deprecation notice / documentation (fixes #418)
- Remove unnecessary methods and constructors
- Rename classes to better match their counterpart in S3 API
- Convert Integration Test to Kotlin
- Version updates
- Bump aws-java-sdk-s3 from 1.12.162 to 1.12.170
- Bump aws-v2.version from 2.17.133 to 2.17.141
- Bump docker-maven-plugin from 0.39.0 to 0.39.1
- Features and fixes
- Let S3Mock run with custom application.properties on classpath (fixes #434)
- Change Docker image entrypoint to exec form (fixes #421)
- Version updates
- Bump aws-java-sdk-s3 from 1.12.150 to 1.12.162
- Bump aws-v2.version from 2.17.120 to 2.17.133
- Bump docker-maven-plugin from 0.38.1 to 0.39.0
- Bump maven-javadoc-plugin from 3.3.1 to 3.3.2
- Bump maven-compiler-plugin from 3.9.0 to 3.10.0
- Features and fixes
- getObjectTagging incorrectly returns JSON instead of XML (fixes #406)
- Features and fixes
- Docker image is now available as multi arch for both
amd64
andarm64
platforms. (fixes #253, #287, #313, #389)
- Docker image is now available as multi arch for both
Test releases that incremented the version number but were not released to Maven One or Docker Hub. Please refer / update to version 2.4.6, thanks.
- Features and fixes
- Make contextPath of FileStoreController configurable (Fixes #388)
- Add multi-part upload checks, S3 has a minimum size allowed of 5MB (Fixes #392)
- Handle Content-MD5 header. (Fixes #208)
- Etags are Hex encoded digests. (Fixes #208)
- Refactorings
- Introduce @Configuration for packages.
- Move all remaining DTOs to "dto" package.
- Rename "domain" package to "store".
- Reduced visibility of some classes and methods to package / private.
- Use Java 17 for CI and release.
- Version updates
- Bump aws-java-sdk-s3 from 1.12.131 to 1.12.150
- Bump aws-v2.version from 2.17.102 to 2.17.120
- Bump xmlunit-assertj3 from 2.8.4 to 2.9.0
- Bump spring-boot.version from 2.6.2 to 2.6.3
- Bump testcontainers.version from 1.16.2 to 1.16.3
- Bump maven-compiler-plugin from 3.8.1 to 3.9.0
- Bump maven-release-plugin from 3.0.0-M4 to 3.0.0-M5
- Bump maven-jar-plugin from 3.2.0 to 3.2.2
- Bump testng from 7.4.0 to 7.5
Problems publishing through Sonatype, only Docker container was released, not the Java libraries.
Please refer / update to version 2.4.1, thanks.
- Features and fixes
- Fix MultipartUpload without range (fixes #341)
- Treat empty delimiter as
null
(fixes #306) - Fix -DskipDocker (fixes #344)
- Version updates
- Bump maven-deploy-plugin from 3.0.0-M1 to 3.0.0-M2
- Bump spring-boot.version from 2.6.1 to 2.6.2
- Bump aws-java-sdk-s3 from 1.12.130 to 1.12.131
- Bump checkstyle from 9.2 to 9.2.1
- Features and fixes
- Set only one CORS header (fixes #74 - again)
- Add examples for validKmsKeys and initialBuckets configuration (fixes #322)
- Refactorings
- Using official Alpine Docker container with JDK17 from APK to run
- alpine:3.15.0
- This is in preparation of multi-arch release
- Using official Alpine Docker container with JDK17 from APK to run
- Added dependabot for automated version updates
- Version updates
- Bump spring-boot from 2.3.12.RELEASE to 2.6.1
- Bump aws-v2 from 2.17.73 to 2.17.102
- Bump aws-java-sdk-s3 from 1.12.15 to 1.12.130
- Bump commons-io from 2.10.0 to 2.11.0
- Bump jaxb-api from 2.3.0 to 2.3.1
- Bump checkstyle from 8.44 to 9.2
- Bump xmlunit-assertj3 from 2.8.2 to 2.8.4
- Bump maven-resources-plugin from 3.1.0 to 3.2.0
- Bump maven-checkstyle-plugin from 3.1.1 to 3.1.2
- Bump maven-enforcer-plugin from 3.0.0-M3 to 3.0.0
- Bump maven-javadoc-plugin from 3.2.0 to 3.3.1
- Bump docker-maven-plugin from 0.36.1 to 0.38.1
- Bump Log4j2 to 2.15.0 (not actively used, just in case)
Problems publishing through Sonatype, only Docker container was released, not the libraries.
Please refer / update to version 2.3.2, thanks.
Problems publishing through Sonatype, only Docker container was released, not the libraries.
Please refer / update to version 2.3.2, thanks.
- Features and fixes
- Set bucket for multipart uploads, return by bucket. (Fixes #292)
- Features and fixes
- Adds option "retainFilesOnExit" to keep files after exit. Default is to remove all files. (Fixes #286)
- Fixes ignored "root" environment variable in Docker (Fixes #289)
- Support CORS headers from any host (fixes #74)
- Features and fixes
- Fixes copy part / copy object encoding issues (Fixes #279)
- Features and fixes
- Add TestContainers support
- Features and fixes
- Delete all files on JVM shutdown (Fixes #249)
- Refactorings
- Extract Docker build and integration tests to separate modules
- Docker build and integration test is now optional, run with "-DskipDocker" to skip the Docker build and the integration tests. (Fixes #235)
- Features and fixes
- ETag value now enclosed in quotation marks
- All dates are formatted in UTC timezone (Fixes #203)
- "CommonPrefixes" are now serialized als multiple elements containing one "Prefix" (Fixes #215)
- Removed several superfluous / erroneous elements like "truncated" or "part" from various responses
- Features and fixes
- Fixed potential NPE in FileStore
- Version updates
- Updated spring-boot to 2.3.12.RELEASE
- Updated aws-java-sdk-s3 to 1.12.15
- Updated awssdk V2 to 2.16.93
- Updated commons-codec to 1.15
- Updated commons-io to 2.10.0
- Updated junit-jupiter to 5.7.0
- Updated testng to 7.4.0
- Updated base Docker image to alpine-3.13_glibc-2.33
- Updated JDK bundled in Docker image to 11.0.11_9
- Removed unneeded junit-bom import
- Updated checkstyle to 8.44
- Features and fixes
- Fixes getS3Object with absolute path (Fixes #245 and #248)
- Version updates
- Updated spring-security-oauth2 from 2.3.5.RELEASE to 2.3.6.RELEASE
- Features and fixes
- Fix encoded responses for aws-cli (Fixes #257)
- Version updates
- Updated commons-io from 2.6 to 2.7
- Features and fixes
- Add encodingType as return parameter of ListBucket and ListBucketV2
- Version updates
- Updated junit from 4.13-beta-1 to 4.13.1
- Refactorings
- Changes to build system, test release
- Features and fixes
- Remove accidental JDK9+ bytecode dependency (Fixes #243)
Initial Release