Under the hood and working with .Net, TDD, Software Design, and Agile Stuff
The importance of a clean build server was reinforced for me this morning. We're getting ready to wrap up our first demonstration of our executable for users in a different timezone in London. Everything is wonderful on our developer workstations, but not so good on a clean box. It's the normal culprit, a 3rd party control library needs some licensing info embedded into an assembly or has to be installed or something else. We found the problem easy enough before it hit the end users because we run the client on our build box that doesn't have Visual Studio or the control libraries installed into the GAC. A clean build server finds these problems for you fast so the customer or testers don't. Whatever you do, don't put Visual Studio on your build box because it can fool you into thinking your installation script is complete when it only really works because of the assemblies that VS GAC's for you.
About Jeremy D. Miller
Jeremy began his IT career writing "Shadow IT" applications to automate his engineering documentation, then wandered into software development because it looked like more fun. Jeremy previously worked as a systems architect building mission critical supply chain software for a Fortune 100 company and learned agile development practices as a .Net consultant at ThoughtWorks, one of the pioneers of agile development. Jeremy is the author of the open source StructureMap (http://structuremap.sourceforge.net) tool for Dependency Injection with .Net and the forthcoming StoryTeller (http://storyteller.tigris.org) tool for supercharged FIT testing in .Net. Jeremy's thoughts on just about everything software related can be found on his weblog "The Shade Tree Developer" at http://codebetter.com/blogs/jeremy.miller, part of the popular CodeBetter site. Jeremy is a Microsoft MVP for C#.