it-swarm.com.ru

Ошибка MSBuild MSB3021: невозможно скопировать файл. Не удалось найти файл 'obj\Release\myWebProject1.dll'

При использовании TeamCity для компиляции моего скрипта задачи MSBuild XML происходит сбой с этим:

[10:43:03]: myWebProject1\ myWebProject 1 .csproj (3s)
[10:43:07]: [ myWebProject1\ myWebProject1 .csproj] _CopyWebApplicationLegacy
[10:43:07]: [_CopyWebApplicationLegacy] Copy
[10:43:07]: [Copy] C:\Program Files\MSBuild\Microsoft\VisualStudio\v10.0\WebApplications\Microsoft.WebApplication.targets(131, 5): error MSB3021: Unable to copy file "obj\Release\myWebProject1.dll" to "C:\MSBUILDRELEASE\myWebProject1\\bin\myWebProject1.dll". Could not find file 'obj\Release\myWebProject1.dll'.

Когда я запускаю его локально, он работает.

Когда я сравниваю свой локальный вывод с выводом моего сервера сборки, на моем сервере сборки отсутствуют файлы. Например, файл global.asax отсутствует в выходном каталоге моего сервера сборки (но не при локальной компиляции). Это почему?

Вот мой текущий MSBuildScript:

<?xml version="1.0" encoding="utf-8"?>
<Project
  xmlns="http://schemas.Microsoft.com/developer/msbuild/2003"
  ToolsVersion="4.0"
  DefaultTargets="Build">

  <PropertyGroup>
    <OutputDir>C:\MSBUILDRELEASE</OutputDir>
  </PropertyGroup>

  <ItemGroup>
    <ProjectToBuild Include="UtilityApp.sln" >
      <Properties>OutputPath=$(OutputDir);Configuration=MSBuildRelease;Platform=x86</Properties>
    </ProjectToBuild>
  </ItemGroup>

  <Target Name="Build">
    <MSBuild Projects="@(ProjectToBuild)"/>
            <CallTarget Targets="Publish WebProject1" />
            <CallTarget Targets="Publish WebProject2" />  
  </Target>

<Target Name="Publish WebProject1">
 <RemoveDir Directories="$(OutputFolder)"
       ContinueOnError="true" />
 <MSBuild Projects="WebProject1\WebProject1.csproj"
      Targets="ResolveReferences;_CopyWebApplication"
      Properties="WebProjectOutputDir=$(OutputDir)\WebProject1\;
      OutDir=$(OutputDir)\WebProject1\;Configuration=Release;Platform=AnyCPU" />
</Target>

<Target Name="Publish WebProject2">
 <RemoveDir Directories="$(OutputFolder)"
       ContinueOnError="true" />
 <MSBuild Projects="WebProject2\WebProject2.csproj"
      Targets="ResolveReferences;_CopyWebApplication"
      Properties="WebProjectOutputDir=$(OutputDir)\WebProject2\;
      OutDir=$(OutputDir)\WebProject2\;Configuration=Release;Platform=AnyCPU" />
</Target>

</Project>

Я могу запустить этот скрипт локально, и он, кажется, работает нормально (без ошибок). Когда я запускаю его на своем сервере сборки, происходит сбой MSBuild с ошибкой MSB3021.

Теперь, когда я сравниваю локальные выходные файлы сборки с выходными файлами сборки сервера, на выходе сервера не так много файлов. Например, файл global.ASAX отсутствует в выводе на моем сервере сборки. Почему он будет работать локально для меня, но не на моем сервере сборки TeamCity? Какая разница и как я могу это исправить?

Я заметил, что сообщение об ошибке агента сборки TeamCity содержит забавный путь к каталогу: "C:\MSBUILDRELEASE\myWebProject1\bin\myWebProject1.dll"

^ Перед папкой находится две косые черты. Я не указываю, что нигде. Что дает? У меня такое чувство, что я неправильно строю свои веб-проекты (может быть, используется другой подход к задаче?). Кажется, он работает локально, но не на моем сервере сборки.

Правильно ли я строю свои веб-проекты? Это просто веб-проекты для развертывания веб-сервисов (ASMX). Помогите?

21
D3vtr0n

Хорошо, я понял это. Это несоответствие «Конфигурации». У вас есть одно здание проекта с Configuration = MSBuildRelease и два других проекта здания с Configuration = Release. MSBuild тогда ищет не в том месте для «промежуточных» сборок.

