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

fix(deps): update all dependencies #3451

Merged
merged 2 commits into from
Jun 7, 2024
Merged

fix(deps): update all dependencies #3451

merged 2 commits into from
Jun 7, 2024

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Jun 5, 2024

Mend Renovate

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
org.jetbrains.kotlinx:kotlinx-serialization-json 1.6.3 -> 1.7.0 age adoption passing confidence
org.jetbrains.kotlinx:kotlinx-serialization-core 1.6.3 -> 1.7.0 age adoption passing confidence
com.google.devtools.ksp (source) 2.0.0-1.0.21 -> 2.0.0-1.0.22 age adoption passing confidence
com.google.devtools.ksp:com.google.devtools.ksp.gradle.plugin (source) 2.0.0-1.0.21 -> 2.0.0-1.0.22 age adoption passing confidence
com.google.devtools.ksp:symbol-processing-api (source) 2.0.0-1.0.21 -> 2.0.0-1.0.22 age adoption passing confidence
dev.zacsweers.kctfork:ksp 0.4.1 -> 0.5.0 age adoption passing confidence
dev.zacsweers.kctfork:core 0.4.1 -> 0.5.0 age adoption passing confidence
io.kotest:kotest-property 5.9.0 -> 5.9.1 age adoption passing confidence
io.kotest:kotest-assertions-core 5.9.0 -> 5.9.1 age adoption passing confidence
io.github.classgraph:classgraph 4.8.172 -> 4.8.173 age adoption passing confidence

Release Notes

Kotlin/kotlinx.serialization (org.jetbrains.kotlinx:kotlinx-serialization-json)

v1.7.0

==================

This is a release candidate for the next version. It is based on Kotlin 2.0.0-RC3 and is fully compatible with a stable Kotlin 2.0 release.
Due to a potential breaking change (see below), it requires a compiler plugin with a version at least of 2.0.0-RC1.

Important change: priority of PolymorphicSerializer for interfaces during call to serializer() function

Non-sealed interfaces in kotlinx.serialization are always serializable with a polymorphic serializer,
even if they do not have @Serializable annotation. This also means that serializersModule.serializer<SomeInterface>() call will return you a serializer capable of polymorphism.
This function was written in a way that it unconditionally returns a PolymorphicSerializer if type argument is a non-sealed interface.
This caused problems with SerializersModule functionality, because actual module was not taken into consideration, and therefore it was impossible
to override serializer for interface using 'contextual serialization' feature. The problem is described in details here.
To overcome these problems, we had to change the behavior of this function regarding interfaces. It now looks into SerializersModule first if T is a non-sealed interface,
and only if there is no registered contextual serializer for T, it returns a polymorphic serializer.

Behavior before 1.7.0-RC:

interface SomeInterface

val module = SerializersModule {
    contextual(SomeInterface::class, CustomSomeInterfaceSerializer)
}

// Prints PolymorphicSerializer<SomeInterface>:
println(module.serializer<SomeInterface>())

Behavior in 1.7.0-RC, 1.7.0, and higher:

interface SomeInterface

val module = SerializersModule {
    contextual(SomeInterface::class, CustomSomeInterfaceSerializer)
}

// Prints CustomSomeInterfaceSerializer:
println(module.serializer<SomeInterface>())

We expect minimal impact from this change but be aware of it anyway.
Implementation details are available in this PR.

Due to the serializer() function being also a compiler intrinsic, code
of kotlinx.serialization compiler plugin also accommodates for this change in 2.0 branch. To get a consistent result from both plugin and runtime,
kotlinx.serialization compiler plugin should be at least of 2.0.0-RC1 version.
To verify so, 1.7.0-RC runtime will be rejected by older plugins.

Json configuration flag to allow commentaries

While JSON standard does not allow any kind of commentaries, they are one of the most popular extensions — for example,
commentaries are widely used in configuration files.
To support this use-case, we added a new configuration flag, allowComments.
This flag allows the parser to skip over C/Java-style commentaries in JSON input.
Note that commentaries cannot affect decoding or encoding in any way and are not stored anywhere.
See details in the PR.

Promote JsonConfiguration.explicitNulls to a stable API

