Wednesday, January 31, 2007

MCMS Installation Woes

Installing MCMS 2002 SP1a on my laptop proved quite difficult this week.  This is one product that Microsoft really did not focus on the install experience.

I first tried to install it without Visual Studio 2003.  It complained, so I got Visual Studio Installed.  It also asked for the IE Web Controls, so I downloaded those, extracted it, and ran the build.bat file.  I copied the sample app as directed and everything was working there.

I didn’t have SQL Server installed locally, so I didn’t have SQL-DMO, but the installer didn’t tell me how to get it.  It kept complaining that I didn’t have Visual Studio 2002, Visual Studio 2003, IE Web Controls, and SQL-DMO, when I clearly had 2 of those 4.

I installed the SQL Client tools and that solved the SQL-DMO requirement.  Then I found an MSI installer for IE Web Controls, and that did the trick there (apparently it doesn’t REALLY check to see if you have it, it just checks the Add/Remove Programs section).  Visual Studio 2002 isn’t really required, the wording is just off on the installer.

That was a waste of a day.  I could have gotten much more accomplished if this installation had been easier.

Sunday, January 28, 2007

NHibernate in Action

Finally.  A book on NHibernate!!!

I was the first to guess that this was the secret news so I suppose I will be getting a free copy.  Maybe I can be a technical reviewer for them (though I’m sure they already have one lined up).

Pierre Henri KuatĂ© should do an excellent job with the book, especially knowing that Bauer and King are behind him!  (If you don’t already know, they wrote the original Hibernate in Action — which is a must-have)

Friday, January 26, 2007

My Presentation on Continuous Integration

I gave a talk on Continuous Integration last night at the Houston Sark Office.  Thanks to all who attended.

We had pizza and discussed some of the processes and principles behind CI, as well as some of the tools to get you there.  I did a live demo of an app, connected to source control and a build server.

A-la Jeremy Miller, I had my CCTray audio clips setup, so when the build failed, you’d hear Napolean Dynamite say “Freakin Idiot!”

I think it went well, however for those of you who attended, I’d really like to hear your thoughts!  Please take a second to leave a comment.

Here are the files used in the demo:

continuous integration.zip (8323 KB)

(included are the sample project, cruise control config, and power-point slides)

I left out the build server installation because it was over 70mb.  It consisted of Subversion binaries, Nant, and a Cruise folder with some project state data.

I got amazing help from Jean-Paul Boodhoo, who has a 9 part NAnt starter series, which ends on a screencast of setting up CruiseControl!

Additional resources were:

Monday, January 22, 2007

My Wedding

Many of you already know, I got married to Silvia on December 30th, 2006!

We had a beautiful ceremony with lots of friends and family.  Everyone had a good time.  My wife and I are quite the happy couple!  As promised, here are some pictures from the wedding.  The entire album is avaiable on flickr.

IMG_2246

IMG_2258

IMG_2293

IMG_2325

IMG_2365

IMG_2456

IMG_2551

IMG_2604

IMG_2635

IMG_2714

IMG_2725

IMG_2741

IMG_2854

 

Saturday, January 20, 2007

Database Migrations for .NET

In my search for the one-command automated build, I’ve often stumbled upon how to deal with the database while writing code on a multi-developer project.

Most of us use source control, however only a small fraction of us actually store the database scripts in source control.  This is a powerful tool that is often missed completely.

This is a development process I see frequently:

  • get the latest version of the source from VSS
  • exclusively check-out the code files you need
  • make changes to the code and the database to enable your new features
  • check in the code once it is all done
  • do a sql compare to the dev/test databases to get a delta script
  • run the compare script in the test environment and deploy the project to test.

There are a number flaws in this process, but it doesn’t stop people from continuing along this path for an entire project.  Rather than point out everything that scares me from that list, I’ll focus on the database portion.

What’s wrong with just making changes and then doing a SQL compare?  Well, for starters… that compare script is used once and thrown away.  It is never checked into source control.  If we need to restore the state of an application as of 4 months ago, we can do it with the code, but not the database.  The database only stays on the current version, and there’s no going back.  Another drawback is that the process is a manual one, and we want to get into automation.  Lastly, SQL Compare (and SQL Delta) are both licensed tools, and not all of us can purchase them.  At home I cannot justify the cost, so I am forced to come up with something else.

The Ruby on Rails community is lucky.  Baked into the Rails framework is something called migrations.

