Fix #1190 by marking RequestOptions transient #1197
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
cc @stripe/api-libraries
The problem was that Gson was attempting to make certain
java.net
classes constructors accessible through reflection but this is not longer allowed in JDK16 with the default module setup.The reason that Gson was attempting to instantiate these classes was that we forgot to mark the field
StripeCollection.requestOptions
transient
(it isn't part of the JSON response). The typeRequestOptions
in turn contains ajava.net.Proxy
-type field, which was the source of the problem.I also added
ReflectionCheckingTypeAdapterFactory
which is a fakeTypeAdapterFactory
that just checks that we aren't using reflection to access anything outside ofcom.stripe
packages.In trying to replicate this problem I tried to get this project to build on JDK 16 but that required an upgrade to Gradle 7 which turned out to be too much to put into this PR. The WIP branch for that is here.
Fixes #1190