2014-05-19 14 views
5

Sto caricando una lumaca su Heroku ma ottengo l'errore nel titolo dell'argomento. In primo luogo, il mio config/ambiente/file di production.rbErrore Heroku con Rails: errore di sintassi, keyword_end imprevisto, attesa end-of-input

config/environment/production.rb 
    <App Name>::Application.configure do 
    # Settings specified here will take precedence over those in config/application.rb 


    #Devise Note: 
    #config/environments/development.rb: 

    #config.action_mailer.default_url_options = { :host => 'localhost:3000' } 

    #In production, :host should be set to the actual host of your application. 


    # Code is not reloaded between requests 
    config.cache_classes = true 

    # Full error reports are disabled and caching is turned on 
    config.consider_all_requests_local  = false 
    config.action_controller.perform_caching = true 

    # Disable Rails's static asset server (Apache or nginx will already do this) 
    config.serve_static_assets = false 

    # Compress JavaScripts and CSS 
    config.assets.compress = true 

    # Don't fallback to assets pipeline if a precompiled asset is missed 
    config.assets.compile = true 

    # Generate digests for assets URLs 
    config.assets.digest = true 

    config.action_mailer.delivery_method = :smtp 

    # server smtp settings 
    config.action_mailer.smtp_settings = { 
    :openssl_verify_mode => OpenSSL::SSL::VERIFY_NONE, 
    :address => "<address>", 
    :port => 2525, 
    :domain => "<domain>", 
    :authentication => "plain", 
    :user_name => ENV["smtp_un"], 
    :password => ENV["smtp_pw"] 
    } 

    # Defaults to nil and saved in location specified by config.assets.prefix 
    # config.assets.manifest = YOUR_PATH 

    # Specifies the header that your server uses for sending files 
    # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache 
    # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx 

    # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. 
    # config.force_ssl = true 

    # See everything in the log (default is :info) 
    # config.log_level = :debug 

    # Prepend all log lines with the following tags 
    # config.log_tags = [ :subdomain, :uuid ] 

    # Use a different logger for distributed setups 
    # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new) 

    # Use a different cache store in production 
    # config.cache_store = :mem_cache_store 

    # Enable serving of images, stylesheets, and JavaScripts from an asset server 
    # config.action_controller.asset_host = "http://assets.example.com" 

    # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added) 
    # config.assets.precompile += %w(search.js) 

    # Disable delivery errors, bad email addresses will be ignored 
    config.action_mailer.raise_delivery_errors = false 

    # Enable threaded mode 
    # config.threadsafe! 

    # Enable locale fallbacks for I18n (makes lookups for any locale fall back to 
    # the I18n.default_locale when a translation can not be found) 
    config.i18n.fallbacks = true 

    # Send deprecation notices to registered listeners 
    config.active_support.deprecation = :notify 

    # Log the query plan for queries taking more than this (works 
    # with SQLite, MySQL, and PostgreSQL) 
    # config.active_record.auto_explain_threshold_in_seconds = 0.5 
end 

C'era una penzoloni end alla fine di questo file, ma ho rimosso e repushed. Heroku lancia un errore quando chiama lo rake assets:precompile mentre riceve la spinta. Tuttavia, l'errore viene generato per /tmp/build_<build_number>/config/environments/production.rb:91 non config/environments/production.rb:91. Ho cercato nella cartella /tmp ma non c'è nessuna cartella con un numero di build elencato nel mio ambiente di sviluppo. Cosa sta guardando Heroku e come posso risolvere questo errore?


A livello locale, sto usando la seguente:

$ ruby -v 
ruby 1.9.3p545 (2014-02-24 revision 45159) [x86_64-darwin11.4.2] 
$ rvm -v 
rvm 1.25.25 (stable) by Wayne E. Seguin <[email protected]>, Michal Papis <[email protected]> [https://rvm.io/] 
$ rails -v 
Rails 3.2.16 

Tuttavia, Heroku sta usando rubino 2.0.0, vedi:

$ git push heroku master 
... 
-----> Using Ruby version: ruby-2.0.0 
-----> Installing dependencies using 1.5.2 
     Ruby version change detected. Clearing bundler cache. 
     Old: ruby 2.0.0p451 (2014-02-24 revision 45167) [x86_64-linux] 
     New: ruby 2.0.0p481 (2014-05-08 revision 45883) [x86_64-linux] 

io non sono sicuro se questo conta

+0

Puoi pubblicare un link a git repo –

+0

Il tuo commento mi ha portato alla risposta corretta. Ho apportato le mie modifiche a '(nessun ramo)' e ho continuato a premere 'master' su Heroku –

+0

Dannazione voleva quella taglia! Sono contento che tu l'abbia capito :) –

risposta

3

Ho apportato le mie modifiche allo (no branch) e ho continuato a inviare master a Heroku. Passare al master e modificare config/environments/production.rb risolto il problema.

Problemi correlati