Let’s say you’re on a ruby project for managing houses for sale.  You get a new feature request where you want to know how many bathrooms a house has (strange request, huh?).  You make the changes to model (adding a bathrooms property) but now you need the database to support it.  So you type rails script/generate migration Add_House_Bathrooms.  This will generate a ruby code file in the /project/db/migrations/xxx_Add_House_Bathrooms.rb file.  (the xxx will be replaced with sequential ordering, so rails knows what order to execute the migrations) Inside this file are 2 methods:  up and down.  This is, how to I create the changes, and how do I remove the changes.  Inside these methods you can write code that adds and removes the column you want.

So then when you need to deploy, rails knows what version the database is on (by having a version table), and can apply the migrations since that version to bring the database up to speed with the code.  If something goes wrong, it can roll the changes back to the original version (by using the down methods).

You can even create migrations that load dummy test data, or default values for static lookup tables.

It usually only takes a little while for a cool idea to make its way into the .NET world, and migrations are no exception.  The Castle Project is a collection of many RoR-esque utilities packaged into one.  One of those utilities is called Migrator, which lives in the Generator project.

To generate a migration, you type:

generate migration Add_House_Bathrooms

With this, you can enable this style of migration in .NET.  You create migrations, these end up as C# code files in your db/migrations folder.  The same concept applies.

The migrator is fairly young, but it was extracted from CastleContrib into the main Castle trunk, so that is a good sign that it is here to stay and will have active support.

When I have more time to play with this, I’ll try and post a little demo.  For now, check out the castle project at http://www.castleproject.org

What does your team do to manage database changes and enable versioning?

Friday, January 19, 2007

Free book on Domain Driven Design

InfoQ has published a small book on DDD called Domain Driven Design Quickly.  They're giving away the PDF for free!  The print version is only $22, so I'll probably buy it if I like the PDF version.

Check it out:
http://www.infoq.com/minibooks/domain-driven-design-quickly

Solid Gold CSS Resource

I came across this site today, which boats 53 CSS Techniques you can't live without.

Normally I don't like to blog just links, but this one is definitely worth it.  It covers most of the major techniques, both simple and advanced for styling web pages.

Thursday, January 18, 2007

Eliga - A New Development Methodology

My latest assignment at work was somewhat small, and the requirements were fairly straightforward so I got to work immediately.  My early requests to meet with my user were met with “let’s get a demo first.”  Given the availability of all parties involved, this took longer than I would have liked.

So here I am, 60 work-hours later, I have a fully functional, ready-to-deploy application, and I have yet to meet with my user.  Let’s sincerely hope he doesn’t decide that this isn’t what he wanted in the first place.

Then my office-mate recognized our new development process.  Ladies and gentlement, I give you Eliga! 

Eliga is the opposite of agile.  Here is our manifesto:

Forget users, they will only slow me down!  Don’t disturb me when I’m coding you peons!  I’ll hear your impressions when I’m finished!  I can’t be bothered with workflow changes!  They’re already coded and set in stone!

Tuesday, January 09, 2007

Tag I'm It! - 5 Things you didn't know about me

Well the internet sure is a tiny place. I was tagged by JP Boodhoo and Aaron Murrell.

Here it goes, 5 things that you probably didn't know about me before:

  • I was born on a farm in Oregon.  I still remember my favorite cow (Jesse) from our farm.  One day he was gone.  Where did he go?
  • I used to be insane on rollerblades.  My friends and I would jump pretty much anything.  It’s actually amazing that I didn’t break any bones jumping over staircases and stuff, especially since I am so accident prone.
  • I got my first guitar when I was 7, however I didn’t really pick up playing until 12 or so.  I still play, but not as often as I would like to.
  • I first got into computer programming watching my dad write a hangman game from scratch.  I picked up QBASIC when I was 13 or 14, and I would write little screen savers using the primitive graphics drawing routines it had.  My pinnacle QBASIC program was a hoax that my friend and I pulled on his younger brother.  We called it “DelBug” and it was supposed to remove bugs from programs, such as Doom 2, which just-so-happened to be causing him troubles.  It went through a series of fake menus and ended up pretending to format his hard drive.  It was great!  He almost wet himself when it started flashing and rebooting in a loop.
  • And lastly, I just got married!  (Pictures coming soon).  Silvia and I had a beautiful ceremony and lots of close friends and family were present.

And I’ll tag:

 

Share Dealing - Car Insurance - Renegade Motorhomes - Best Credit Cards