Skip to main content

Creating Continuous Integration in TFS 2010 for SharePoint 2010 projects




Setting up Continuous Integration for the code in a project is a common procedure followed in projects. The Continuous Integration (CI) becomes more important in development projects using Agile methodology or for geographically distributed teams. You can create build definitions in Team Foundation Server (TFS) 2010 to build your codebase.

But the important question is – how do you setup CI for SharePoint projects? Because by TFS 2010 build agent will not be able to compile SharePoint code. This is because SharePoint code refers to the SharePoint assemblies. And these SharePoint assemblies are not available in the server where the TFS is configured. You could ask why don’t we just install SharePoint 2010 on the same server as TFS 2010. Installing SharePoint 2010 on TFS 2010 server is not recommended for performance reasons obviously.

So, the easiest way to successfully compiling SharePoint 2010 code on TFS 2010 server is to copy the SharePoint 2010 assemblies on the build server. The process is well documented on MSDN. There is also a PowerShell script what will collect the SharePoint 2010 assemblies and install them on the build server.

Please go through the below steps to achieve the same.

•    Follow the procedures defined on MSDN – How to Build SharePoint projects with TFS team build

Also keep in mind that the script may not copy all the required assemblies to build server. Make sure you also consider the following assemblies for copy.

•    Microsoft.Office.Server.dll
•    Microsoft.Office.Server.UserProfiles.dll
•    Microsoft.SharePoint.Client.dll
•    Microsoft.SharePoint.Client.Runtime.dll
•    Microsoft.SharePoint.Client.ServerRuntime.dll
•    Microsoft.SharePoint.Linq.dll
•    Microsoft.SharePoint.Portal.dll
•    Microsoft.SharePoint.Publishing.dll
•    Microsoft.SharePoint.Taxonomy.dll
•    Microsoft.SharePoint.WorkflowActions.dll
•    Microsoft.Web.CommandUI.dll

Now that your build server can compile SharePoint codebase, you have to create a build definition in TFS 2010 for CI.

Creating Build Definition – Process Overview

1.    Make sure that your VS 2010 is connected to the TFS 2010 server. Now from the team explorer select New Build Definition on the Builds node.
 2.    Give the Build Definition a name and description
 3.    In Trigger tab, select Continuous Integration – Build each check-in.
 4.    In Workspace tab, select the source of your SharePoint codebase
 5.    In Build Defaults tab, specify output files drop folder
 6.    In Process tab, specify the solutions and projects to include in the build
 7.    In Retention Policy tab, specify how long builds should be kept. By default, last 10 builds are kept.
8.    Save the build definition

9.    Now go to the newly created build definition, right click and select Queue New Build.

10.    The build explorer window will show the build activity.

Hope this article will at least serve as a reference point for configuring TFS 2010 to build SharePoint 2010 code. Configuring CI for SharePoint projects involve much more planning and research. I would suggest you to go through the links specified in the article and in the reference section below.

Reference

http://blogs.msdn.com/b/sharepointdev/archive/2011/08/25/creating-your-first-tfs-build-process-for-sharepoint-projects.aspx
http://msdn.microsoft.com/en-us/library/ff622991.aspx
http://archive.msdn.microsoft.com/SPPwrShllTeamBuild

-    Vighnesh Bendre

Comments

Popular posts from this blog

Working with large xml files in c# .net

Working with large (huge) xml files is always a pain in the … The reason? These files can’t be loaded in to memory. On my desktop, where I have 2 gigs memory, I can’t open the file in even notepad. I was presented with a challenge recently to manipulate one such large xml file. The xml file was of 550+ MB. I know many would say I have seen bigger xml files than this. But the heart of the matter is if I can’t open 550+ MB file in notepad or in xmldocument in c#, then I can’t open any file bigger than this. And hence the logic to play with these files would remain same. The scenario: We have an xml file from which we want to remove a single node without removing its children. In the below sample xml fragment, the node has to be removed. The children nodes, must then be attached to ( node’s parent) node. One Two 100.22 GoodDay 3 4 Five 200.09 Cra...

Upgrade and Migration for SharePoint Foundation 2010

      1.1 Introduction Microsoft SharePoint Foundation 2010 has been designed for scale and performance and as such requires new hardware and software requirements. There are 3 major steps while upgrading. 1. Plan and Prepare 2. Perform a database attach upgrade 3. Verify upgrade 1.2 Plan and Prepare   Before we run any process to upgrade from Windows SharePoint Services 3.0 to Microsoft SharePoint Foundation 2010, we have to determine which upgrade approach to take. In our scenario, Database Attach Upgrade seems to be appropriate approach to follow. We can upgrade the content for the environment on a separate farm. The result is that you do not upgrade any of the services or farm settings. You can upgrade the databases in any order and upgrade several databases at the same time. While each database is being upgraded, the content in that database is not available to users. 1.2.1 Upgrade Approach A database attach upgrade enables you to move to...

Object Oriented Analysis & Design (OOAD) and Unified Modelling Language (UML)

Part 1 – Identifying Use Cases – Use Case Diagrams Recently I went through OOAD and UML training. The OOAD and UML tutorial was very impressive and I decided to share it with you. Object Oriented Analysis & Design and Unified Modelling Language is very important in a life cycle of a project. Previously I was involved in project requirement study and technical design. But this time, I learned the tricks of the trade. I discovered different tips for identifying Use Cases, Actors and Classes . In this series of posts, I am planning to take you through the process of involvement of UML in Requirement analysis and Design phase. This series will include 3 parts... Part 1. Identifying Use Cases – Use Case Diagrams Part 2. Realizing Use Cases – Sequence Diagrams Part 3. Identifying Classes – Class Diagrams For this purpose we will take commonly available sample requirement – Student Registration process. From this requirement we will identify the ACTORS and US...