Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Rails3 ActionView Template Handlers doesn't work on Production Server

I am using Rails 3.2.3 / Ruby 1.9.3p125 / jbuilder (0.4.0)

In my view/mycontroller folder i got a show.json.jbuilder file. when I test everything on my local machine with rails s -e production everything works fine. The JSON gets rendered as espected.

But when I deploy to Ubuntu LTS (nginx/unicorn) I get the following Error Message:

ActionView::MissingTemplate (Missing template mycontroller/show, application/show with {:locale=>[:de, :en], :formats=>[:json], :handlers=>[:erb, :builder]}. Searched in:
  * "/home/deployer/apps/myapp/releases/#############/app/views"
):

When I check on my server if the jbuilder gem is installed with bundle show jbuilder everything seems right.

weird is that the Error message does't show :handlers=>[:erb, :builder, :jbuilder] The jbuilder handler is obviously missing. But how do I solve the problem?

Edit: The Problem is not based on Jbuilder. I tried rabl and the same problem appears.

Does any one has a hint, how to debug this?

Here some more Information:

Gemfile

source 'https://rubygems.org'

gem 'rails', '3.2.3'
gem 'jquery-rails'
gem 'mysql2'
gem 'simple_form'

# Gems used only for assets and not required
# in production environments by default.
group :assets do
  gem 'sass-rails',   '~> 3.2.3'
  gem 'coffee-rails', '~> 3.2.1'
  gem 'uglifier', '>= 1.0.3'
  gem 'bootstrap-sass', '2.0.2'
end

# Use unicorn as the app server
gem 'unicorn'

# Deploy with Capistrano
gem 'capistrano'

# for performance monitoring
gem 'newrelic_rpm'

# use asset pipline and flash
gem 'swf_fu', '~> 2.0'

gem 'geocoder'

# To use Jbuilder templates for JSON
gem 'jbuilder'

Controller

  def show

  end

show.json.jbuilder - file

 json.(@map, :id)
like image 324
HaNdTriX Avatar asked May 09 '12 16:05

HaNdTriX


2 Answers

Your jbuilder seems to be skipped.

Is jbuilder in your Gemfile.lock file?

cat Gemfile.lock | grep jbuilder

If it's missing:

RAILS_ENV=production bundle update jbuilder 

Is jbuilder loadable?

RAILS_ENV=production bundle exec rails console
> require 'jbuilder'
=> false  # this is false if jbuilder is pre-loaded

Can you build in the console?

> Jbuilder.encode{|j| j.foo :bar }
=> "{\"foo\":\"bar\"}"

Can you build in your controller action?

def the_method_you_are_testing
   raise Jbuilder.encode{|j| j.foo :bar }
end

Do you see the same error with a different server setup, such as Apache & Passenger instead of Nginx & Unicorn, or simply rails server?

rails server -e production

Do you get the same results if you change your server app from production to development?

rails server -e development

For RABL, can you try putting the RABL gem last in your Gemfile?

gem 'rails'
#...
gem 'rabl'

Try registering immediately after requiring builder?

require 'tilt'
require 'rabl'
# ...
require 'builder'
Rabl.register!

Do you get the same results with RABL master?

gem 'rabl', :git => "git://github.com/nesquena/rabl.git" 
like image 192
joelparkerhenderson Avatar answered Sep 28 '22 09:09

joelparkerhenderson


The problem is with the load order when rails boots in production. It's needs to be fixed in jbuilder, but here is a workaround:

Gemfile:

gem :jbuilder, :require=>false

config/initializers/jbuilder.rb:

require 'jbuilder'
like image 35
Sam Oliver Avatar answered Sep 28 '22 07:09

Sam Oliver