持续集成 - 构建脚本



现在我们来看下 MSBuild 文件的某些方面来了解它们的含义。了解这些方面对于持续集成循环来说很重要。

构建脚本用于构建解决方案,这将会是整个持续集成循环的一部分。我们来看一看在 Visual Studio 的.Net中创建的构建脚本,用于我们的示例解决方案。即使对于一个简单的解决方案来说,构建脚本都是相当庞大的,因此我们将详细介绍其中最重要的部分。默认情况下,构建脚本将存储在与 Visual Studio 中主解决方案同名的文件中。因此,在我们的示例中,如果你打开了文件Simple.csproj,你会看到将用来构建解决方案的所有设置。

  • 依赖于所使用的 MSBuild 版本 - 以下设置将使用 CI 服务器上安装的 MSBuild 文件。

<VisualStudioVersion Condition = "'$(VisualStudioVersion)' == 
   ''">10.0</VisualStudioVersion>

<VSToolsPath Condition = "'$(VSToolsPath)' == ''"> 
   $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)
</VSToolsPath>

<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>

<Import Project = "$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<Import Project = "$(VSToolsPath)\WebApplications\
   Microsoft.WebApplication.targets" Condition = "'$(VSToolsPath)' ! = ''" />

<Import Project = "$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\
   WebApplications\Microsoft.WebApplication.targets" Condition = "false" />
  • 正确构建解决方案所需的文件 - ItemGroup 标记将包含让项目成功构建所需的所有必要的 .Net 文件。这些文件需要相应地驻留在构建服务器上。

<ItemGroup>
   <Reference Include = "Microsoft.CSharp" />
   <Reference Include = "System.Web.DynamicData" />
   <Reference Include = "System.Web.Entity" />
   <Reference Include = "System.Web.ApplicationServices" />
   <Reference Include = "System.ComponentModel.DataAnnotations" />
   <Reference Include = "System" />
   <Reference Include = "System.Data" />
   <Reference Include = "System.Core" />
   <Reference Include = "System.Data.DataSetExtensions" />
   <Reference Include = "System.Web.Extensions" />
   <Reference Include = "System.Xml.Linq" />
   <Reference Include = "System.Drawing" />
   <Reference Include = "System.Web" />
   <Reference Include = "System.Xml" />
   <Reference Include = "System.Configuration" />
   <Reference Include = "System.Web.Services" />
   <Reference Include = "System.EnterpriseServices"/>
</ItemGroup>
  • 要使用的 Web 服务器设置 - 当我们访问持续部署主题时,你将看到如何使用 MSBuild 覆盖这些设置并将其部署到我们选择的服务器上。

<UseIIS>True</UseIIS>
<AutoAssignPort>True</AutoAssignPort>
<DevelopmentServerPort>59495</DevelopmentServerPort>
<DevelopmentServerVPath>/</DevelopmentServerVPath>
<IISUrl></IISUrl>
<NTLMAuthentication>False</NTLMAuthentication>
<UseCustomServer>False</UseCustomServer>
广告
© . All rights reserved.