BT

Facilitating the Spread of Knowledge and Innovation in Professional Software Development

Write for InfoQ

Topics

Choose your language

InfoQ Homepage News Rails 2.0 - What's a Newbie to Do?

Rails 2.0 - What's a Newbie to Do?

This item in japanese

Bookmarks
With the recent release of Rails 2.0.0, 2.0.1, and now 2.0.2 in rapid succession, the Rails support discussion groups have had frequent inquiries from newcomers to Rails who are having problems following popular tutorials such as the books "Agile Web Development with Rails" by Dave Thomas and David Heinemeier Hansson. The Thomas/Hansson book, which is commonly referred to as AWDR is already in it's second edition which is just about a year old and covers Rails 1.2.

While the difference between Rails 2.0 and its predecessor Rails 1.2 are far less drastic than those between Rails 1.2 and Rails 1.1, enough potholes are there to trip up the unsuspecting newbie.

One of the themes of Rails 2.0 was to make it leaner. This means that some features which were previously standard have been removed from the core and relegated to plugins. For someone following a tutorial based on an 1.2, this can be a stumbling block. Two examples:
  1.  Many tutorials are base on using MySql as the database adapter because it has always been the Rails 'default.' Up to now, that is, Rails 2.0.3 changed the default to Sqlite3. AWDR describes how to use Sqlite3, later in the book, but a newbie following along might not be equipped to troubleshoot the problem without help at the time it's encountered.
  2. The early parts of AWDR make use of the dynamic scaffolding feature of Rails which now is only available after the scaffolding plugin has been installed with:
              script/plugin install scaffolding 
    Other such "missing" features in Rails 2.0 include AJAX in-place-editing and auto-completion, and some of the popular acts_as_x model extensions. Someone following an aging tutorial might try running the command:
              script/plugin list 
    to see if one of the available plugins looks like it might provide a missing feature.
Another option is to use Rails 1.2.6, work through the tutorial(s) and then consider moving to 2.0. First, install the 1.2.6 version of Rails:
    gem install rails --version 1.2.6 
Then, either remove any rails 2.0.x gems you have installed, or specify the version on the rails command when you generate your project:
    rails _1.2.6_ my_rails_project 
Most commands installed by gems are wrappers which invoke the code in the gem, and allow you to specify the version of the gem used by calling them with a version number surrounded by underscores as the first argument.

There are already some books which cover Rails 2.0 available such as "The Rails Way" by Obie Fernandez, but so far they all seem to be targeted as resources for those with a little more Rails experience under the belt. Some of the "Classic" Rails literature will no doubt be updated as time goes on, and newer tutorials will join them.

In the meantime the Rails newbie has the choice of either struggling through the changes as they are encountered, or perhaps more wisely using the version of Rails which matches the tutorial until a certain level of mastery has been achieved.

Rate this Article

Adoption
Style

Hello stranger!

You need to Register an InfoQ account or or login to post comments. But there's so much more behind being registered.

Get the most out of the InfoQ experience.

Allowed html: a,b,br,blockquote,i,li,pre,u,ul,p

Community comments

  • Misinformations?

    by Kristof Jozsa,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    I haven't read it myself, but all the reviews seem to claim Obie Fernandez's book as a throughout one aimed towards beginners. On the other hand, it has been confirmed several times through the 2.0 release cycle since the beta series that the AWDR book will NOT get an update for Rails 2.0.x. I might be wrong in both cases so someone please correct me, as I'd also like to know these for sure!

  • In correct book title

    by Nicholas Henry,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    You mention the book "Active Web Development with Rails" - the title of this book in incorrect. The correct title is "Agile Web Development with Rails".

  • Some inaccuracies

    by Chu Yeow Cheah,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    Just wanted to point out some inaccuracies in the article. The new default database of SQLite3 was actually introduced in 2.0.2 (2.0.3 is not out yet). It may have been a bad move publicity-wise but you can simply do 'rails -d mysql myapp' to generate a Rails app pre-configured for MySQL as detailed in weblog.rubyonrails.org/2007/12/17/rails-2-0-2-s....

    Also, dynamic scaffolding is completely deprecated/removed - even installing the plugin you mention will still cause failures in using dynamic scaffolds. Mind you, normal scaffolding still works, just not _dynamic_ scaffolding.

  • openrorbook = (german) Rails 2.0 Book also for beginners

    by der kaan,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    OpenRoRBook is a free German language book that covers Rails 2.0 development. It's availabe on www.rubyonrails.de/newsitems/98. We hope to find someone who have time and fun to translate the book into English in the future.

  • Rails 2.0 Screencast and Tutorial

    by Fabio Akita,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    I think these can help as well:

  • Peepcode Screencasts

    by Matt Henry,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    The Akita on Rails screencasts are great. Rails newbies might also check out Geoff Grossenbach's intro screencasts at Peepcode. They come with notes that point out the spots where Rails 2.0 differs from 1.2. Very handy for those just starting out.

  • Re: Misinformations?

    by Matt Henry,

    Your message is awaiting moderation. Thank you for participating in the discussion.

    The Obie Fernandez book is awesome, but he's careful to say in the preface that it's not really intended for beginners. Most of the reviews I've seen say the same.

Allowed html: a,b,br,blockquote,i,li,pre,u,ul,p

Allowed html: a,b,br,blockquote,i,li,pre,u,ul,p

BT