diff --git a/zio-http/jvm/src/test/scala/zio/http/MediaTypeSpec.scala b/zio-http/jvm/src/test/scala/zio/http/MediaTypeSpec.scala index fd0780fa22..38e16aeca9 100644 --- a/zio-http/jvm/src/test/scala/zio/http/MediaTypeSpec.scala +++ b/zio-http/jvm/src/test/scala/zio/http/MediaTypeSpec.scala @@ -48,5 +48,13 @@ object MediaTypeSpec extends ZIOHttpSpec { ), ) }, + test("application/x-zip-compressed should be binary") { + val mediaType = MediaType.forContentType("application/x-zip-compressed") + assertTrue(mediaType.exists(_.binary)) + }, + test("text/plain should not be binary") { + val mediaType = MediaType.forContentType("text/plain") + assertTrue(mediaType.exists(!_.binary)) + }, ) } diff --git a/zio-http/shared/src/main/scala/zio/http/MediaType.scala b/zio-http/shared/src/main/scala/zio/http/MediaType.scala index 8a38bf9ac0..37a45302cb 100644 --- a/zio-http/shared/src/main/scala/zio/http/MediaType.scala +++ b/zio-http/shared/src/main/scala/zio/http/MediaType.scala @@ -64,11 +64,16 @@ object MediaType extends MediaTypes { val contentTypeParts = customMediaType.split('/') if (contentTypeParts.length == 2) { val subtypeParts = contentTypeParts(1).split(';') + // Default binary to true for unknown types unless they belong to text families + val isBinary = !customMediaType.startsWith("text/") && + !customMediaType.startsWith("application/json") && + !customMediaType.startsWith("application/xml") if (subtypeParts.length >= 1) { Some( MediaType( mainType = contentTypeParts.head, subType = subtypeParts.head, + binary = isBinary, parameters = if (subtypeParts.length >= 2) parseOptionalParameters(subtypeParts.tail) else Map.empty, ), )