Mam to głównie działa bez niestandardowego skryptu msbuild. Oto odpowiednie ustawienia konfiguracji kompilacji TeamCity:
Ścieżki artefaktów:% system.teamcity.build.workingDir% \ MyProject \ obj \ Debug \ Package \ PackageTmp
Rodzaj biegacza: MSBuild (Runner dla plików MSBuild)
Ścieżka pliku kompilacji: MyProject \ MyProject.csproj
Katalog roboczy: taki sam jak katalog kasy
Wersja MSBuild: Microsoft .NET Framework 4.0
MSBuild ToolsVersion: 4.0
Uruchom platformę: x86
Cele: pakiet
Parametry wiersza polecenia do MSBuild.exe: / p: Configuration = Debug
Spowoduje to skompilowanie, spakowanie (z transformacją web.config) i zapisanie danych wyjściowych jako artefaktów. Brakuje tylko kopiowania danych wyjściowych do określonej lokalizacji, ale można to zrobić w innej konfiguracji kompilacji TeamCity z zależnością od artefaktów lub za pomocą skryptu msbuild.
Aktualizacja
Oto skrypt msbuild, który skompiluje, spakuje (z transformacją web.config) i skopiuje dane wyjściowe na mój serwer pomostowy
<?xml version="1.0" encoding="utf-8" ?>
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Release</Configuration>
<SolutionName>MySolution</SolutionName>
<SolutionFile>$(SolutionName).sln</SolutionFile>
<ProjectName>MyProject</ProjectName>
<ProjectFile>$(ProjectName)\$(ProjectName).csproj</ProjectFile>
</PropertyGroup>
<Target Name="Build" DependsOnTargets="BuildPackage;CopyOutput" />
<Target Name="BuildPackage">
<MSBuild Projects="$(SolutionFile)" ContinueOnError="false" Targets="Rebuild" Properties="Configuration=$(Configuration)" />
<MSBuild Projects="$(ProjectFile)" ContinueOnError="false" Targets="Package" Properties="Configuration=$(Configuration)" />
</Target>
<Target Name="CopyOutput">
<ItemGroup>
<PackagedFiles Include="$(ProjectName)\obj\$(Configuration)\Package\PackageTmp\**\*.*"/>
</ItemGroup>
<Copy SourceFiles="@(PackagedFiles)" DestinationFiles="@(PackagedFiles->'\\build02\wwwroot\$(ProjectName)\$(Configuration)\%(RecursiveDir)%(Filename)%(Extension)')"/>
</Target>
</Project>
Można również usunąć właściwości SolutionName i ProjectName ze znacznika PropertyGroup i przekazać je do msbuild.
msbuild build.xml /p:Configuration=Deploy;SolutionName=MySolution;ProjectName=MyProject
Aktualizacja 2
Ponieważ to pytanie wciąż generuje duży ruch, pomyślałem, że warto zaktualizować swoją odpowiedź za pomocą mojego obecnego skryptu, który używa Web Deploy (znanego również jako MSDeploy).
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003" DefaultTargets="Build" ToolsVersion="4.0">
<PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Release</Configuration>
<ProjectFile Condition=" '$(ProjectFile)' == '' ">$(ProjectName)\$(ProjectName).csproj</ProjectFile>
<DeployServiceUrl Condition=" '$(DeployServiceUrl)' == '' ">http://staging-server/MSDeployAgentService</DeployServiceUrl>
</PropertyGroup>
<Target Name="VerifyProperties">
<!-- Verify that we have values for all required properties -->
<Error Condition=" '$(ProjectName)' == '' " Text="ProjectName is required." />
</Target>
<Target Name="Build" DependsOnTargets="VerifyProperties">
<!-- Deploy using windows authentication -->
<MSBuild Projects="$(ProjectFile)"
Properties="Configuration=$(Configuration);
MvcBuildViews=False;
DeployOnBuild=true;
DeployTarget=MSDeployPublish;
CreatePackageOnPublish=True;
AllowUntrustedCertificate=True;
MSDeployPublishMethod=RemoteAgent;
MsDeployServiceUrl=$(DeployServiceUrl);
SkipExtraFilesOnServer=True;
UserName=;
Password=;"
ContinueOnError="false" />
</Target>
</Project>
W TeamCity, mam parametrów nazwanych env.Configuration
, env.ProjectName
a env.DeployServiceUrl
. Program uruchamiający MSBuild ma ścieżkę pliku kompilacji, a parametry są przekazywane automatycznie (nie trzeba ich określać w parametrach wiersza poleceń).
Możesz również uruchomić go z wiersza poleceń:
msbuild build.xml /p:Configuration=Staging;ProjectName=MyProject;DeployServiceUrl=http://staging-server/MSDeployAgentService