Commercial Products
Apr '09
30

It's an outrake!

posted by delano

This is a story about Ruby mixins, Rake, and hell. After releasing Rudy 0.6 last week, I started immediately on 0.7. This next version has a rebuilt DSL for the routines configuration, including a new syntax for running shell commands. The new syntax makes it possible to specify shell commands like methods. You can probably see where this is heading. First, a comparison of the old and new syntax:

Old, 0.6 syntax

routines do
  startup do
    after :root => "mkdir -p /path/2/create"
  end
end

New, 0.7 syntax

routines do
  startup do
    after :root do
      mkdir :p, "/path/2/create"
    end
  end
end

There are several advantages to using the new syntax which I’ll cover in a future post. Right now, I’ll cut to the hellish chase.

Both DSLs produce a configuration hash. Nothing else should happen when they’re parsed. And nothing else did happen until I tried running the tests with rake. The old syntax was fine, but I was getting some strange errors with the new syntax. Stuff like

Error in test/10_config/30_machines_test.rb: can't convert Fixnum into String
/usr/local/lib/ruby/1.9.1/fileutils.rb:1386:in `path'

FileUtils? That’s weird, I don’t use FileUtils. Or do I?

rake-0.8.4/lib/rake.rb includes FileUtils into the RakeFileUtils module and later includes RakeFileUtils into the global namespace. My criminy!

Offensive ruby code

module RakeFileUtils
  include FileUtils       # Nothing wrong here
end
# ... later on
include RakeFileUtils     # Noooooooo

That means when I’m running rake the following methods are accessible from everywhere: cd, mkdir, touch, rm, …! The mkdir in the DSL was being executed as it was parsed. That’s insane. Thank the Great Scott I wasn’t testing rm.

I'm Delano Mandelbaum, the founder of Solutious Inc. I've worked for companies large and small and now I'm putting everything I've learned into building great tools. I recently launched a monitoring service called Stella.

You can also find me on:

-       Delano (@solutious.com)

Solutious is a software company based in Montréal. We build testing and development tools that are both powerful and pleasant to use. All of our software is on GitHub.

This is our blog about performance, development, and getting stuff done.

-       Solutious