Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add test to verify TemporalAccessor serialization. #638

Merged
merged 3 commits into from
Aug 3, 2023
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
package io.micronaut.cache.serialize

import io.micronaut.core.convert.DefaultMutableConversionService
import spock.lang.Issue
import spock.lang.Specification

import java.nio.charset.Charset
import java.time.LocalDate
import java.time.LocalDateTime
import java.time.OffsetDateTime
import java.time.OffsetTime
import java.time.ZoneId
import java.time.ZoneOffset
import java.time.ZonedDateTime

class DefaultStringKeySerializerSpec extends Specification {

@Issue("https://github.com/micronaut-projects/micronaut-cache/issues/404")
wetted marked this conversation as resolved.
Show resolved Hide resolved
void "test TemporalAccessor serialization"() {

given:
final serializer = new DefaultStringKeySerializer("cacheName", Charset.defaultCharset(), new DefaultMutableConversionService())

expect:
new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12, result: 2022-08-12, #0]

Condition failed with Exception: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | 2022-08-12 | java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: HourOfDay | at java.base/java.time.LocalDate.get0(LocalDate.java:709) | at java.base/java.time.LocalDate.getLong(LocalDate.java:688) | at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308) | at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763) | at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402) | at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849) | at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823) | at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153) | at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155) | at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60) | at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25) <io.micronaut.cache.serialize.DefaultStringKeySerializer@5a6efe33 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@71668a67 cacheName=cacheName charset=UTF-8>
Raw output
Condition failed with Exception:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
           |          |         |
           |          |         2022-08-12
           |          java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: HourOfDay
           |          	at java.base/java.time.LocalDate.get0(LocalDate.java:709)
           |          	at java.base/java.time.LocalDate.getLong(LocalDate.java:688)
           |          	at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
           |          	at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
           |          	at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
           |          	at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
           |          	at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
           |          	at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
           <io.micronaut.cache.serialize.DefaultStringKeySerializer@5a6efe33 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@71668a67 cacheName=cacheName charset=UTF-8>

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
Caused by: java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: HourOfDay
	at java.base@17.0.8/java.time.LocalDate.get0(LocalDate.java:709)
	at java.base@17.0.8/java.time.LocalDate.getLong(LocalDate.java:688)
	at java.base@17.0.8/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
	at app//io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
	at app//io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
	at app//io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
	... 1 more

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12T12:19, result: 2022-08-12T12:19:00, #1]

Condition failed with Exception: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | 2022-08-12T12:19 | java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: OffsetSeconds | at java.base/java.time.LocalDate.get0(LocalDate.java:709) | at java.base/java.time.LocalDate.getLong(LocalDate.java:688) | at java.base/java.time.LocalDateTime.getLong(LocalDateTime.java:718) | at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308) | at java.base/java.time.format.DateTimeFormatterBuilder$OffsetIdPrinterParser.format(DateTimeFormatterBuilder.java:3628) | at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402) | at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849) | at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823) | at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153) | at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155) | at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60) | at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25) <io.micronaut.cache.serialize.DefaultStringKeySerializer@2c0fefac conversionService=io.micronaut.core.convert.DefaultMutableConversionService@6fbc7853 cacheName=cacheName charset=UTF-8>
Raw output
Condition failed with Exception:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
           |          |         |
           |          |         2022-08-12T12:19
           |          java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: OffsetSeconds
           |          	at java.base/java.time.LocalDate.get0(LocalDate.java:709)
           |          	at java.base/java.time.LocalDate.getLong(LocalDate.java:688)
           |          	at java.base/java.time.LocalDateTime.getLong(LocalDateTime.java:718)
           |          	at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$OffsetIdPrinterParser.format(DateTimeFormatterBuilder.java:3628)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
           |          	at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
           |          	at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
           |          	at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
           |          	at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
           |          	at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
           <io.micronaut.cache.serialize.DefaultStringKeySerializer@2c0fefac conversionService=io.micronaut.core.convert.DefaultMutableConversionService@6fbc7853 cacheName=cacheName charset=UTF-8>

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
Caused by: java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: OffsetSeconds
	at java.base@17.0.8/java.time.LocalDate.get0(LocalDate.java:709)
	at java.base@17.0.8/java.time.LocalDate.getLong(LocalDate.java:688)
	at java.base@17.0.8/java.time.LocalDateTime.getLong(LocalDateTime.java:718)
	at java.base@17.0.8/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$OffsetIdPrinterParser.format(DateTimeFormatterBuilder.java:3628)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
	at app//io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
	at app//io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
	at app//io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
	... 1 more

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 12:19+05:00, result: 12:19:00+05:00, #2]

