Ruby on Rails 5.0
Summary
Ruby on Rails 5.0 is the latest version of well known web framework written in Ruby.
Owner
- Name: Pavel Valena, Jun Aruga, Vít Ondruch
- Email: pvalena@redhat.com, jaruga@redhat.com, vondruch@redhat.com, ruby-sig@lists.fedoraproject.org
- Release notes owner: Simon Clark (sclark) TODO
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.2 in Fedora 24 to 5.0 (latest version) in Fedora 25. 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 5.0 will bring ActionCable (A new framework that seamlessly integrates WebSockets with the rest of your Rails application), API mode (You can create a new Rails application using rails new backend --api), ActionRecord attributes that can override, and exclusive use of rails CLI over Rake.
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-actioncable | Create | |
rubygem-actionmailer | Update to 5.0.x | |
rubygem-actionpack | Update to 5.0.x | |
rubygem-actionview | Update to 5.0.x | |
rubygem-activejob | Update to 5.0.x | |
rubygem-activemodel | Update to 5.0.x | |
rubygem-activerecord | Update to 5.0.x | |
rubygem-activesupport | Update to 5.0.x | |
rubygem-arel | Update? TODO | |
rubygem-arel | Update? TODO | |
rubygem-builder | Update? TODO | |
rubygem-concurrent-ruby | Update? TODO | |
rubygem-erubis | Update? TODO | |
rubygem-globalid | Update? TODO | |
rubygem-i18n | Update? TODO | |
rubygem-json | Update? TODO | |
rubygem-loofah | Update? TODO | |
rubygem-mail | Update? TODO | |
rubygem-method_source | Update? TODO | |
rubygem-mime-types | Update? TODO | |
rubygem-mime-types-data | Create? TODO | |
rubygem-mini_portile2 | Update? TODO | |
rubygem-minitest | Update? TODO | |
rubygem-nio4r | Create | #1315801 |
rubygem-nokogiri | Update? TODO | |
rubygem-nokogiri | Update? TODO | |
rubygem-pkg-config | Update? TODO | |
rubygem-rack | Update? TODO | |
rubygem-rack-test | Update? TODO | |
rubygem-rails | Update to 5.0.x | |
rubygem-rails-deprecated_sanitizer | Update? TODO | |
rubygem-rails-dom-testing | Update? TODO | |
rubygem-rails-html-sanitizer | Update? TODO | |
rubygem-railties | Update to 5.0.x | |
rubygem-sprockets | Update? TODO | |
rubygem-sprockets-rails | Update? TODO | |
rubygem-thor | Update? TODO | |
rubygem-thread_safe | Update? TODO | |
rubygem-tzinfo | Update? TODO | |
rubygem-websocket-driver | Update? TODO | |
rubygem-websocket-extensions | Update? TODO |
- Other developers: Update Rails dependent packages to be working with Ruby on Rails 5.0
- 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 5.0 from upstream:
gem install rails -v 5.0.x rails new app cd app && rails s
- Go to http://127.0.0.1:3000/ and make sure you are running Rails 5.0.x
- To test only Rails itself
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 TODO not therubyracer but nodejs?
sudo dnf install nodejs su -c "yum install rubygem-{rails,sqlite3,coffee-rails,sass-rails,uglifier,jquery-rails,turbolinks,jbuilder,therubyracer,sdoc,spring,byebug,web-console}" rails new app --skip-bundle && cd app sed -i "s|# gem 'therubyracer'|gem 'therubyracer'|" Gemfile rails s
- Go to http://127.0.0.1:3000/ and make sure you are running Rails 5.0.x
User Experience
- New version of Ruby on Rails (5.0) available
- The most significant Rails 5.0 features:
- ActionCable: user can use WebSockets with the rest of your Rails application.
- API mode: uesr can create a Rails application for API server easily with API mode.
- Exclusive use of rails CLI over Rake. Add bin/rails test, bin/rails db:migrate. Now bin/rails is the one master command to rule them all.
- ActionRecord attributes: user can override ActiveRecord attributes if needed.
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:
- none now
- openshift-origin-broker and any of rubygem-openshift-origin* gems might need to be updated and tested against Rails 5.0
- Contact person: Krishna Raman <kraman@redhat.com> from OpenShift Origin team
- Following gems don't support Rails 5.0 right now and would be broken by the update:
- none now
- As Rails requires Ruby >= 2.2.2, the platform less than the version can not use Rails 5.0.
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
- http://weblog.rubyonrails.org/2016/6/22/Rails-5-0-rc2/ TODO Replace it as Rails 5.0 later.
- http://edgeguides.rubyonrails.org/5_0_release_notes.html