Круиз-контроль .Net исключение записи - PullRequest
5 голосов
/ 26 марта 2012

У меня есть сервер круиз-контроля, на котором выполняется сборка на виртуальной машине. Все, что я сделал, это изменил управление исходным кодом с Perforce на Git, и сборка теперь не удалась.

CCNet Config

<tasks>
    <msbuild>
        <executable>C:\Windows\Microsoft.NET\Framework\v4.0.30319\MSBuild.exe</executable>
        <workingDirectory>c:\Build\Pcp_Main</workingDirectory>
        <buildArgs>/v:d Pcp.proj /target:Clobber;Build /property:Configurations="Debug;Release" /property:NUnitRedirectConsoleOutput=1</buildArgs>
        <logger>C:\Program Files\CruiseControl.NET\server\ThoughtWorks.CruiseControl.MSBuild.dll</logger>
        <timeout>2700</timeout>
    </msbuild>
</tasks>

Журнал сборки

Done Building Project "c:\Build\Pcp_Main\Pcp.proj" (Clobber;Build target(s)).

Build succeeded.
    0 Warning(s)
    0 Error(s)

Time Elapsed 00:01:32.39
MSBUILD : error MSB4015: The build stopped unexpectedly because the "ReusableLogger"   logger failed unexpectedly during shutdown.
System.IO.DirectoryNotFoundException: Could not find a part of the path  'c:\Build\Pcp_Main\Artifacts\msbuild-results-2d082e8c-0e88-4c0b-9a6b-aa0e3094cab9.xml'.
   at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
   at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath)
   at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share)
   at System.Xml.XmlDocument.Save(String filename)
   at ThoughtWorks.CruiseControl.MSBuild.XmlLogger.Shutdown()
   at Microsoft.Build.Evaluation.ProjectCollection.ReusableLogger.Shutdown()
   at Microsoft.Build.BackEnd.Logging.LoggingService.ShutdownLogger(ILogger logger)
</build>

Папка c: \ Build \ Pcp_Main \ Artifacts \ существует, и у пользователя, выполняющего сборку, есть доступ на запись в папку.

Я также попытался изменить dll для ведения журнала на Rodemeyer.MsBuildToCCnet.dll, и я получил то же исключение.

Проект также собирается без проблем из командной строки.

1 Ответ

6 голосов
/ 27 марта 2012

У проблемы была папка артефактов внутри папки сборки.Перемещение его за пределы папки сборки решило проблему.

...