Condition failed with Exception: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | 12:19+05:00 | java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth | at java.base/java.time.LocalTime.get0(LocalTime.java:703) | at java.base/java.time.LocalTime.getLong(LocalTime.java:680) | at java.base/java.time.OffsetTime.getLong(OffsetTime.java:536) | at java.base/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205) | at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308) | at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763) | at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402) | at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849) | at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823) | at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153) | at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155) | at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60) | at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25) <io.micronaut.cache.serialize.DefaultStringKeySerializer@19d3f6ad conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1b69fc07 cacheName=cacheName charset=UTF-8>
Raw output
Condition failed with Exception:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
           |          |         |
           |          |         12:19+05:00
           |          java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth
           |          	at java.base/java.time.LocalTime.get0(LocalTime.java:703)
           |          	at java.base/java.time.LocalTime.getLong(LocalTime.java:680)
           |          	at java.base/java.time.OffsetTime.getLong(OffsetTime.java:536)
           |          	at java.base/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205)
           |          	at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
           |          	at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
           |          	at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
           |          	at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
           |          	at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
           |          	at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
           <io.micronaut.cache.serialize.DefaultStringKeySerializer@19d3f6ad conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1b69fc07 cacheName=cacheName charset=UTF-8>

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
Caused by: java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth
	at java.base@17.0.8/java.time.LocalTime.get0(LocalTime.java:703)
	at java.base@17.0.8/java.time.LocalTime.getLong(LocalTime.java:680)
	at java.base@17.0.8/java.time.OffsetTime.getLong(OffsetTime.java:536)
	at java.base@17.0.8/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205)
	at java.base@17.0.8/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
	at app//io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
	at app//io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
	at app//io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
	... 1 more

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12T12:19+05:00, result: 2022-08-12T12:19:00+05:00, #3]

