这个问题与 Setting the version number for .NET Core projects 非常相似,但不一样。使用撰写本文时最新的稳定版本 .NET Core (1.1) 和 VS2017,.NET Core 已从基于 JSON 的项目文件切换为 CSPROJ 文件。
所以 - 我想做的是建立一个 CI 环境,我希望能够在构建之前修改一些东西,以便用正确的版本号标记我的构建。 p>
如果我使用像这样的旧属性(SharedAssemblyInfo.cs 技巧):
[assembly: AssemblyFileVersion("3.3.3.3")]
[assembly: AssemblyVersion("4.4.4.4")]
在项目的某个地方,我得到了
CS0579 - 重复“System.Reflection.AssemblyFileVersionAttribute”
和
CS0579 - 重复“System.Reflection.AssemblyVersionAttribute”
构建时出错。
当深入研究它时,我发现在 \obj\Debug\netcoreapp1.1 中有一个在构建过程中生成的文件(在构建之前它不存在)
:
//------------------------------------------------------------------------------
// <auto-generated>
// This code was generated by a tool.
// Runtime Version:4.0.30319.42000
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------
using System;
using System.Reflection;
[assembly: System.Reflection.AssemblyCompanyAttribute("TestApplication")]
[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")]
[assembly: System.Reflection.AssemblyDescriptionAttribute("Package Description")]
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.1.99.0")]
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.1.99")]
[assembly: System.Reflection.AssemblyProductAttribute("TestApplication")]
[assembly: System.Reflection.AssemblyTitleAttribute("TestApplication")]
[assembly: System.Reflection.AssemblyVersionAttribute("1.1.99.0")]
// Generated by the MSBuild WriteCodeFragment class.
问题 - 我该怎么做?
所以我可以看到这必须以某种方式从项目属性“包页面”中输入的值生成,但我不知道在我的 CI 机器上更改这些值的正确方法是什么。
理想情况下,我希望能够在我的 (Jenkins) CI 脚本中指定所有这些信息,但我只满足于能够设置版本号。
编辑 - 更多信息
阅读第一个答案后,我想明确表示我正在创建服务和 NuGET 包 - 我更喜欢有一种对所有内容进行版本控制的方法,这就像旧的 JSON 项目,我可以在其中更新单个文件。
更新 我将编写对 CSPROJ 文件的更改脚本,在我看来,这相当老套,因为我需要修改的部分看起来像这样......
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>netcoreapp1.1</TargetFramework>
<Version>1.0.7777.0</Version>
<AssemblyVersion>1.0.8888.0</AssemblyVersion>
<FileVersion>1.0.9999.0</FileVersion>
<Company>MyCompany</Company>
<Authors>AuthorName</Authors>
<Product>ProductName</Product>
<Description />
<Copyright>Copyright © 2017</Copyright>
</PropertyGroup>
所以 - 这里的问题是有多个“PropertyGroup”元素;其他的似乎都有标签 - 但不知道 CSPROJ 是如何组合在一起的,我不能说情况总是如此。
我的工作前提是包详细信息将始终被填写,否则值标签(上面)不会出现在 XML 中 - 因此我可以使用脚本来更新适当的值。如果值标签不存在,我将不清楚将值插入到哪个 PropertyGroup 元素(以及哪个顺序,因为这似乎很重要;更改顺序阻止我在 VS2017 中加载项目)。
我仍然坚持寻找比这个更好的解决方案!
更新:在有人将此问题标记为可能重复的问题( Auto Versioning in Visual Studio 2017 (.NET Core) )之后 - 我以前没有见过这个问题,现在阅读它似乎几乎相同,只是我不想设置版本号。另外,这个问题的答案并不能解决我的问题 - 只问我在问题中问的问题。我的问题所接受的答案正是我解决问题所需的答案 - 因此,虽然另一个问题首先出现并且看起来相同 - 它根本对我没有帮助。也许模组可以提供帮助?
请您参考如下方法:
您可以通过传递 /p:PropertyName=Value
从命令行覆盖任何属性作为 dotnet restore
的参数, dotnet build
和dotnet pack
.
目前,版本组合的工作方式如下: 如果Version
未设置,请使用 VersionPrefix
(如果未设置,则默认为 1.0.0)并且 - 如果存在 - 附加 VersionSuffix
.
所有其他版本都默认为 Version
是。
例如,您可以设置 <VersionPrefix>1.2.3</VersionPrefix>
在你的.csproj
然后调用dotnet pack --version-suffix beta1
产生 YourApp.1.2.3-beta1.nupkg
(如果您有一个项目引用,并且希望应用版本后缀,则需要在此之前调用 dotnet restore /p:VersionSuffix=beta1
- 这是工具中的一个已知错误)。
当然,您也可以使用自定义变量,参见this GitHub issue举几个例子。
有关受支持的程序集属性的完整引用,我建议查看构建逻辑的源代码 here ($()
包围的值是使用的属性)。 因为我已经在谈论来源了,this是组成版本和其他一些属性的逻辑。