Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is the difference between using 'devenv' and 'msbuild' in CruiseControl.NET builds?

What is the main difference between using the <devenv> tag and the <msbuild> tag is in CruiseControl.NET?

I understand they call different executables, but sometimes I get different results (as far as pass/fail at compile time), and I would like to know why there is a difference between the two build commands.

like image 675
Bender the Greatest Avatar asked Feb 12 '11 21:02

Bender the Greatest


3 Answers

For us, the major difference is that devenv will handle installer projects (*.vdproj) while msbuild will not. If I recall correctly, msbuild is much less forgiving when it comes to finding referenced assemblies (especially if the paths are slightly off.)

like image 189
Pedro Avatar answered Nov 08 '22 10:11

Pedro


Basically devenv (Visual Studio) wraps MSBuild and add lots of Visual Studio specific properties.

To use devenv you need Visual Studio installed on your computer. To use MSBuild you only need to have the .NET framework.

like image 39
Benjamin Baumann Avatar answered Nov 08 '22 10:11

Benjamin Baumann


One of the things we discovered as we moved to TFS (which uses msbuild, at least as we have it configured) from VSS/CruiseControl.NET (which I'm guessing used devenv in our configuration) is that sometimes the ProjectGuids get out of sync.

So, Project A references Project B and the project or solution file for Project A has the ProjectGuid and path to Project B's project file. However, for whatever reason Project B's ProjectGuid has changed and Project A's project or solution file didn't get updated to reflect this.

Devenv is fine because it either just uses the file path to Project B's project file or it falls back to it. Msbuild, however, stops cold at this point because if the ProjectGuids don't match it's a no-go. At this point you can either fix it in Visual Studio (I think removing and re-adding the project works) or manually through Notepad or something.

I'll leave it up to you to decide which is better (strict adherence to the ProjectGuid or leniency when the path to the project is known)

like image 5
Tom Kidd Avatar answered Nov 08 '22 11:11

Tom Kidd