fix(rosetta): infuse incorrectly handles compressed assemblies #3669
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.
The behavior of
rosetta infuse
was incorrectly handled before.infuse
would always overwrite the.jsii
file with the uncompressed assembly. This PR fixes that behavior by detecting whether or not there is a compressed file in the directory, and compressing if that is the case.There are two alternative solutions I considered, primarily because I'm concerned that looking up the location of the compressed assembly can be considered a leaky abstraction:
.jsii
again to determine whether or not it is a file redirect. I did not choose this option as it involves additional loading, which will slow things down.LoadedAssembly
type to include information on whether or not the assembly was originally compressed. Then pass that into thereplaceAssembly()
function. I ultimately decided against this because it would involve changing the function signature of allloadAssemblyFromXxx
functions. It's both a breaking change, and unnecessary clutter for a single use case.Based on the reasoning above, I think what is included in this PR makes the most sense: expose an independent function,
compressedAssemblyExists
, that returns whether or not there is a file located atSPEC_FILE_NAME_COMPRESSED
.By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.