Condition not satisfied: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | | | | | | | | | | | UTF-8 | 2022-08-12T12:19:00+05:00 | | | | | | false | | | | | | 17 differences (58% similarity) | | | | | | cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+05(-)00 | | | | | | cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+05(:)00 | | | | | class java.nio.charset.Charset | | | | [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 53, 48, 48] | | | 2022-08-12T12:19+05:00 | | Optional[[B@54a6ef6] | <io.micronaut.cache.serialize.DefaultStringKeySerializer@2ca1e49a conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1aee6d14 cacheName=cacheName charset=UTF-8> cacheName:Fri, 12 Aug 2022 12:19:00 +0500
Raw output
Condition not satisfied:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
|          |          |         |             |      |       |                 |              |
|          |          |         |             |      |       UTF-8             |              2022-08-12T12:19:00+05:00
|          |          |         |             |      |                         false
|          |          |         |             |      |                         17 differences (58% similarity)
|          |          |         |             |      |                         cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+05(-)00
|          |          |         |             |      |                         cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+05(:)00
|          |          |         |             |      class java.nio.charset.Charset
|          |          |         |             [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 53, 48, 48]
|          |          |         2022-08-12T12:19+05:00
|          |          Optional[[B@54a6ef6]
|          <io.micronaut.cache.serialize.DefaultStringKeySerializer@2ca1e49a conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1aee6d14 cacheName=cacheName charset=UTF-8>
cacheName:Fri, 12 Aug 2022 12:19:00 +0500

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12T12:19+05:00, result: 2022-08-12T12:19:00+05:00, #4]

Condition not satisfied: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | | | | | | | | | | | UTF-8 | 2022-08-12T12:19:00+05:00 | | | | | | false | | | | | | 17 differences (58% similarity) | | | | | | cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+05(-)00 | | | | | | cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+05(:)00 | | | | | class java.nio.charset.Charset | | | | [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 53, 48, 48] | | | 2022-08-12T12:19+05:00 | | Optional[[B@722b3ba2] | <io.micronaut.cache.serialize.DefaultStringKeySerializer@361f26b4 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1d9ff1e2 cacheName=cacheName charset=UTF-8> cacheName:Fri, 12 Aug 2022 12:19:00 +0500
Raw output
Condition not satisfied:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
|          |          |         |             |      |       |                 |              |
|          |          |         |             |      |       UTF-8             |              2022-08-12T12:19:00+05:00
|          |          |         |             |      |                         false
|          |          |         |             |      |                         17 differences (58% similarity)
|          |          |         |             |      |                         cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+05(-)00
|          |          |         |             |      |                         cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+05(:)00
|          |          |         |             |      class java.nio.charset.Charset
|          |          |         |             [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 53, 48, 48]
|          |          |         2022-08-12T12:19+05:00
|          |          Optional[[B@722b3ba2]
|          <io.micronaut.cache.serialize.DefaultStringKeySerializer@361f26b4 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@1d9ff1e2 cacheName=cacheName charset=UTF-8>
cacheName:Fri, 12 Aug 2022 12:19:00 +0500

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12T12:19+02:00[Europe/Berlin], result: 2022-08-12T12:19:00+02:00[Europe/Berlin], #5]

Condition not satisfied: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | | | | | | | | | | | UTF-8 | 2022-08-12T12:19:00+02:00[Europe/Berlin] | | | | | | false | | | | | | 32 differences (36% similarity) | | | | | | cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+02(-)00(---------------) | | | | | | cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+02(:)00([Europe/Berlin]) | | | | | class java.nio.charset.Charset | | | | [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 50, 48, 48] | | | 2022-08-12T12:19+02:00[Europe/Berlin] | | Optional[[B@2bc59ab7] | <io.micronaut.cache.serialize.DefaultStringKeySerializer@32caae19 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@60e67c06 cacheName=cacheName charset=UTF-8> cacheName:Fri, 12 Aug 2022 12:19:00 +0200
Raw output
Condition not satisfied:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
|          |          |         |             |      |       |                 |              |
|          |          |         |             |      |       UTF-8             |              2022-08-12T12:19:00+02:00[Europe/Berlin]
|          |          |         |             |      |                         false
|          |          |         |             |      |                         32 differences (36% similarity)
|          |          |         |             |      |                         cacheName:(Fri, 1)2( Aug )2(022 )12:19:00( )+02(-)00(---------------)
|          |          |         |             |      |                         cacheName:(202---)2(-08-1)2(T---)12:19:00(-)+02(:)00([Europe/Berlin])
|          |          |         |             |      class java.nio.charset.Charset
|          |          |         |             [99, 97, 99, 104, 101, 78, 97, 109, 101, 58, 70, 114, 105, 44, 32, 49, 50, 32, 65, 117, 103, 32, 50, 48, 50, 50, 32, 49, 50, 58, 49, 57, 58, 48, 48, 32, 43, 48, 50, 48, 48]
|          |          |         2022-08-12T12:19+02:00[Europe/Berlin]
|          |          Optional[[B@2bc59ab7]
|          <io.micronaut.cache.serialize.DefaultStringKeySerializer@32caae19 conversionService=io.micronaut.core.convert.DefaultMutableConversionService@60e67c06 cacheName=cacheName charset=UTF-8>
cacheName:Fri, 12 Aug 2022 12:19:00 +0200

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)

Check failure on line 25 in cache-core/src/test/groovy/io/micronaut/cache/serialize/DefaultStringKeySerializerSpec.groovy

View workflow job for this annotation

GitHub Actions / Java CI / Test Report (17)

DefaultStringKeySerializerSpec.test TemporalAccessor serialization [sourceObject: 2022-08-12T12:19:00Z, result: 2022-08-12T12:19:00Z, #6]

Condition failed with Exception: new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result" | | | | | 2022-08-12T12:19:00Z | java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth | at java.base/java.time.Instant.getLong(Instant.java:604) | at java.base/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205) | at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308) | at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763) | at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402) | at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849) | at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823) | at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153) | at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155) | at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74) | at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60) | at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25) <io.micronaut.cache.serialize.DefaultStringKeySerializer@799971ac conversionService=io.micronaut.core.convert.DefaultMutableConversionService@59c08cf1 cacheName=cacheName charset=UTF-8>
Raw output
Condition failed with Exception:

new String(serializer.serialize(sourceObject).get(), Charset.defaultCharset()) == "cacheName:$result"
           |          |         |
           |          |         2022-08-12T12:19:00Z
           |          java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth
           |          	at java.base/java.time.Instant.getLong(Instant.java:604)
           |          	at java.base/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205)
           |          	at java.base/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
           |          	at java.base/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
           |          	at java.base/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
           |          	at java.base/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
           |          	at io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
           |          	at io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
           |          	at io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
           |          	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
           <io.micronaut.cache.serialize.DefaultStringKeySerializer@799971ac conversionService=io.micronaut.core.convert.DefaultMutableConversionService@59c08cf1 cacheName=cacheName charset=UTF-8>

	at io.micronaut.cache.serialize.DefaultStringKeySerializerSpec.test TemporalAccessor serialization(DefaultStringKeySerializerSpec.groovy:25)
Caused by: java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: DayOfMonth
	at java.base@17.0.8/java.time.Instant.getLong(Instant.java:604)
	at java.base@17.0.8/java.time.format.DateTimePrintContext$1.getLong(DateTimePrintContext.java:205)
	at java.base@17.0.8/java.time.format.DateTimePrintContext.getValue(DateTimePrintContext.java:308)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$NumberPrinterParser.format(DateTimeFormatterBuilder.java:2763)
	at java.base@17.0.8/java.time.format.DateTimeFormatterBuilder$CompositePrinterParser.format(DateTimeFormatterBuilder.java:2402)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.formatTo(DateTimeFormatter.java:1849)
	at java.base@17.0.8/java.time.format.DateTimeFormatter.format(DateTimeFormatter.java:1823)
	at app//io.micronaut.runtime.converters.time.TimeConverterRegistrar.lambda$register$3(TimeConverterRegistrar.java:153)
	at app//io.micronaut.core.convert.DefaultMutableConversionService.convert(DefaultMutableConversionService.java:155)
	at app//io.micronaut.core.convert.ConversionService.convert(ConversionService.java:68)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.toByteArray(DefaultStringKeySerializer.java:74)
	at app//io.micronaut.cache.serialize.DefaultStringKeySerializer.serialize(DefaultStringKeySerializer.java:60)
	... 1 more

where:
sourceObject | result
LocalDate.of(2022, 8, 12) | "2022-08-12"
LocalDateTime.of(2022, 8, 12, 12, 19) | "2022-08-12T12:19:00"
OffsetTime.of(12, 19, 0, 0, ZoneOffset.ofHours(5)) | "12:19:00+05:00"
OffsetDateTime.of(2022, 8, 12, 12, 19, 0, 0, ZoneOffset.ofHours(5)) | "2022-08-12T12:19:00+05:00"
ZonedDateTime.of(2022, 8, 12, 12, 19, 0, 0, ZoneOffset.ofHours(5)) | "2022-08-12T12:19:00+05:00"
ZonedDateTime.of(2022, 8, 12, 12, 19, 0, 0, ZoneId.of("Europe/Berlin")) | "2022-08-12T12:19:00+02:00[Europe/Berlin]"
LocalDateTime.of(2022, 8, 12, 12, 19).toInstant(ZoneOffset.UTC) | "2022-08-12T12:19:00Z"
}
}
Loading