Skip to main content

Going to convert your existing Rails 1.2.1 apps to 3.2.3 ? then this post may help you!!!

Rails 1.2.1 => Rails 3.2.3


Actually, we started a product on 2007 with rails 1.2.1, at that time we were busy in the core development and we sincerely forgot to look about the rails updates!! in-between 3-4 years rails jumped to 3.x.x then only we realized that we are doing some funny things so started to review about 3.x.x 


Almost we are out-dated, but still it is not too far .. We realized that this is right time to convert our existing 1.2.1 apps to 3.2.3 so first we have started to find the practical difficulties and possibilities and learned the followings. The following is the major things for us, you guys may meet some more, but any way it will be helpful for someone. 


Lets checkout one by one.
1. RVM will helps us to manage different ruby and gems version in a same system

2. All required gems should be maintained through Gemfile, it will be useful when the time of deployment

3. You have to understand, learn and change the file route.rb

4. .rhtml is no longer in use, try to use either .html or .html.erb [I have created a script for this, let me know if any one wants] Note: .html.erb is the recommended extension

5. Need to use <%= yield %> instead of <%= @content_for_layout %> in layout

6. Here after all js, css and images are referred from ‘assets’ at /app directory instead of /public. and we can’t use /images/omie.gif here , need to use /assets/omie.gif in all of the places where we are referring images like <img> , css etc.,

7. Have to change pagination usage

@rss_pages, @rss_articles = paginate(:rss_articles, :order => "published_date DESC", :conditions => ["publication_string =  ? ", "NEJM" ])

to

@rss_articles = RssArticle.paginate(:page => params[:page], :order => "published_date DESC", :conditions => ["publication_string =  ? ", "NEJM" ])

Note: paginate will return only one object instead of two like what we have in our old (1.2.1) method, you can use the same object to get about page information, like @rss_articles.current_page, @rss_articules.next_page

In your old method you might uses, @rss_pages.current.next, here it is simple @rss_articles.next_page

8. Have to change paginate_by_sql

In your older method you might hacked the code in your application controller, but here the gem ‘will_paginate’ will do all of the required things for us. But of-course the usage of paginate_by_sql is bit different, look at our old method

@sql = “select * from lab_tests”

@unreviewed_pages,@labs_unreviewed = paginate_by_sql(LabTest, @sql,25)

but now we need to use as:

@labs_unreviewed = LabTest.paginate_by_sql(@sql,{:page => page, :per_page => 25})


9. use the function 'raw' to avoid HTML encoding
  <% a= “<div> Test </div>” %>
  <%= a %>
      The output will be a html encoded like &lt;div&lt; Test &lt;/div&gt;
  <%= raw a %>
      The output like what you expected <div> Test </div>

10. All session values (> 4kb) must maintain only through active_record_store [We can setup it through config/initializers/session_store.rb]  before it is done directly in environment.rb and this one is optional in lower version.
Note: Rails 3 uses a newer version of session schema, need to remove our old one and have to migrate the newer one.

11. We can’t use render(:layout=>false)  in viewer, of-course it is meaningless but some of us used in some of our old view pages (like /comp/_datepicker.rhtml) by our old developers. :p

12. request.url is enough instead of request.request_uri

13. request.env in enough instead of @request.evn to get environment keys

14. We need special plugins to use ‘act_as’ modifiers such as acts_as_list, acts_as_tree.
it is under in review, as per my current knowledge , we have to use ‘ancestry’.
ref: https://github.com/stefankroes/ancestry

rails plugin install acts_as_tree => but it raises error. need to review about it

15. DateTime is no longer work, use Time always

16. There is no remote tag , use remote specifier as argument with the helper
Say for eg:

We used link_to_remote, form_remote_tag remember ?? this is going to be just
link_to, form_tag

so the code
link_to_remote("Next",{:update => "unreviewed_block"}) become
link_to("Next",{:update => "unreviewed_block", :remote => true})

and the form_remote_tag code

<%
form_remote_tag(

:update => "_results_",
:url => {:controller => '/chart/demo', :action => 'add_quick_link_refs',:id => 'link_ref'}
)
%>

Other HTML code here

<% end_form_tag %>

becomes

<%
form_tag(
:update => "_results_",
:url => {:controller => '/chart/demo', :action => 'add_quick_link_refs',:id => 'link_ref'},
:remote => true
) do
%>

Other HTML code here

<% end%>

Still there exists more.. will try to update if possible.


Comments

Popular posts from this blog

Errno::ENOENT: No such file or directory

HTML to PDF conversion is very easy in rails and pdfkit will be useful in this case, wkhtmltopdf tool will be supporting tool so you can easily convert an html to pdf.  In my experience I used the following steps: gem install pdfkit -v 0.5.0 gem install wkhtmltopdf -v 0.1.2 gem install wkhtmltopdf-binary Some times this sequence will not work, so I use the following as per the instruction from  https://github.com/pdfkit/pdfkit/wiki/Installing-WKHTMLTOPDF Be careful to download the appropriate wkhtmltopdf tar ball, it depends on your os architecture, like i386 or 64 wget http://wkhtmltopdf.googlecode.com/files/wkhtmltopdf-0.9.9-static-amd64.tar.bz2 tar xvjf wkhtmltopdf-0.9.9-static-amd64.tar.bz2 mv wkhtmltopdf-amd64 /usr/local/bin/wkhtmltopdf chmod +x /usr/local/bin/wkhtmltopdf Try to convert html to pdf after restarting your web servers.  If you get any error like: Errno::ENOENT: No such file or directory then I have a str...

Redis & nginx configuration for websocket/actionCable

Start redis server => redis-server redis console => redis-cli view available databases => config get databases pubsub channels global* pubsub channels global_notification_2 pubsub channels global_notification pubsub channels * => Lists all the available channels pubsub numsub global_notification_2 => returns the number of subscribers From unix command line directly redis-cli PUBSUB CHANNELS redis-cli PUBSUB NUMSUB global_notification_2 [root@api prod-openmednet-api]# redis-cli PUBSUB CHANNELS 1) "_action_cable_internal" 2) "global_notification_2" [root@api prod-openmednet-api]# redis-cli PUBSUB CHANNELS global_notification_2 1) "global_notification_2" [root@api prod-openmednet-api]# redis-cli PUBSUB NUMSUB global_notification_2 1) "global_notification_2" 2) (integer) 2 NGINX configuration:  worker_processes   auto; worker_rlimit_nofile 500000;  #=> refer RLIM...

Postgres points

Export sql data to file copy (select * from table-name) to '/tmp/cta.pl.list' in root dnf install postgresql-server postgresql-devel service postgresql start mkdir /home/pgdir chown postgres:postgres /home/pgdir -R chmod 777 /home/pgdir -R  su postgres initdb -D /home/pgdir pg_ctl -D /home/pgdir -l /home/pgdir/log start