Измените свой код на это:

<?xml version="1.0" encoding="utf-8"?>
<Project
  xmlns="http://schemas.Microsoft.com/developer/msbuild/2003"
  ToolsVersion="4.0"
  DefaultTargets="Build">

  <PropertyGroup>
    <OutputDir>C:\MSBUILDRELEASE</OutputDir>
  </PropertyGroup>

  <ItemGroup>
    <ProjectToBuild Include="UtilityApp.sln" >
      <Properties>OutputPath=$(OutputDir);Configuration=MSBuildRelease;Platform=x86</Properties>
    </ProjectToBuild>
  </ItemGroup>

  <Target Name="Build">
    <MSBuild Projects="@(ProjectToBuild)"/>
            <CallTarget Targets="Publish WebProject1" />
            <CallTarget Targets="Publish WebProject2" />  
  </Target>

<Target Name="Publish WebProject1">
 <RemoveDir Directories="$(OutputFolder)"
       ContinueOnError="true" />
 <MSBuild Projects="WebProject1\WebProject1.csproj"
      Targets="ResolveReferences;_CopyWebApplication"
      Properties="WebProjectOutputDir=$(OutputDir)\WebProject1\;
      OutDir=$(OutputDir)\WebProject1\;Configuration=MSBuildRelease;Platform=AnyCPU" />
</Target>

<Target Name="Publish WebProject2">
 <RemoveDir Directories="$(OutputFolder)"
       ContinueOnError="true" />
 <MSBuild Projects="WebProject2\WebProject2.csproj"
      Targets="ResolveReferences;_CopyWebApplication"
      Properties="WebProjectOutputDir=$(OutputDir)\WebProject2\;
      OutDir=$(OutputDir)\WebProject2\;Configuration=MSBuildRelease;Platform=AnyCPU" />
</Target>

</Project>
10
Carl

Потратив 3 часа на эту ошибку, я запустил новый проект и импортировал каждый файл из старого проекта по одному. Я был в состоянии скомпилировать между каждым файлом, пока я не добавил последний файл.

Я думал, что проблема была связана с этим последним файлом, но я понял, удалив другие файлы, что эта проблема возникала только тогда, когда в моем проекте было определенное количество файлов.

Я не могу сказать, почему это работает, но я решил эту проблему, добавив/удалив пустые классы со случайными именами в свой проект.

После пары Add/Compile/Remove/Compile снова VS начал работать правильно.

3
The_Black_Smurf

Просто догадка, но я заметил, что вы строите решение с помощью Platform = x86, а затем вызываете два Web-проекта с Platform = AnyCPU. Если эти два проекта строятся решением, расположение вывода может отличаться для сборки и последующего вызова для развертывания.

Некоторые другие заметки:

Я обычно избегаю CallTarget и предпочел бы эту форму в вашем случае:

<Target Name="BuildProjects">
    <MSBuild Projects="@(ProjectToBuild)" />
</Target>
<Target Name="Build"
    DependsOnTargets="BuildProjects;Publish WebProject1;Publish WebProject2"
    />

Удвоенные косые черты обычно указывают на одну из двух вещей:

$(OutDir)\$(Intervening)\bin

Либо промежуточное свойство не оценивалось, если $ (Intervening) пусто, либо одна из частей пути уже заканчивается конечной косой чертой, если свойство $ (OutDir) уже имеет конечную косую черту.

Я никогда не знал, что у вас может быть пробел в названии цели, я должен был проверить это, чтобы быть уверенным, и это сработало!

2
Brian Kretzler

У меня была эта проблема при попытке развернуть в appharbor, для меня, исключив файл, затем снова включив исправил проблему

0
Jay

Шаг 1. Перезапустите Visual Studio.

Шаг 2: Построить >> Переконфигурировать приложение.

Я понял это правильно.

0
Geomatik Mühendisi

Хотя у меня была точно такая же ошибка; в моем случае у меня был проект развертывания Wix (v3.9) (MSI - для настольного приложения), который запустил Heat.exe для извлечения файла из выходной папки. Оказалось, что VS и Heat не играют хорошо, если у вас нет 

RunAsSeparateProcess = "истина"

атрибут, заданный в задаче предварительной сборки Heat Directory. Нашел это после многих часов разочарования. См. Wix HeatFile Task Locks Dll для деталей . HTH кто-то.

0
Shreyas Murali