-
Notifications
You must be signed in to change notification settings - Fork 111
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
Index.json in Consolidated zip stores full path, not just hash #1416
base: release/27.3.5
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
@@ -39,7 +39,8 @@ public IReadOnlyList<SourceFile> GetSourceFiles(ILogger log) | |||
IsNupkg = false, | |||
FullNameInDestinationArchive = string.Join("/", parts.Skip(1)), | |||
FullNameInSourceArchive = entry.FullName, | |||
Hash = hasher.Hash(entry) | |||
Hash = hasher.Hash(entry), | |||
FileName = parts.Last() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
FWIW entry.Name should give you the file name
var entryName = Path.Combine(uniqueFile.Hash, uniqueFile.FullNameInDestinationArchive); | ||
var entry = zip.CreateEntry(entryName, CompressionLevel.Fastest); | ||
|
||
var entry = zip.CreateEntry(uniqueFile.EntryNameInConsolidationArchive(), CompressionLevel.Fastest); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could CompressionLevel.SmallestSize
be a good way to go? We can afford extra creation time if it makes it a smaller archive
} | ||
|
||
public string PackageId { get; } | ||
public string Version { get; } | ||
public bool IsNupkg { get; } | ||
public Dictionary<string, string[]> PlatformHashes { get; } | ||
public Dictionary<string, FileTransfer[]> PlatformHashes { get; } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
PlatformHashes
-> PlatformFiles
At the moment the index.json in consolidated calamari contains a list of hashes (aka directories) which must be consolidated in order for a given flavour of calamari to execute.
Thus when octopus is trying to construct a calamari to run, it copies ALL files from each of the listed directories into a single zip (with pathing) - and sends that over to the target.
Up until now, that works correctly.
As part of the migration to netcore - AzureWebApp required a "shim app" to wrap the capabilities in Microsoft.Deployments.Web (which does not have a netcore counterpart) - this shim-app is a netfx app - and uses newtonsoft.
When a consolidated calamari is created - the AzureWebApp now list in its hashes:
Unfortunately, this means that Newtonsoft is pulled in 3 times:
Thus - the netcore version of newtonsoft in the root-directory is overwritten with the netfx version - meaning Calamari.AzureWebApp fails to start when it is reconstructed from a consolidated calamari.
================
The solution is to replace the hashes, with a full-blown file-reference (See example below).
NOTE: Linux path separators are used as they are valid cross platform.
{ "Packages": { "Calamari": { "PackageId": "Calamari", "Version": "27.3.5-pullrequest1416-0029", "IsNupkg": true, "PlatformHashes": { "netfx": [ { "Source": "0bb288e5dfefd00cf8dd53e282a3fb6f/Calamari.nuspec", "Destination": "Calamari.nuspec" }, { "Source": "d712a5a82a446086443ce00b610d8a5d/System.Data.Common.dll", "Destination": "Cloud/System.Data.Common.dll" }, { "Source": "33b8972fa6b00b8922210ca95e5745d1/System.IO.Compression.dll", "Destination": "Cloud/System.IO.Compression.dll" }, { "Source": "bc1215a36bcb4bb151194af2fd6bd8eb/System.Memory.Data.dll", "Destination": "Cloud/System.Memory.Data.dll" }, { "Source": "55d9528d161567a19dbb71244b3ae3ce/System.ObjectModel.dll", "Destination": "Cloud/System.ObjectModel.dll" }, { "Source": "e1e2239979b853157ba75310fea7e65d/System.Runtime.Serialization.Json.dll", "Destination": "Cloud/System.Runtime.Serialization.Json.dll" }, { "Source": "d40515a84448b91315f956e6d1a6c64b/System.Text.Encoding.Extensions.dll", "Destination": "Cloud/System.Text.Encoding.Extensions.dll" },