<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/css" href="/stylesheets/rss.css"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/">
  <channel>
    <title>has_many :thoughts</title>
    <link>http://blog.kineticweb.com</link>
    <language>en-us</language>
    <ttl>40</ttl>
    <description>Musings from a Ruby on Rails development team</description>
    <item>
      <title>My RailsConf 2008 picks</title>
      <description>&lt;p&gt;Here are my tentative selections for RailsConf 2008. Looking forward to everything!&lt;/p&gt;


Thursday:
	&lt;ul&gt;
	&lt;li&gt;Refactoring Your Rails Application&lt;/li&gt;
		&lt;li&gt;Developer Testing Tricks&lt;/li&gt;
	&lt;/ul&gt;


Friday:
	&lt;ul&gt;
	&lt;li&gt;Entrepreneurs On Rails&lt;/li&gt;
		&lt;li&gt;Hosting and the Woes&lt;/li&gt;
		&lt;li&gt;Faster, Better, &lt;span class="caps"&gt;ORM&lt;/span&gt; with DataMapper&lt;/li&gt;
		&lt;li&gt;&amp;#8220;Design Patterns&amp;#8221; in Ruby&lt;/li&gt;
		&lt;li&gt;UI Design on Rails&lt;/li&gt;
	&lt;/ul&gt;


Saturday:
	&lt;ul&gt;
	&lt;li&gt;Optimizing Rails&lt;/li&gt;
		&lt;li&gt;Asynchronous Processing with Ruby on Rails&lt;/li&gt;
		&lt;li&gt;Fast, Sexy, and Svelte: Our Kind of Rails Testing&lt;/li&gt;
		&lt;li&gt;Integration Testing with RSpec&amp;#8217;s Story Runner&lt;/li&gt;
		&lt;li&gt;Metaprogramming and Ruby Internals for Rails Programmers&lt;/li&gt;
	&lt;/ul&gt;


Sunday:
	&lt;ul&gt;
	&lt;li&gt;De-Railing: Smashing the Rails Stack&lt;/li&gt;
		&lt;li&gt;Oh the Fail I&amp;#8217;ve Known&lt;/li&gt;
		&lt;li&gt;Building an app in 48 hours &amp;#8211; A Rails Rumble Case Study&lt;/li&gt;
	&lt;/ul&gt;</description>
      <pubDate>Wed, 28 May 2008 21:16:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:07aa64bb-0106-4e20-9313-631dec00bbd9</guid>
      <author>Colin A. Bartlett</author>
      <link>http://blog.kineticweb.com/articles/2008/05/28/my-railsconf-2008-picks</link>
      <category>RailsConf</category>
      <category>railsconf08</category>
    </item>
    <item>
      <title>RailsConf 2008 - Justin's Schedule</title>
      <description>&lt;p&gt;Below is the schedule I came up with when going over the sessions available this year at RailsConf&amp;#8230; Going to try to make these, if not switch with Colin so we cover the conference well&amp;#8230; very glad to see some advanced classes! Would have loved a &lt;span class="caps"&gt;REAL&lt;/span&gt; advanced Rspec session though.&lt;/p&gt;


	&lt;p&gt;8:30am Thursday, 05/29/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1862"&gt;Meta-programming Ruby for Fun &amp;amp; Profit&lt;/a&gt;
