Roslyn gave us deterministic
builds a few years ago.
And with the addition of NuGet lock files, we can finally have guaranteed reproducible build.
I'm looking at the docs that say I can opt-in with
--use-lock-file Bootstraps use of lock file for a project. You can alternatively set RestorePackagesWithLockFile property in the project file
And will require a lock file when restoring with:
--locked-mode Enables locked mode for restore. This is useful in CI/CD scenarios where you would like to get the repeatable builds. This can be also by setting the RestoreLockedMode MSBuild property to true
I'm trying it out by modifying the Directory.Build.props
at the root of the repo:
<PropertyGroup>
...
+ <RestorePackagesWithLockFile>true</RestorePackagesWithLockFile>
</PropertyGroup>
When I run dotnet restore
, I see the lock
files generated:
benchmarks/Sentry.Benchmarks/packages.lock.json
samples/Sentry.Samples.AspNetCore.Basic/packages.lock.json
...
test/Sentry.Tests/packages.lock.json
Now if I try to restore: dotnet restore --locked-mode
, it fails completely. A summary of the output is:
/Users/bruno/git/sentry-dotnet/test/Sentry.Tests/Sentry.Tests.csproj : error NU1603: System.Private.DataContractSerialization 4.1.1 depends on System.Xml.XmlDocument (>= 4.0.1) but System.Xml.XmlDocument 4.0.1 was not found. An approximate best match of System.Xml.XmlDocument 4.3.0 was resolved. [/Users/bruno/git/sentry-dotnet/Sentry.sln]
/Users/bruno/git/sentry-dotnet/test/Sentry.Tests/Sentry.Tests.csproj : error NU1603: System.Xml.XPath.XmlDocument 4.0.1 depends on System.Xml.XmlDocument (>= 4.0.1) but System.Xml.XmlDocument 4.0.1 was not found. An approximate best match of System.Xml.XmlDocument 4.3.0 was resolved. [/Users/bruno/git/sentry-dotnet/Sentry.sln]
Restore failed in 383.47 ms for /Users/bruno/git/sentry-dotnet/test/Sentry.NLog.Tests/Sentry.NLog.Tests.csproj.
Restore failed in 370.7 ms for /Users/bruno/git/sentry-dotnet/test/Sentry.Testing/Sentry.Testing.csproj.
I must be getting something totally wrong here.
PS: I've pushed the changes to a branch and opened a PR on GitHub if one is interested to taking a look.
EDIT: Jan 2021: 1 and half year later I tried again with the .NET 5 SDK, and I still have problems: https://github.com/getsentry/sentry-dotnet/pull/731
I've tried DisableImplicitNuGetFallbackFolder
without success. The lock file seem to be platform dependant.
In CI it works properly on macOS
and Linux
but fails on Windows
. I created the lock file on a Mac. I pulled the branch on Windows and it indeed fails with:
error NU1403: Package content hash validation failed for System.Net.Http.4.3.0. The package is different than the last restore.
I'd bet money it's using the file path separator such as /
when calculating the hash and that's the reason for the failure.
Cross-platform stable lock-files should be possible by adding RuntimeIdentifiers
to your PropertyGroup
, e.g. <RuntimeIdentifiers>win-x64;linux-x64;osx-x64</RuntimeIdentifiers>
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With