Under the hood and working with .Net, TDD, Software Design, and Agile Stuff
-
Stale code is dangerous. My poor colleague tried to merge code from a class that's basically a directives file today. He had kept his code out for a month. When I was much younger my father would gently mock me about my propensity to foul out of basketball games. Guess who played the "I told you so Father" role today? (I did help him through the merge). One more time with feeling, stale code is evil. Check in often. Work in small steps so you can check in often. If you can't check in often, update your copy from the master frequently. You can keep the nasty merges away without retreating to pessimistic locking. Walking out of the office at night with modified code on your workstation needs to feel like going to work in the morning without a shower.
-
Side note: I worked with a quirky developer at my last job that used to say "Uh oh, it looks like another learning opportunity" anytime he or we suffered an episode like my colleague today with the merge.
-
Note to self: get better with SVN Merge
-
Keep the build server clean baby! The build server today caught a problem with a VS project reference that wasn't apparent on a developer workstation.
-
Frequent checkins plus the SVN Revert command == ugly code be gone
-
Cubicles == Collaboration Proof Force Field. Is there any worse way possible to arrange a development team?
-
A team building a feature is far better than a group of individuals doing tasks. It's the same amount of work, but somehow the team/feature combo working with a shared purpose produces more real value than a bunch of disconnected individuals working tasks in a project management worksheet.
-
Something smells if you sit in a meeting for an hour and are only impacted by 5 minutes of that hour.

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#.