Close streams to avoid resource leaks #579
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.
Now that Collect checks for unclosed streams, I saw that form deserialization always left an open
InputStream
. I searched forStream
across the project and used try with resources.What has been done to verify that this works as intended?
Ran all tests and verify that they pass. Visually inspected the code.
Why is this the best possible solution? Were any other approaches considered?
I considered only making the
FormDefCache
change that I saw logged but I figure that it's a good time to change all of the cases I can find.How does this change affect users? Describe intentional changes to behavior and behavior that could have accidentally been affected by code changes. In other words, what are the regression risks?
There should be no user-facing changes other than a slightly reduced risk of resource leaks.
I think this is quite low risk and easy to visually verify but if there is a problem with the code, loading a form def from xml or cache, localization and selects with choice filters are at risk.
Do we need any specific form for testing your changes? If so, please attach one.
No.
Does this change require updates to documentation? If so, please file an issue here and include the link below.
No.