This configuration flag has been around for a long time and got positive feedback.
Therefore, we are promoting it to a stable state.
It also received functionality enhancements when used with JsonConfiguration.coerceInputValues (#​2586).
See related PR for details.

oneof support in ProtoBuf

oneof fields in protobuf messages represent a set of optional fields, where the only one of them is present.
With the help of the new @ProtoOneOf annotation, you can naturally map them to Kotlin's sealed class hierarchy.
Check out the comprehensive guide for this feature here.

This functionality was contributed to us by xzk.

Other improvements and bugfixes
  • Update okio to 3.9.0 version (#​2671)
  • Add extension to access original descriptor from one made with SerialDescriptor.nullable (#​2633) (thanks to Chuckame)
  • Use @​SerialName of inline polymorphic children in Json (#​2601) (thanks to Tad Fisher)
  • Fix serializing nulls for a property of a parameterized type with a nullable upper bound with Protobuf (#​2561) (thanks to Shreck Ye)
  • Fixed type discriminator value for custom serializer that uses encodeJsonElement (#​2628)
  • Refine exception messages in case of deserializing data from JsonElement. (#​2648)
google/ksp (com.google.devtools.ksp)

v2.0.0-1.0.22

Compare Source

Important Changes

  • KSErrorType.toString() now contains the reference name it was tried to be resolved, and therefore KSErrorType is no longer a singleton. Processors relying on equality checks of that (in contrast of using KSType.isError) will need to be updated accordingly.

Issues Fixed

#​1908 KSP2: Calling KSP2 in programs does not appear to work on macOS or Windows
#​1917 KSP2's symbol-processing-aa-embeddable artifact exposes an unresolvable pre-release kotlin 2.0.20 dependency
#​1911 NoSuchMethodError when running KSP2 with Dagger (KSP 2.0.0-1.0.21)
#​1909 KSP2: default annotation arguments no longer work in 1.0.21
#​1232 Expose simple names on a missing types's synthetic declaration
#​1857 [KSP2] Modifiers are missing for property accessors
#​1924 [KSP2] Type arg becomes '*' after calling KSType.replace() with an error type
#​1948 KSP2 default annotation KClass values for built-in types use java.lang.* versions

What's Changed

Full Changelog: google/ksp@2.0.0-1.0.21...2.0.0-1.0.22

zacsweers/kotlin-compile-testing (dev.zacsweers.kctfork:ksp)

v0.5.0

Compare Source

2024-06-05

  • Update to Kotlin 2.0.0.
  • Update to KSP 2.0.0-1.0.22.
  • Change supportsK2 to true by default.
  • Change disableStandardScript to true by default. This doesn't seem to work reliably in K2 testing.
  • Update kapt class location references.
  • Support Kapt4 (AKA kapt.k2).
  • Support KSP2.
  • Introduce a new KotlinCompilation.useKsp() API to simplify KSP configuration.
  • Update to ClassGraph 4.8.173.

Note that in order to test Kapt 3 or KSP 1, you must now also set languageVersion to 1.9 in your KotlinCompilation configuration.

kotest/kotest (io.kotest:kotest-property)

v5.9.1

What's Changed
Assertions
Framework
Property-testing
Docs
Build / CI/CD / Dependency updates
New Contributors

Full Changelog: kotest/kotest@v5.9.0...v5.9.1


Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

👻 Immortal: This PR will be recreated if closed unmerged. Get config help if that's undesired.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Mend Renovate. View repository job log here.

Copy link
Contributor

github-actions bot commented Jun 5, 2024

Kover Report

Total Project Coverage 60.66%

@renovate renovate bot changed the title fix(deps): update dependency io.github.classgraph:classgraph to v4.8.173 chore(deps): update all dependencies Jun 6, 2024
@renovate renovate bot force-pushed the renovate/all branch 3 times, most recently from 1afea8c to 3f41130 Compare June 6, 2024 12:58
| datasource | package                                                       | from         | to           |
| ---------- | ------------------------------------------------------------- | ------------ | ------------ |
| maven      | org.jetbrains.kotlinx:kotlinx-serialization-json              | 1.6.3        | 1.7.0        |
| maven      | org.jetbrains.kotlinx:kotlinx-serialization-core              | 1.6.3        | 1.7.0        |
| maven      | com.google.devtools.ksp:com.google.devtools.ksp.gradle.plugin | 2.0.0-1.0.21 | 2.0.0-1.0.22 |
| maven      | com.google.devtools.ksp:symbol-processing-api                 | 2.0.0-1.0.21 | 2.0.0-1.0.22 |
| maven      | dev.zacsweers.kctfork:ksp                                     | 0.4.1        | 0.5.0        |
| maven      | dev.zacsweers.kctfork:core                                    | 0.4.1        | 0.5.0        |
| maven      | io.kotest:kotest-property                                     | 5.9.0        | 5.9.1        |
| maven      | io.kotest:kotest-assertions-core                              | 5.9.0        | 5.9.1        |
| maven      | io.github.classgraph:classgraph                               | 4.8.172      | 4.8.173      |
@renovate renovate bot changed the title chore(deps): update all dependencies fix(deps): update all dependencies Jun 6, 2024
Copy link
Contributor Author

renovate bot commented Jun 6, 2024

Edited/Blocked Notification

Renovate will not automatically rebase this PR, because it does not recognize the last commit author and assumes somebody else may have edited the PR.

You can manually request rebase by checking the rebase/retry box above.

⚠️ Warning: custom changes will be lost.

@serras serras self-requested a review June 7, 2024 07:34
@serras serras merged commit 6e7b54d into main Jun 7, 2024
11 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant