From Fedora Project Wiki
Line 20: Line 20:
<!-- The actual name of your proposed change page should look something like: Changes/Your_Change_Proposal_Name.  This keeps all change proposals in the same namespace -->
<!-- The actual name of your proposed change page should look something like: Changes/Your_Change_Proposal_Name.  This keeps all change proposals in the same namespace -->


= Ruby on Rails 4.1 <!-- The name of your change proposal --> =
= Ruby on Rails 4.2 <!-- The name of your change proposal --> =


== Summary ==
== Summary ==
Line 33: Line 33:
This should link to your home wiki page so we know who you are.  
This should link to your home wiki page so we know who you are.  
-->
-->
* Name: [[User:vondruch| Vít Ondruch]], [[User:jstribny| Josef Stříbný]]
* Name: [[User:jstribny| Josef Stříbný]], [[User:vondruch| Vít Ondruch]]
<!-- Include you email address that you can be reached should people want to contact you about helping with your change, status is requested, or technical issues need to be resolved. If the change proposal is owned by a SIG, please also add a primary contact person. -->
<!-- Include you email address that you can be reached should people want to contact you about helping with your change, status is requested, or technical issues need to be resolved. If the change proposal is owned by a SIG, please also add a primary contact person. -->
* Email: vondruch@redhat.com, jstribny@redhat.com, ruby-sig@lists.fedoraproject.org
* Email: jstribny@redhat.com, vondruch@redhat.com, ruby-sig@lists.fedoraproject.org
* Release notes owner: <!--- To be assigned by docs team [[User:FASAccountName| Release notes owner name]] <email address> -->
* Release notes owner: <!--- To be assigned by docs team [[User:FASAccountName| Release notes owner name]] <email address> -->
<!--- UNCOMMENT only for Changes with assigned Shepherd (by FESCo)
<!--- UNCOMMENT only for Changes with assigned Shepherd (by FESCo)
Line 42: Line 42:


== Current status ==
== Current status ==
* Targeted release: [[Releases/21 | Fedora 21 ]]  
* Targeted release: [[Releases/22 | Fedora 22 ]]  
* Last updated: {{REVISIONYEAR}}-{{REVISIONMONTH}}-{{REVISIONDAY2}}
* Last updated: {{REVISIONYEAR}}-{{REVISIONMONTH}}-{{REVISIONDAY2}}
<!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page  
<!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page  
Line 56: Line 56:
== Detailed Description ==
== Detailed Description ==
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
The Ruby on Rails stack is evolving quickly and Fedora needs to keep pace with it. Therefore the whole Ruby on Rails stack should be updated from 4.0 in Fedora 20 to 4.1 (latest version) in Fedora 21. This will ensure that all the Ruby developers using Fedora have the latest and greatest RPM-packaged Ruby on Rails.  
The Ruby on Rails stack is evolving quickly and Fedora needs to keep pace with it. Therefore the whole Ruby on Rails stack should be updated from 4.1 in Fedora 21 to 4.2 (latest version) in Fedora 22. This will ensure that all the Ruby developers using Fedora have the latest and greatest RPM-packaged Ruby on Rails.  


== Benefit to Fedora ==
== Benefit to Fedora ==
<!-- What is the benefit to the platform?  If this is a major capability update, what has changed?  If this is a new functionality, what capabilities does it bring? Why will Fedora become a better distribution or project because of this proposal?-->
<!-- What is the benefit to the platform?  If this is a major capability update, what has changed?  If this is a new functionality, what capabilities does it bring? Why will Fedora become a better distribution or project because of this proposal?-->
This update will keep Fedora up-to-date and will ensure that the current Ruby on Rails developers stay with us as they will get support for system-packaged Ruby on Rails of the latest version. Apart from that, update to Rails 4.1 will bring a new version of rubygem-tzinfo which is able to use the zoneinfo timezone database so the users will be able to benefit from the system updates of zoneinfo files.
This update will keep Fedora up-to-date and will ensure that the current Ruby on Rails developers stay with us as they will get support for system-packaged Ruby on Rails of the latest version. Apart from that, update to Rails 4.2 will bring ActiveJob (an adapter layer on top of queuing systems like Resque, Delayed Job, Sidekiq), ActionMailer #deliver_later, GlobalID serialization and Web Console (an IRB console available in the browser).


== Scope ==
== Scope ==
Line 161: Line 161:
* To test Rails 4.1 from upstream:
* To test Rails 4.1 from upstream:
<pre>
<pre>
gem install rails -v 4.1.0
gem install rails -v 4.2.0
rails new app
rails new app
cd app && rails s
cd app && rails s
Line 179: Line 179:
rails s
rails s
</pre>
</pre>
* Go to http://127.0.0.1:3000/ and make sure you are running Rails 4.1.x
* Go to http://127.0.0.1:3000/ and make sure you are running Rails 4.2.x


== User Experience ==
== User Experience ==
<!-- If this change proposal is noticeable by its target audience, how will their experiences change as a result?  Describe what they will see or notice. -->
<!-- If this change proposal is noticeable by its target audience, how will their experiences change as a result?  Describe what they will see or notice. -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* New version of Ruby on Rails (4.1) available
* New version of Ruby on Rails (4.2) available
* The most significant Rails 4.1 features:
* The most significant Rails 4.2 features:
** Spring application preloader
** ActiveJob
** config/secrets.yml
** ActionMailer #deliver_later
** Action Pack variants
** GlobalID
** Action Mailer previews
** Web Console
* Users will be able to use rubygem-tzinfo with the system zoneinfo database
 