Portland Ballroom 252&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2650"&gt;Neal Ford&lt;/a&gt; (ThoughtWorks), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2751"&gt;Patrick Farley&lt;/a&gt; (ThoughtWorks)
Ruby is the revenge of the Smalltalkers. Not since Smalltalk has a language had such powerful meta-programming facilities. While this may seem like a minor feature, it turns out that surgical meta-programming allows solutions to problems that are clearer, more concise, more maintainable, and take orders of magnitudes fewer lines of code. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1862"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;1:30pm Thursday, 05/29/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1213"&gt;Powering &lt;span class="caps"&gt;AIR&lt;/span&gt; Applications with Rails&lt;/a&gt;
Portland Ballroom 252
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/467"&gt;Tony Hillerson&lt;/a&gt; (EffectiveUI), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2576"&gt;Daniel Wanja&lt;/a&gt; (Nouvelles Solutions, Inc.)
Adobe&amp;#8217;s &lt;span class="caps"&gt;AIR&lt;/span&gt; platform offers developers familiar with web technology the tools to create desktop applications. Come and learn how to drive an &lt;span class="caps"&gt;HTML&lt;/span&gt; and a Flex &lt;span class="caps"&gt;AIR&lt;/span&gt; application with Rails using RubyAMF. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1213"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;10:45am Friday, 05/30/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2495"&gt;Entrepreneurs On Rails&lt;/a&gt;
Portland Ballroom 251&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/4997"&gt;Dan Benjamin&lt;/a&gt; (Rails Machine)
Many of the people working with Rails are independent developers, doing freelance work or running small development shops. This makes sense &amp;#8211; Rails provides a great framework for an indy developer, making it easy to work with with designers and other developers. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2495"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;11:45am Friday, 05/30/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2043"&gt;Hosting and the Woes&lt;/a&gt;
Portland Ballroom 255&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/1583"&gt;Ezra Zygmuntowicz&lt;/a&gt; (EngineYard), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2863"&gt;Jamie van Dyke&lt;/a&gt; (Engine Yard), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2866"&gt;Tom Mornini&lt;/a&gt; (Engine Yard)
What are the day to day issues with Rails hosting. How can they be solved, and what are the best practise methods of avoiding them. Engine Yard have extensive experience with high volume Rails applications and would like to talk about what we&amp;#8217;ve learned and what our customers have learnt. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2043"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;1:50pm Friday, 05/30/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1883"&gt;Faster, Better, &lt;span class="caps"&gt;ORM&lt;/span&gt; with DataMapper&lt;/a&gt;
Portland Ballroom 256&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2686"&gt;Yehuda Katz&lt;/a&gt; (EngineYard)
This session will cover using the DataMapper &lt;span class="caps"&gt;ORM&lt;/span&gt; with Ruby on Rails, and go in-depth into its code. It will focus on integration with Ruby on Rails and provide an advanced-level overview of the codebase and design philosophy. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1883"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;2:50pm Friday, 05/30/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/4342"&gt;Rubinius &amp;#8211; Under the Hood and Behind the Curtain&lt;/a&gt;
&lt;span class="caps"&gt;D135&lt;/span&gt;-136&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/13749"&gt;Evan Phoenix&lt;/a&gt; (Engine Yard), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/22997"&gt;Brian Ford&lt;/a&gt; (Engine Yard), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/13767"&gt;Wilson Bilkovich&lt;/a&gt; (Engine Yard)
Rubinius is a virtual machine built from the ground up to provide a robust, high-performance runtime for Ruby code. The Rubinius team is guiding the development of 20,000+ specifications that define the Ruby language. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/4342"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;4:25pm Friday, 05/30/2008&lt;br&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1963"&gt;The Launch: Dos and Don&amp;#8217;ts of Real Life Deploys&lt;/a&gt;
Portland Ballroom 255&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2518"&gt;Chris Wanstrath&lt;/a&gt; (Err Free)
There&amp;#8217;s more to launching an app than &amp;#8220;cap deploy&amp;#8221;&amp;#8212;the process is as much a psychological challenge as a technical one. So, what does it take to launch an app you can depend on and be proud of? With a handful of production launches under his belt, Chris will talk about the big picture and little details of bringing your site to life. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1963"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;10:45am Saturday, 05/31/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2042"&gt;Assembling Pages Last: Edge Caching, &lt;span class="caps"&gt;ESI&lt;/span&gt; &amp;amp; Rails&lt;/a&gt;
Portland Ballroom 256&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2594"&gt;Aaron Batalion&lt;/a&gt; (Hungry Machine &lt;span class="caps"&gt;LLC&lt;/span&gt;)
When working on scaling Rails to millions of users/day with complex personalization, caching becomes essential. This talk will cover edge caching, edge side includes (ESI) in Rails, and partial page caching higher in the stack. It will also cover &lt;span class="caps"&gt;ESI&lt;/span&gt; as a fabric for assembling heterogeneous applications into a single, cacheable web experience. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2042"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;11:45am Saturday, 05/31/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1755"&gt;Advanced RESTful Rails&lt;/a&gt;
Portland Ballroom 252&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/1467"&gt;Ben Scofield&lt;/a&gt; (Viget Labs)
Designing RESTful systems in Rails carries many benefits. It is not a problem-free approach, however; there are accessibility issues with the standard conventions, and some functions are more difficult to map to resources than others. In this session, we&amp;#8217;ll look at solutions for these (and other) problems that arise when you take &lt;span class="caps"&gt;REST&lt;/span&gt; beyond the standard examples. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1755"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;1:50pm Saturday, 05/31/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2031"&gt;Build Your Own Distributed, Self-Configuring Rails Cluster&lt;/a&gt;
Portland Ballroom 251&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2833"&gt;Dave Fayram&lt;/a&gt; (Powerset, Inc), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2520"&gt;Tom Preston-Werner&lt;/a&gt; (Powerset, Inc.)
Fuzed is a Rails server stack written in Erlang that can replace standard mongrel/reverse proxy architectures. It focuses on reliability and ease of deployment in distributed environments. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2031"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;2:50pm Saturday, 05/31/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1871"&gt;Custom Nginx Modules: Accelerate Rails, &lt;span class="caps"&gt;HTTP&lt;/span&gt; Tricks&lt;/a&gt;
General Portland Ballroom 251&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2451"&gt;Adam Wiggins&lt;/a&gt; (Heroku)
Got a Rails app that needs even more speed? Adam Wiggins of Heroku will show you how to write a custom Nginx module to bring blinding speed to critical code paths (and do &lt;span class="caps"&gt;HTTP&lt;/span&gt; tricks that can&amp;#8217;t be done with Rails and Mongrel alone), using examples from Heroku&amp;#8217;s own authentication module ngx_heroku_gate. Dust off your C compiler and prepare to push the limits of nginx, Rails, and &lt;span class="caps"&gt;HTTP&lt;/span&gt;. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1871"&gt;Read more.&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;4:25pm Saturday, 05/31/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1948"&gt;Metaprogramming and Ruby Internals for Rails Programmers&lt;/a&gt;
Portland Ballroom 256&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2751"&gt;Patrick Farley&lt;/a&gt; (ThoughtWorks)
Rails programmers are Ruby programmers. In this session we&amp;#8217;ll cover some useful Ruby metaprogramming techniques as used in real world Rails applications and extensions. Then we&amp;#8217;ll dig deep into &lt;span class="caps"&gt;MRI&lt;/span&gt; and JRuby source to gain a nuanced understanding of the implementation details of Singletons, Mixins and the Ruby Object model. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1948"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;10:45am Sunday, 06/01/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2021"&gt;Scaling Ruby from the Inside Out&lt;/a&gt;
Portland Ballroom 252&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/1583"&gt;Ezra Zygmuntowicz&lt;/a&gt; (EngineYard)
This is a talk about what it takes to &lt;strong&gt;really&lt;/strong&gt; scale Ruby applications. We will not only examine all the aspects of hardware and web server configurations, we will also look at scaling the ruby interpreter itself. Including performance quirks of &lt;span class="caps"&gt;MRI&lt;/span&gt; and how Rubinius is set to fix a lot of these problems. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/2021"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;11:45am Sunday, 06/01/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1945"&gt;Everyday DTrace on &lt;span class="caps"&gt;OSX&lt;/span&gt;: A Guide To Using DTrace for Your Full Application Stack&lt;/a&gt;
Portland Ballroom 251&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2752"&gt;Scott Barron&lt;/a&gt; (EdgeCase), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2696"&gt;Chad Humphries&lt;/a&gt; (EdgeCase)
Have you ever wanted to know why a part of your application is slow? How about how long that query takes? Wouldn&amp;#8217;t it be nice if you could get this type of information for ruby, rails, and the database server in one place? You can now with DTrace on &lt;span class="caps"&gt;OSX 10&lt;/span&gt;.5. We&amp;#8217;ll show you how to best use this tool-chain to debug, profile, and gather more information about your application. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1945"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;


	&lt;p&gt;1:50pm Sunday, 06/01/2008&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1935"&gt;Building an app in 48 hours &amp;#8211; A Rails Rumble Case Study&lt;/a&gt;
Portland Ballroom 251&lt;br /&gt;
&lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2321"&gt;Josh Owens&lt;/a&gt; (Intridea, Inc/Web 2.0 Show Podcast), &lt;a href="http://en.oreilly.com/rails2008/public/schedule/speaker/2024"&gt;Chris Selmer&lt;/a&gt; (Intridea, Inc.)
So you want to build a Rails app quickly? Competitors in the Rails Rumble had 48 hours to design, develop, and deploy a complete application. We&#226;&#8364;&#8482;ll take you through the development processes of the winning four-man Tasty Planner team, and compare it with those of the one-man Your Pet Records team. We&#226;&#8364;&#8482;ll discuss techniques, short-cuts, helpers, and Rails plugins that helped speed development. &lt;a href="http://en.oreilly.com/rails2008/public/schedule/detail/1935"&gt;Read more&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;/p&gt;</description>
      <pubDate>Wed, 28 May 2008 20:52:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:0ba193b0-24aa-467a-a485-9616d4296435</guid>
      <author>Justin Reagor</author>
      <link>http://blog.kineticweb.com/articles/2008/05/28/railsconf-2008-justins-schedule</link>
      <category>RailsConf</category>
      <category>Rails</category>
      <category>ruby</category>
    </item>
    <item>
      <title>Automagical RSpec: Sake Spec for your Scripts</title>
      <description>&lt;p&gt;I&amp;#8217;ve been trying to attempt at spec&amp;#8217;ing every single tiny lil script and bit of code I write a long the way. This means I needed a quick, cross directory/app/project script that would run specs from the current directory.&lt;/p&gt;


	&lt;p&gt;I love Rake, and I love Sake even more.. and Sake was born to do this sort of system-wide task&amp;#8230; so lets get to the code!&lt;/p&gt;


	&lt;p&gt;Throw this in your ~/.sake and smoke it:&lt;/p&gt;


&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;desc 'runs specs in the current project, with its own SpecHelper setup'
task 'spec' do
  require 'rake'
  require 'spec/rake/spectask'

  module SpecBase
    def self.included(klass)
      Object.class_eval do
        require 'rubygems'
        require 'spec'
        Spec::Runner.configure { |config| config.mock_with(:mocha) }
      end
    end
  end

  Spec::Rake::SpecTask.new(&amp;quot;spec&amp;quot;) do |t|
    t.spec_opts  = [&amp;quot;--format&amp;quot;, &amp;quot;specdoc&amp;quot;, &amp;quot;--colour&amp;quot;]
    t.spec_files = Dir[&amp;quot;spec/**/*_spec.rb&amp;quot;, &amp;quot;./*_spec.rb&amp;quot;].sort
    include SpecBase
  end
end&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;As the description string states, this task encapsulates spec_helper.rb and runs any _spec.rb files in the current directory. This makes it very quick for writing specs for small scripts.&lt;/p&gt;


	&lt;p&gt;Of course, I try to maintain a convention of naming my spec&amp;#8217;s just like in Spec::Rails. So if I&amp;#8217;m writing a eat_bacon.rb script, I use eat_bacon_spec.rb as the spec file.&lt;/p&gt;


	&lt;p&gt;Also note: I&amp;#8217;m loading Mocha up there, so make sure to take that out if you don&amp;#8217;t need it.&lt;/p&gt;


	&lt;p&gt;Enjoy, with Sake!&lt;/p&gt;</description>
      <pubDate>Wed, 16 Apr 2008 21:18:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:80b44ade-e540-4673-978a-e85bf302bd7a</guid>
      <author>Justin Reagor</author>
      <link>http://blog.kineticweb.com/articles/2008/04/16/automagical-rspec-sake-spec-for-your-scripts</link>
      <category>rspec</category>
      <category>sake</category>
      <category>tasks</category>
    </item>
    <item>
      <title>Our server names</title>
      <description>&lt;p&gt;Every good tech company needs a sensible naming scheme for their servers. Ours has always been &amp;#8220;film directors Colin likes&amp;#8221;.  I figured it would be fun to publish our list here. So, in no particular order, these are the server names we&amp;#8217;re currently using:&lt;/p&gt;


	&lt;ul&gt;
	&lt;li&gt;Richard &lt;strong&gt;Linklater&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Alfred &lt;strong&gt;Hitchcock&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Joel and Ethan &lt;strong&gt;Coen&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Quentin &lt;strong&gt;Tarantino&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;M. Night &lt;strong&gt;Shyamalan&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Robert &lt;strong&gt;Altman&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;David &lt;strong&gt;Cronenberg&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Martin &lt;strong&gt;Scorsese&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Dario &lt;strong&gt;Argento&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Guy &lt;strong&gt;Ritchie&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Wes &lt;strong&gt;Anderson&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Darren &lt;strong&gt;Aronofksy&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;George &lt;strong&gt;Lucas&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Rob &lt;strong&gt;Reiner&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Robert &lt;strong&gt;Zemeckis&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Stanley &lt;strong&gt;Kubrick&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Steven &lt;strong&gt;Spielberg&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;David &lt;strong&gt;Fincher&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Hayao &lt;strong&gt;Miyazaki&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Terry &lt;strong&gt;Gilliam&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;Danny &lt;strong&gt;Boyle&lt;/strong&gt;&lt;/li&gt;
		&lt;li&gt;John &lt;strong&gt;Hughes&lt;/strong&gt;&lt;/li&gt;
	&lt;/ul&gt;


	&lt;p&gt;Some others have been retired over the years but we try to recycle names when we can. Any suggestions? Baz Luhrmann, Joel Schumacher, Alan J. Pakula are all on the short list we keep.&lt;/p&gt;</description>
      <pubDate>Wed, 16 Apr 2008 08:59:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:9f8cb7eb-ffc9-4aa2-a1f3-2465a43f66ad</guid>
      <author>Colin A. Bartlett</author>
      <link>http://blog.kineticweb.com/articles/2008/04/16/our-server-names</link>
    </item>
    <item>
      <title>Automagical RSpec: Shared Example Loading from Separate Files</title>
      <description>&lt;p&gt;I especially love Ruby because I can quickly customize it to my tastes and likes. With out regard for anyone else&amp;#8217;s feeling but my own. With that said, I do try and use this power for good. For the better of my office mates.&lt;/p&gt;


	&lt;p&gt;Earlier today I was doing some of this&amp;#8230;&lt;/p&gt;


&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;describe Admin::ModelsController do
  shared_examples_for 'all admin pages' do
    code code code here...
  end

  describe 'when logged in' do
    more specific controller specs here...
  end
end&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;...and I thought to myself that I would really just love to do this&amp;#8230;&lt;/p&gt;


&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;describe Admin::ModelsController do
  it_should_behave_like 'all admin pages'

  describe 'when logged in' do
    more specific controller specs here...
  end
end&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;Loading it from some separated out module underneath the specific &lt;span class="caps"&gt;MVC&lt;/span&gt; spec/ sub directories.&lt;/p&gt;


	&lt;p&gt;I&amp;#8217;ll explain more in a second&amp;#8230; but using some code I was working on before, thanks to storing it in Yojimbo, I quickly wrote this into my spec_helper.rb&amp;#8230;&lt;/p&gt;


&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;Dir[File.dirname(__FILE__)+'/**/shared/*'].each { |group| 
  require group
  include Object.const_get(group.match(/.*[\/]{1}([\w]*)[.rb]./).captures.first.camelize)
}&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;As you can tell from the code, it will go through all sub-directories of the current one (RAILS_ROOT/spec in this case) and rummage for &amp;#8220;shared/&amp;#8221; directories. It will then try and load modules, within these files, named after the file&amp;#8217;s file name.&lt;/p&gt;


	&lt;p&gt;Without having to require and include each single file/module throughout your spec files (or the parent spec_helper).&lt;/p&gt;


	&lt;p&gt;Examples:&lt;/p&gt;


spec/controllers/shared/all_admin_pages.rb
&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;module AllAdminPages
  shared_examples_for 'all admin pages' do
    code code code here...
  end
end&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;Of course this is a smallish hack that I think really cleans out my specs. I generally got the idea from app/views/shared or app/views/layouts/shared directories in Rails. Keeping small shared view partials in separate, nicely organized sub-directories.&lt;/p&gt;


	&lt;p&gt;Let the flaming commence! j/k ;)&lt;/p&gt;</description>
      <pubDate>Tue, 15 Apr 2008 21:05:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:f91f1f27-f4a2-4167-b2a1-580d1905bc27</guid>
      <author>Justin Reagor</author>
      <link>http://blog.kineticweb.com/articles/2008/04/15/automagical-rspec-shared-example-loading-from-separate-files</link>
      <category>rspec</category>
      <category>ruby</category>
      <category>hacks</category>
    </item>
    <item>
      <title>Introduction to the Internet and eCommerce</title>
      <description>&lt;p&gt;Each year I volunteer a few hours of my time to speak to a group of individuals interested in starting their own business as part of the &lt;a href="http://www.readingscore.com"&gt;Reading &lt;span class="caps"&gt;SCORE&lt;/span&gt;&lt;/a&gt; program. It&amp;#8217;s always great to see new entrepreneurs and to relay whatever little nuggets of experience I might have gained during my trials and tribulations starting a company (or two).&lt;/p&gt;


	&lt;p&gt;I speak for a short time about the basics of building a website for your start-up business and then I answer questions. I&amp;#8217;ve been using the same presentation now for ages. (I don&amp;#8217;t even recall if I created it or if it was given to me.) But it was in need a refresh.&lt;/p&gt;


	&lt;p&gt;So I&amp;#8217;ve drafted a whole new version which is more my style &amp;#8211; less boring bullets and more basic points and pictures to help trigger me to recall things and prompt questions.&lt;/p&gt;


	&lt;p&gt;For those that attended, you can &lt;a href="http://blog.kineticweb.com/files/score_internet_slides.zip"&gt;download the slides here&lt;/a&gt;.&lt;/p&gt;</description>
      <pubDate>Mon, 14 Apr 2008 16:13:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:c2a57130-db17-48f1-98d8-22126bc395f2</guid>
      <author>Colin A. Bartlett</author>
      <link>http://blog.kineticweb.com/articles/2008/04/14/introduction-to-the-internet-and-ecommerce</link>
      <category>Business</category>
      <category>presentation</category>
    </item>
    <item>
      <title>request.xhr? is only for Prototype?</title>
      <description>&lt;p&gt;I just found this lovely tid-bit of information in the &lt;a href="http://api.rubyonrails.org/classes/ActionController/AbstractRequest.html#M000407"&gt;ActionController::AbstractRequest&lt;/a&gt; class&amp;#8230;&lt;/p&gt;


&lt;div class="typocode"&gt;&lt;pre&gt;&lt;code class="typocode_shell "&gt;# Returns true if the request's &amp;quot;X-Requested-With&amp;quot; header contains
# &amp;quot;XMLHttpRequest&amp;quot;. (The Prototype Javascript library sends this header with
# every Ajax request.)
def xml_http_request?
    !(@env['HTTP_X_REQUESTED_WITH'] !~ /XMLHttpRequest/i)
end
alias xhr? :xml_http_request?&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;

	&lt;p&gt;Mental note for later: Make sure to set this header when using jQuery in future projects&amp;#8230;. Not sure if jQuery does this already (probably not).&lt;/p&gt;</description>
      <pubDate>Wed, 26 Mar 2008 13:12:00 -0400</pubDate>
      <guid isPermaLink="false">urn:uuid:cf7dfbc4-7c45-41ed-b53d-24f0aa3e9021</guid>
      <author>Justin Reagor</author>
      <link>http://blog.kineticweb.com/articles/2008/03/26/request-xhr-is-only-for-prototype</link>
      <category>actionpack</category>
      <category>Javascript</category>
      <category>AJAX</category>
    </item>
    <item>
      <title>Highrise API and tagging</title>
      <description>&lt;p&gt;Like &lt;a href="http://forum.37signals.com/highrise/forums/15/topics/1312"&gt;many&lt;/a&gt;, I was disappointed that the &lt;a href="http://www.highrisehq.com/"&gt;Highrise&lt;/a&gt; &lt;a href="http://developer.37signals.com/highrise/"&gt;&lt;span class="caps"&gt;API&lt;/span&gt;&lt;/a&gt; does not support tagging of people. However, I found a way to easily add the capability to the 37signals-supplied Ruby wrapper class, even if it is unsupported. I added a &lt;code&gt;#tag!&lt;/code&gt; instance method to the Person class and used a call directly to the site, not through the &lt;span class="caps"&gt;API&lt;/span&gt;.&lt;/p&gt;


&lt;pre&gt;
class Person &amp;lt; Subject
  ...
  def tag!(tag_name)
    `curl -s -d 'name=#{tag_name}' #{ENV['HIGHRISE_URL']}parties/#{id}/tags`
  end
end
&lt;/pre&gt;

	&lt;p&gt;The output is a bunch of javascript to update the page to reflect the change, but one can safely ignore this. The tag is added and everything works great. Not sure how well this would work on Windows, as the &lt;code&gt;curl&lt;/code&gt; command-line program is likely unavailable.&lt;/p&gt;


	&lt;p&gt;We use this method in our latest project to add appropriate tags to people as they are created. It helps us segment people added to Highrise for the project from the rest of our contacts in Highrise.&lt;/p&gt;</description>
      <pubDate>Mon, 18 Feb 2008 13:28:00 -0500</pubDate>
      <guid isPermaLink="false">urn:uuid:8162daad-bcb1-4b7f-a3df-e1c8c8a840e0</guid>
      <author>Colin A. Bartlett</author>
      <link>http://blog.kineticweb.com/articles/2008/02/18/highrise-api-and-tagging</link>
      <category>highrise</category>
      <category>ruby</category>
      <category>Rails</category>
      <category>37signals</category>
    </item>
  </channel>
</rss>
