MSBuild:部署未包含在项目中的文件

时间:2012-10-12 04:25:03

标签: deployment msbuild pre-build-event

我在Web项目上有一个预构建事件,它使用节点缩小和连接javascript文件。这将在脚本文件夹中创建一个名为BuiltScripts的文件夹,该文件夹是脚本文件夹的副本,但文件被缩小。当我进行部署时,我想发布脚本文件夹,包括其中的BuiltScripts文件夹。为此,我将BuiltScripts文件夹添加到项目中。这不是一个理想的解决方案:

  1. 我必须检查BuiltScripts文件夹才能构建,因为其中的文件是只读的,因为解决方案在源代码管理下。这会在签入时造成麻烦,因为我签了这么多文件。
  2. 当我向项目添加新文件时,我必须确保将其添加到BuiltScripts文件夹中,否则将不会部署该文件的内置版本。
  3. 构建服务器上的构建将失败,因为BuiltScripts文件夹中的文件也只在那里读取。
  4. 在搜索文件和进行基于文本的搜索时,拥有两个具有相同名称的文件副本是个问题。
  5. 我希望构建服务器构建并将javascript文件作为预构建步骤,但我不希望将BuiltScripts文件夹添加到项目中。但是,当构建服务器在最后打包项目时,我希望它使用构建过程的输出复制BuiltScripts文件夹。我怎样才能做到这一点?

3 个答案:

答案 0 :(得分:7)

不使用项目属性的预构建事件(我认为是你的意思),而是覆盖.csproj / .vbproj文件中的BeforeBuild目标。

<Project ...>
  ...
  <Target Name="BeforeBuild">
    <!-- Create the 'BuildScripts' directory. -->
    <!-- The $(IntermediateOutputPath) reference the 'obj' folder, which I like to -->
    <!-- use for these kinds of things. -->
    <MakeDir Directories="$(IntermediateOutputPath)BuiltScripts">
      <Output PropertyName="BuildScriptsPath" TaskParameter="DirectoriesCreated" />
    </MakeDir>
    <!-- Execute the javascript minifier. -->
    <Exec Command="..." />
    <!-- Create an item group for the minified scripts so we manipulate the target path. -->
    <CreateItem Include="$(BuildScriptsPath)\*.js">
      <Output ItemName="BuiltScripts" TaskParameter="Include" />
      <Output ItemName="FileWrites" TaskParameter="Include" />
    </CreateItem>
    <!-- Add the minified scripts to the Content item group, -->
    <!-- which the deployment MSBuild inspects for files to deploy. -->
    <CreateItem Include="@(BuiltScripts)"
      AdditionalMetadata="TargetPath=scripts\%(Filename)%(Extension)">
      <Output ItemName="ContentWithTargetPath" TaskParameter="Include" />
    </CreateItem>
  </Target>
  ...
</Project>

如果文件未部署到正确的目录,您可能必须使用作为CreateItem任务输出的Content项目组的形状。请注意,我使用了项目转换来制作目标路径scripts\YourScript.js

另请注意,第一个CreateItem任务将输出填充到名为“FileWrites”的项目组中。我发现Clean目标检查该项目组以了解要删除的文件。

放入项目文件 <Import>元素之后,你应该好好去。不需要检查源代码控制,甚至构建服务器都会很高兴。

答案 1 :(得分:0)

您是否可以使用后期构建事件来运行脚本来执行您想要的操作?我使用一个将输出文件移动到与项目完全无关的位置。无论是普通批处理,VBScript / JScript还是PowerShell,您都可以做任何你想做的事情。

答案 2 :(得分:0)

我有类似的要求,但它只涉及将现有文件添加到部署包中,而不是将其作为构建的一部分生成。我发现this page上的技术很有用。