== Dependencies ==
== Dependencies ==
Line 225: Line 225:
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* http://api.rubyonrails.org/
* http://api.rubyonrails.org/
* http://brewhouse.io/blog/2013/12/17/whats-new-in-rails-4-1.html?brewPubStart=1
<!-- * http://brewhouse.io/blog/2013/12/17/whats-new-in-rails-4-1.html?brewPubStart=1 -->


== Release Notes ==
== Release Notes ==
Line 234: Line 234:
-->
-->


* http://weblog.rubyonrails.org/2014/4/8/Rails-4-1/
* http://weblog.rubyonrails.org/2014/4/8/Rails-4-2/
* http://guides.rubyonrails.org/4_1_release_notes.html
* http://guides.rubyonrails.org/4_2_release_notes.html


<!--  [[Category:ChangeAcceptedF21]] -->
<!--  [[Category:ChangeAcceptedF21]] -->

Revision as of 11:16, 30 September 2014


Ruby on Rails 4.2

Summary

Ruby on Rails 4.2 is the latest version of well know web framework written in Ruby.

Note: This change might be changed to Rails 5.

Owner

Current status

Detailed Description

The Ruby on Rails stack is evolving quickly and Fedora needs to keep pace with it. Therefore the whole Ruby on Rails stack should be updated from 4.1 in Fedora 21 to 4.2 (latest version) in Fedora 22. This will ensure that all the Ruby developers using Fedora have the latest and greatest RPM-packaged Ruby on Rails.

Benefit to Fedora

This update will keep Fedora up-to-date and will ensure that the current Ruby on Rails developers stay with us as they will get support for system-packaged Ruby on Rails of the latest version. Apart from that, update to Rails 4.2 will bring ActiveJob (an adapter layer on top of queuing systems like Resque, Delayed Job, Sidekiq), ActionMailer #deliver_later, GlobalID serialization and Web Console (an IRB console available in the browser).

Scope

  • Proposal owners:
  • The whole Rails stack has to be updated
  • Some dependencies of the Rails stack will need update

The packages need to be created/updated:

Package name Task Status
rubygem-spring Create
Pass pass jstribny
1076516
rubygem-arel Update to 5.0.0
Pass pass jstribny
1022695
rubygem-tzinfo Update to 1.1
Pass pass jstribny
917630
rubygem-minitest Update to 5.1
Pass pass vondruch
950392
rubygem-actionview Create
Pass pass jstribny
rubygem-activesupport Update to 4.1.x
Pass pass jstribny
rubygem-actionpack Update to 4.1.x
Pass pass jstribny
rubygem-activemodel Update to 4.1.x
Pass pass jstribny
rubygem-activerecord Update to 4.1.x
Pass pass jstribny
rubygem-actionmailer Update to 4.1.x
Pass pass jstribny
rubygem-railties Update to 4.1.x
Pass pass jstribny
rubygem-rails Update to 4.1.x
Pass pass jstribny
  • Other developers: Update Rails dependent packages to be working with Ruby on Rails 4.1
  • Release engineering: Not needed.
  • Policies and guidelines: Not needed

Upgrade/compatibility impact

Web applications build above Ruby on Rails framework might need to be updated. Official upstream upgrade guide might come handy: http://guides.rubyonrails.org/upgrading_ruby_on_rails.html

How To Test

  • No special hardware is needed.
  • To test Rails 4.1 from upstream:
gem install rails -v 4.2.0
rails new app
cd app && rails s
yum install rubygem-{rails,sqlite3}
rails new app
cd app && rails s
  • To test the complete feature including generating a new Rails app using RPM
su -c "yum install rubygem-{rails,sqlite3,coffee-rails,sass-rails,uglifier,jquery-rails,turbolinks,jbuilder,therubyracer,sdoc,spring}"
rails new app --skip-bundle && cd app
sed -i "s|# gem 'therubyracer'|gem 'therubyracer'|" Gemfile
rails s

User Experience

  • New version of Ruby on Rails (4.2) available
  • The most significant Rails 4.2 features:
    • ActiveJob
    • ActionMailer #deliver_later
    • GlobalID
    • Web Console


Dependencies

  • There are several packages, which depends on Ruby on Rails framework. All need to be tested an updated:
  • These needs to be surely updated:
    • rubygem-haml-rails to 0.5.3
  • openshift-origin-broker and any of rubygem-openshift-origin* gems might need to be updated and tested against Rails 4.1
    • Contact person: Krishna Raman <kraman@redhat.com> from OpenShift Origin team
  • Following gems don't support Rails 4.1 right now and would be broken by the update:
    • rubygem-simple_form
    • rubygem-delayed_job -> updated in rawhide
    • rubygem-delayed_job_active_record -> updated in rawhide
    • rubygem-haml-rails -> updated in rawhide

Contingency Plan

  • Contingency mechanism: None needed. Rails stack won't be updated until all its dependencies are in Rawhide. After that, it will be a simple matter of updating the core packages (and their dependencies).
  • Contingency deadline: N/A
  • Blocks release? No

Documentation

Release Notes