Почему моя задача nant не выполняется в CruiseControl (не удается найти nunit)? - PullRequest
3 голосов
/ 15 июля 2009

Мой сценарий nant не выполняется, когда я запускаю его в режиме круиз-контроля (Windows Server 2003), но отлично работает при запуске на консоли.

скрипт nant (соответствующий раздел):

<target name="compile" depends="init">
    <echo message="Build Directory is ${build.dir}" />
    <exec program="${framework::get-framework-directory(framework::get-target-framework())}\msbuild.exe"
          commandline="${solution.file} /m /t:Clean /p:Configuration=${project.config} /v:q" workingdir="." />
    <exec program="${framework::get-framework-directory(framework::get-target-framework())}\msbuild.exe"
          commandline="${solution.file} /m /t:Rebuild /p:Configuration=${project.config} /v:q" workingdir="." />
</target>

см-конфигурация:

<tasks>

    <nant>
        <executable>C:\Program Files\nant-0.86-beta1\bin\nant.exe</executable>
        <baseDirectory>C:\Builds\WorkManagement\RC1</baseDirectory>
        <buildArgs>-D:outputType=Xml</buildArgs>
        <nologo>false</nologo>
        <buildFile>WaterWorks.build</buildFile>
        <targetList>
            <target>build</target>
        </targetList>
        <buildTimeoutSeconds>1200</buildTimeoutSeconds>
    </nant>

</tasks>

Это работает, но я думаю, что недавнее обновление nunit (до 2.5.1) запутало вещи.

cc nant log:

    Buildfile: file:///C:/Builds/WorkManagement/RC1/WaterWorks.build 
    Target framework: Microsoft .NET Framework 3.5 
    Target(s) specified: build 
    [loadtasks] Scanning assembly "NCoverExplorer.NAntTasks" for extensions. 
    [property] Read-only property "outputType" cannot be overwritten. 

    clean: 

    [delete] Deleting directory 'C:\Builds\WorkManagement\RC1\build'. 

    version: 

    init: 

    [tstamp] 15 July 2009 10:31:20. 
    [mkdir] Creating directory 'C:\Builds\WorkManagement\RC1\build\net-3.5.win32-WaterWorksConsole-release\'. 
    [echo] Current Directory: C:\Builds\WorkManagement\RC1 

    drop-database: 

    create-database: 

    compile: 

    [echo] Build Directory is build/net-3.5.win32-WaterWorksConsole-release/ 
    [exec] Microsoft (R) Build Engine Version 3.5.21022.8 
    [exec] [Microsoft .NET Framework, Version 2.0.50727.1433] 
    [exec] Copyright (C) Microsoft Corporation 2007. All rights reserved. 
    [exec] Microsoft (R) Build Engine Version 3.5.21022.8 
    [exec] [Microsoft .NET Framework, Version 2.0.50727.1433] 
    [exec] Copyright (C) Microsoft Corporation 2007. All rights reserved. 
    [exec] C:\WINDOWS\Microsoft.NET\Framework\v3.5\Microsoft.Common.targets : warning MSB3245: Could not resolve this reference. Could not locate the assembly "nunit.framework, Version=2.5.1.9189, Culture=neutral, PublicKeyToken=96d09a1eb7f44a77, processorArchitecture=MSIL". Check to make sure the assembly exists on disk. If this reference is required by your code, you may get compilation errors. 
    [exec] AddressTests.cs(1,7): error CS0246: The type or namespace name 'NUnit' could not be found (are you missing a using directive or an assembly reference?) 
  :
  :

консольная команда для запуска nant:

nant /f:WaterWorks.build build

Немного озадачен! Кто-нибудь может указать мне правильное направление?

Ответы [ 2 ]

3 голосов
/ 15 июля 2009

Хорошо, вы установили версию NUnit 2.5.1.9189 на машине непрерывной сборки в GAC? (Точная версия.)

Лично мне все равно не нравится устанавливать зависимости в GAC - мне нравится, когда на них явно ссылаются относительные пути, но YMMV.

0 голосов
/ 22 февраля 2010

Изменение учетной записи службы CruiseControl Windows с локальной системы на Администратор или другую учетную запись более высокого уровня устранило аналогичную проблему, с которой мы столкнулись. По какой-то причине я еще не понял, что учетная запись локальной системы не может получить доступ к GAC должным образом.

Точно так же вы знаете, что мы используем Apache 2.2 (32-разрядная версия), CruiseControl 2.8 (32-разрядная версия Java, не CruiseControl.NET) в Windows Server 2008 R2 (x64). В NAnt мы используем Devenv.com для создания решения:

<exec program="Devenv.com" basedir="${compiler.basedir}">
  <arg line='/rebuild "Release" "${solution.file}"' />
</exec>

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

...