/ / Koudoku działa dobrze lokalnie, ale ulega awarii na Heroku - ruby-on-rails, heroku

Koudoku działa dobrze lokalnie, ale zawiesza się na Heroku - ruby-on-rails, heroku

Niedawno zainstalowałem Klejnot Koudoku i działa świetnie na moim komputerze, ale kiedy naciskamdo heroku, aplikacja ma błąd, a dzienniki wyglądają jak poniżej. Czy ktoś wie, dlaczego otrzymuję błąd dotyczący application_helper? Zwykle nie mam tego konkretnego pliku w moim projekcie, ale wydaje mi się, że silnik Koudoku dodaje go w czasie wykonywania. Dziękuję za pomoc!

EDYTOWAĆ:Nie mam odpowiedzi, ale podejrzewam, że może to być spowodowane sposobem inicjalizacji silników. Ustawiłem następujący wiersz w moim pliku config / application.rb: config.assets.initialize_on_precompile = false Myślę, że może to uniemożliwić załadowanie inicjalizatora, chyba że dodam coś do mojego lib / engine.rb na podstawie tego posta na blogu: http://octothought.com/precompiling-assets-for-a-rails-engine-on-heroku/

Czy ktoś może mi pomóc zrozumieć, jak mogę dostosowaćkod, który dodają do swojego pliku engine.rb do mojej sytuacji? Mówią: „Magicznym zaklęciem do tego jest przekazanie specjalnej opcji: group =>: asset or: group =>: all do inicjatora twojego silnika i upewnij się, że skonfigurowałeś prekompilację w tym inicjatorze." ale potem w rzeczywistym kodzie mówią o silnikach rakietowych, co mnie dezorientuje.

initializer "RocketEngine asset precompile", :group => :all do |app|
app.config.assets.precompile += %w(
rocket.css
rocket.js
)
end

To jest mój rzeczywisty błąd w Heroku:

 heroku[web.1]: State changed from crashed to starting
heroku[web.1]: Starting process with command `bin/rails server -p 54469 -e production`
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/actionpack-4.2.0.beta2/lib/abstract_controller/helpers.rb:144:in `modules_for_helpers"
app[web.1]: => Booting WEBrick
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/bundler/gems/koudoku-9e73e64e5520/app/controllers/koudoku/application_controller.rb:4:in `<class:ApplicationController>"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/engine.rb:465:in `each"
app[web.1]:    from /app/vendor/ruby-2.1.5/lib/ruby/2.1.0/tsort.rb:226:in `block in tsort_each"
app[web.1]:    from /app/vendor/ruby-2.1.5/lib/ruby/2.1.0/tsort.rb:205:in `tsort_each"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/activesupport-4.2.0.beta2/lib/active_support/dependencies.rb:308:in `depend_on"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/engine.rb:467:in `block in eager_load!"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/rack-1.6.0/lib/rack/server.rb:208:in `app"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/commands/commands_tasks.rb:80:in `block in server"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/commands/commands_tasks.rb:75:in `tap"
app[web.1]:    from bin/rails:8:in `<main>"
app[web.1]: Exiting
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/actionpack-4.2.0.beta2/lib/abstract_controller/helpers.rb:148:in `block in modules_for_helpers"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/activesupport-4.2.0.beta2/lib/active_support/dependencies.rb:248:in `require"
app[web.1]:    from /app/config.ru:3:in `block in <main>"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/commands/commands_tasks.rb:39:in `run_command!"
app[web.1]:    from bin/rails:8:in `require"
app[web.1]: => Run `rails server -h` for more startup options
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/actionpack-4.2.0.beta2/lib/abstract_controller/helpers.rb:108:in `helper"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/activesupport-4.2.0.beta2/lib/active_support/dependencies.rb:349:in `require_or_load"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/engine.rb:465:in `eager_load!"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/application/finisher.rb:56:in `each"
app[web.1]:    from /app/vendor/ruby-2.1.5/lib/ruby/2.1.0/tsort.rb:427:in `each_strongly_connected_component_from"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/rack-1.6.0/lib/rack/builder.rb:49:in `eval"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/rack-1.6.0/lib/rack/server.rb:336:in `wrapped_app"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/commands/server.rb:80:in `start"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/commands.rb:17:in `<top (required)>"
app[web.1]: /app/vendor/bundle/ruby/2.1.0/gems/actionpack-4.2.0.beta2/lib/abstract_controller/helpers.rb:151:in `rescue in block in modules_for_helpers": Missing helper file helpers/application_helper.rb (AbstractController::Helpers::MissingHelperError)
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/actionpack-4.2.0.beta2/lib/action_controller/metal/helpers.rb:93:in `modules_for_helpers"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/railties-4.2.0.beta2/lib/rails/initializable.rb:30:in `run"
app[web.1]:    from /app/vendor/ruby-2.1.5/lib/ruby/2.1.0/tsort.rb:224:in `tsort_each"
app[web.1]:    from /app/vendor/bundle/ruby/2.1.0/gems/activesupport-4.2.0.beta2/lib/active_support/dependencies.rb:248:in `block in require"

Odpowiedzi:

0 dla odpowiedzi № 1

Naprawiłem ten problem, dodając application_helper.rb do app / helpers:

module ApplicationHelper
end

A także importowanie ApplicationHelper w pliku controllers / application_controller.rb

class ApplicationController < ActionController::Base
protect_from_forgery with: :exception
include ApplicationHelper
end