Categories
Development

Service coupling

Ted Neward and Adrian Trenaman discusses doing contract-first vs. code-first services here. It’s a good read. It starts out with Neward sort of being the devils advocate, but in the end he really expresses one of my main concerns: how to enable loose coupling. Loose coupling is one of the main promises of SOA, but it’s not like you automatically get that just because you’re using webservices. Loose coupling of data has always been hard, wether you are using RMI og WS-*. WS-* has made the technology coupling easier, but data is still just as hard.

Oh, and here is a link to Extensible Content Models that he mentions.

Categories
Development

Test RegEx online

I’m no RegEx wizard, and when I need it I’m always a bit lost. Then it’s nice to test the things in an easy fashion, which I can do here.

Categories
Development

Continious Integration Servers

Continious integration is a big part of my every day work right now, and it is important that things run smoothly. If they don’t you waste tons of time on stuff that’s not really important to producing funtionality. Over the last year I have been using Continuum. I originally opted for that because CruiseControl is a bit cumbersome to configure, and I figured it would probably integrate best with Maven 2 since it’s the same group of people. I has done an alright job, but has a some weaknesses that made me look for alternatives:

  • No dependency management between projects and builds
  • Triggering a build manually actuallt triggers two builds (double the time)
  • For some strange reason our Fitnesse tests keep acting up and hanging. To prevent this I have implemented a process timeout specifically for Fitnesse, but this still slows down the turnaround time when you need to do builds.
  • No historical aggregated data

As the project grew it was actually the missing dependency features, double builds and the hangs in Fitnesse that forced me to look at other alternatives. Because it didn’t have dependency handling we got failures due to build order quite often, and when we got one failure it took almost an hour to get it back to a green state (we use lava lamps).

Enter Bamboo. 🙂 It’s a fairly new build server from Atlassian the guys also writing the excellent Confluence and Jira products. It is payware, but it is nothing compared to the time we will save. It is not a radical change compared to Continuum, but it sports:

  • Smooth user interface
  • RSS feeds
  • Dependency builds
  • Editing the build queue
  • Historical aggregated data
  • Easy and excellent pugin architecture
  • Commenting on builds
  • Test statistics

And more I havn’t checked out yet… For some weird reason I don’t get the Fitnesse hangs either. I have been testing it for a while now, and we will change over on monday. Highly recommended.

I should also look into the other build servers like TeamCity that offer a slightly different take on things. I saw it was released with Eclipse support now. Any experiences out there?