Rails ExecJS::ProgramError в Pages#home?

При запуске нового приложения, когда я создаю домашнюю страницу контроллера и пытаюсь перейти на локальный хост:3000/pages/home, я получаю следующую ошибку:

Showing c:/Users/Doesha/desktop/pinplug/app/views/layouts/application.html.erb where line #6 raised:

TypeError: Object doesn't support this property or method
  (in c:/RailsInstaller/Ruby2.1.0/lib/ruby/gems/2.1.0/gems/turbolinks-2.5.3/lib/assets/javascripts/turbolinks.js.coffee)

файл application.html.erb:

<!DOCTYPE html>
<html>
<head>
  <title>Pinplug</title>
  <%= stylesheet_link_tag    'application', media: 'all', 'data-turbolinks-track' => true %>
  <%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
  <%= csrf_meta_tags %>
</head>
<body>

<%= yield %>

</body>
</html>

файл application_controller.rb:

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception
end

файл pages_controller.rb:

class PagesController < ApplicationController
  def home
  end
end

Файл route.rb:

Rails.application.routes.draw do
  get 'pages/home'

  # The priority is based upon order of creation: first created -> highest priority.
  # See how all your routes lay out with "rake routes".

  # You can have the root of your site routed with "root"
  # root 'welcome#index'

  # Example of regular route:
  #   get 'products/:id' => 'catalog#view'

  # Example of named route that can be invoked with purchase_url(id: product.id)
  #   get 'products/:id/purchase' => 'catalog#purchase', as: :purchase

  # Example resource route (maps HTTP verbs to controller actions automatically):
  #   resources :products

  # Example resource route with options:
  #   resources :products do
  #     member do
  #       get 'short'
  #       post 'toggle'
  #     end
  #
  #     collection do
  #       get 'sold'
  #     end
  #   end

  # Example resource route with sub-resources:
  #   resources :products do
  #     resources :comments, :sales
  #     resource :seller
  #   end

  # Example resource route with more complex sub-resources:
  #   resources :products do
  #     resources :comments
  #     resources :sales do
  #       get 'recent', on: :collection
  #     end
  #   end

  # Example resource route with concerns:
  #   concern :toggleable do
  #     post 'toggle'
  #   end
  #   resources :posts, concerns: :toggleable
  #   resources :photos, concerns: :toggleable

  # Example resource route within a namespace:
  #   namespace :admin do
  #     # Directs /admin/products/* to Admin::ProductsController
  #     # (app/controllers/admin/products_controller.rb)
  #     resources :products
  #   end
end

Gemfile:

source 'https://rubygems.org'


# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '4.2.0'
# Use sqlite3 as the database for Active Record
gem 'sqlite3'
# Use SCSS for stylesheets
gem 'sass-rails', '~> 5.0'
# Use Uglifier as compressor for JavaScript assets
gem 'uglifier', '>= 1.3.0'
# Use CoffeeScript for .coffee assets and views
gem 'coffee-rails', '~> 4.1.0'
# See https://github.com/sstephenson/execjs#readme for more supported runtimes
# gem 'therubyracer', platforms: :ruby

gem 'execjs', '~> 2.2.2'

# Use jquery as the JavaScript library
gem 'jquery-rails'
# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks
gem 'turbolinks'
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder', '~> 2.0'
# bundle exec rake doc:rails generates the API under doc/api.
gem 'sdoc', '~> 0.4.0', group: :doc

# Use ActiveModel has_secure_password
# gem 'bcrypt', '~> 3.1.7'

# Use Unicorn as the app server
# gem 'unicorn'

# Use Capistrano for deployment
# gem 'capistrano-rails', group: :development

group :development, :test do
  # Call 'byebug' anywhere in the code to stop execution and get a debugger console
  gem 'byebug'

  # Access an IRB console on exception pages or by using <%= console %> in views
  gem 'web-console', '~> 2.0'
end

# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]

файл gemfile.lock:

GEM
  remote: https://rubygems.org/
  specs:
    actionmailer (4.2.0)
      actionpack (= 4.2.0)
      actionview (= 4.2.0)
      activejob (= 4.2.0)
      mail (~> 2.5, >= 2.5.4)
      rails-dom-testing (~> 1.0, >= 1.0.5)
    actionpack (4.2.0)
      actionview (= 4.2.0)
      activesupport (= 4.2.0)
      rack (~> 1.6.0)
      rack-test (~> 0.6.2)
      rails-dom-testing (~> 1.0, >= 1.0.5)
      rails-html-sanitizer (~> 1.0, >= 1.0.1)
    actionview (4.2.0)
      activesupport (= 4.2.0)
      builder (~> 3.1)
      erubis (~> 2.7.0)
      rails-dom-testing (~> 1.0, >= 1.0.5)
      rails-html-sanitizer (~> 1.0, >= 1.0.1)
    activejob (4.2.0)
      activesupport (= 4.2.0)
      globalid (>= 0.3.0)
    activemodel (4.2.0)
      activesupport (= 4.2.0)
      builder (~> 3.1)
    activerecord (4.2.0)
      activemodel (= 4.2.0)
      activesupport (= 4.2.0)
      arel (~> 6.0)
    activesupport (4.2.0)
      i18n (~> 0.7)
      json (~> 1.7, >= 1.7.7)
      minitest (~> 5.1)
      thread_safe (~> 0.3, >= 0.3.4)
      tzinfo (~> 1.1)
    arel (6.0.0)
    binding_of_caller (0.7.2)
      debug_inspector (>= 0.0.1)
    builder (3.2.2)
    byebug (3.5.1)
      columnize (~> 0.8)
      debugger-linecache (~> 1.2)
      slop (~> 3.6)
    coffee-rails (4.1.0)
      coffee-script (>= 2.2.0)
      railties (>= 4.0.0, < 5.0)
    coffee-script (2.3.0)
      coffee-script-source
      execjs
    coffee-script-source (1.9.0)
    columnize (0.9.0)
    debug_inspector (0.0.2)
    debugger-linecache (1.2.0)
    erubis (2.7.0)
    execjs (2.2.2)
    globalid (0.3.2)
      activesupport (>= 4.1.0)
    hike (1.2.3)
    i18n (0.7.0)
    jbuilder (2.2.6)
      activesupport (>= 3.0.0, < 5)
      multi_json (~> 1.2)
    jquery-rails (4.0.3)
      rails-dom-testing (~> 1.0)
      railties (>= 4.2.0)
      thor (>= 0.14, < 2.0)
    json (1.8.2)
    loofah (2.0.1)
      nokogiri (>= 1.5.9)
    mail (2.6.3)
      mime-types (>= 1.16, < 3)
    mime-types (2.4.3)
    mini_portile (0.6.2)
    minitest (5.5.1)
    multi_json (1.10.1)
    nokogiri (1.6.6.2-x86-mingw32)
      mini_portile (~> 0.6.0)
    rack (1.6.0)
    rack-test (0.6.3)
      rack (>= 1.0)
    rails (4.2.0)
      actionmailer (= 4.2.0)
      actionpack (= 4.2.0)
      actionview (= 4.2.0)
      activejob (= 4.2.0)
      activemodel (= 4.2.0)
      activerecord (= 4.2.0)
      activesupport (= 4.2.0)
      bundler (>= 1.3.0, < 2.0)
      railties (= 4.2.0)
      sprockets-rails
    rails-deprecated_sanitizer (1.0.3)
      activesupport (>= 4.2.0.alpha)
    rails-dom-testing (1.0.5)
      activesupport (>= 4.2.0.beta, < 5.0)
      nokogiri (~> 1.6.0)
      rails-deprecated_sanitizer (>= 1.0.1)
    rails-html-sanitizer (1.0.1)
      loofah (~> 2.0)
    railties (4.2.0)
      actionpack (= 4.2.0)
      activesupport (= 4.2.0)
      rake (>= 0.8.7)
      thor (>= 0.18.1, < 2.0)
    rake (10.4.2)
    rdoc (4.2.0)
      json (~> 1.4)
    sass (3.4.11)
    sass-rails (5.0.1)
      railties (>= 4.0.0, < 5.0)
      sass (~> 3.1)
      sprockets (>= 2.8, < 4.0)
      sprockets-rails (>= 2.0, < 4.0)
      tilt (~> 1.1)
    sdoc (0.4.1)
      json (~> 1.7, >= 1.7.7)
      rdoc (~> 4.0)
    slop (3.6.0)
    sprockets (2.12.3)
      hike (~> 1.2)
      multi_json (~> 1.0)
      rack (~> 1.0)
      tilt (~> 1.1, != 1.3.0)
    sprockets-rails (2.2.4)
      actionpack (>= 3.0)
      activesupport (>= 3.0)
      sprockets (>= 2.8, < 4.0)
    sqlite3 (1.3.10-x86-mingw32)
    thor (0.19.1)
    thread_safe (0.3.4)
    tilt (1.4.1)
    turbolinks (2.5.3)
      coffee-rails
    tzinfo (1.2.2)
      thread_safe (~> 0.1)
    tzinfo-data (1.2015.1)
      tzinfo (>= 1.0.0)
    uglifier (2.7.0)
      execjs (>= 0.3.0)
      json (>= 1.8.0)
    web-console (2.0.0)
      activemodel (~> 4.0)
      binding_of_caller (>= 0.7.2)
      railties (~> 4.0)
      sprockets-rails (>= 2.0, < 4.0)

PLATFORMS
  x86-mingw32

DEPENDENCIES
  byebug
  coffee-rails (~> 4.1.0)
  execjs (~> 2.2.2)
  jbuilder (~> 2.0)
  jquery-rails
  rails (= 4.2.0)
  sass-rails (~> 5.0)
  sdoc (~> 0.4.0)
  sqlite3
  turbolinks
  tzinfo-data
  uglifier (>= 1.3.0)
  web-console (~> 2.0)

файл application.rb:

require File.expand_path('../boot', __FILE__)

require 'rails/all'

# Require the gems listed in Gemfile, including any gems
# you've limited to :test, :development, or :production.
Bundler.require(*Rails.groups)

module Pinplug
  class Application < Rails::Application
    # Settings in config/environments/* take precedence over those specified here.
    # Application configuration should go into files in config/initializers
    # -- all .rb files in that directory are automatically loaded.

    # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
    # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
    # config.time_zone = 'Central Time (US & Canada)'

    # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
    # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
    # config.i18n.default_locale = :de

    # Do not swallow errors in after_commit/after_rollback callbacks.
    config.active_record.raise_in_transactional_callbacks = true
  end
end

Я также понизил рейтинг гемов Turbinks с 2.3.0 до 2.2.2, думая, что более новая версия гемов TurboLinks приводила к появлению ошибок в моем приложении; Очевидно, это не сработало для меня.

Любые предложения о том, что может быть не так с моим приложением?

17 ответов

Решение

В строках /app/views/layouts/application.html.erb 5 и 6 измените первый параметр с application в default,

Я столкнулся с той же проблемой, тоже для моей ситуации, я не знаю почему, но это происходит только в Windows. Параметр application работает на веб-сервере.

Если вы работаете в Windows, coffee-script-source 1.9.0 не работает в Windows.

Измените его на предыдущую версию, добавив эту строку в ваш Gemfile:

gem 'coffee-script-source', '1.8.0'

А затем переустановите пакет, настраивая зависимости для новой версии Gem:

bundle update coffee-script-source

У меня была эта проблема в течение некоторого времени, и, пройдя по всем ответам в этой теме и обнаружив, что все они оказались безуспешными, я решил добавить свое решение в надежде, что оно поможет будущим пользователям Rails.

Я сделал все в этой теме - изменение application в default позволяет пройти без ошибок, но затем, когда вы на самом деле пытаетесь использовать любой JavaScript, появляется сообщение о невозможности найти default.js, Я установил NodeJS и поместил его в папку Ruby/bin. Это ничего не сделало, поэтому я удалил его.

Вы действительно можете временно обойти эту проблему с помощью application с default"решение, но оно чрезвычайно краткосрочное. Это решение может работать для вас, если вы не собираетесь разрабатывать стили или добавлять JavaScript в свое приложение через конвейер ресурсов Rails. Я сам не проверял это, но представляю, как включить JavaScript и таблицы стилей в Заголовочный файл application.html может работать, но тогда вы потеряете магию Rails.

У меня была эта проблема на платформах Windows 8, Windows 10 и Ubuntu.

Единственное, что решает это для меня и все еще отображает JavaScript и таблицы стилей, - это сначала изменить application в application.css для таблиц стилей (даже если вы используете Sass/SCSS, потому что он все еще компилируется в css) и application.js для ссылки JavaScript. Как только это будет сделано, зайдите в свой /assets/javascripts/application.js файл и удалите // перед //= require turbolinks,

И теперь ваше приложение должно работать просто отлично.

Это, вероятно, более глубокая проблема с турболинками, но это быстрый обходной путь, который еще не подводил меня.

В Windows Coffee-скрипт источник>= 1.9.0 не работает должным образом. просто добавьте в Gemfile

 gem 'coffee-script-source', '1.8.0'

и беги

bundle update coffee-script-source

Просто установите NodeJS на свой локальный компьютер (убедитесь, что соответствующая запись добавлена ​​в PATH) и добавьте

gem 'execjs'

в Gemfile.

В windows 10 версии 1511 добавилось добавление gem 'coffee-script-source', '1.8.0' в мой gemfile и затем обновление ruby ​​bin\bundle для обновления coffee-script-source из каталога проекта. NB: предыдущая версия кофе-скрипта-источника, которая была заменена, была 1.10.0

(В Windows 8)

  1. Установите Node.js!
  2. Добавьте его в PATH (ENV_VAR)
  3. перезагрузите сервер

У меня тоже была эта проблема. Я вошел в Sublime в папку моего проекта. Затем щелкнул папки приложения, просмотр папки, макет, нажал application.html.erb и изменил строки 5 и 6 "приложение" на "по умолчанию". Работал отлично. Спасибо за сообщение о вашей проблеме и спасибо тем, кто ответил!

Я просто хотел добавить, что я прошел через Sublime. Я только учусь и не понимаю, как получить доступ к файлу.erb. Просто хотел помочь другим.

Его проблема с самоцветом turbolinks, поэтому его ошибка создания

Так что в app\views\layouts\application.html.erb измените это

<%= stylesheet_link_tag    'application.css', media: 'all', 'data-turbolinks-track': 'reload' %>
<%= javascript_include_tag 'application.js', 'data-turbolinks-track': 'reload' %>

от

<%= stylesheet_link_tag    'application', media: 'all', 'data-turbolinks-track': 'reload' %>
<%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload' %>

и раскомментируйте строку № 15 в app\assets\javascripts\application.js

require turbolinks

и скопируйте его в app \ assets \ stylesheets \ application.css в конце файла

От этого ваши CSS и JS будут запускаться

Я на Rails 5.1.6. Я была такая же проблема. Как рекомендовано выше, я испортил гем кофе-скрипт-источник, который решил проблему.

# Use CoffeeScript for .coffee assets and views
gem 'coffee-rails', '~> 4.2' # <-- This existed already
gem 'coffee-script-source', '1.8.0' # <-- Adding this line solved the problem

Примечание. Я не изменял файл application.html.rb.

Я просто изменилapplicationкdefaultв строках 5 и 6, и решены./app/views/layouts/application.html.erb,

ОТ:

<%= stylesheet_link_tag    '**application**', media: 'all', 'data-turbolinks-track' => true %>
  <%= javascript_include_tag '**application**', 'data-turbolinks-track' => true %>

TO:

<%= stylesheet_link_tag    '**default**', media: 'all', 'data-turbolinks-track' => true %>
  <%= javascript_include_tag '**default**', 'data-turbolinks-track' => true %>

Я перепробовал все вышеперечисленные решения, и единственное, что работало правильно, это установить node.js, добавить каталог в переменную среды path в Windows (находится в разделе "Дополнительные параметры системы", "Переменные среды", "путь"), а затем перезапустить компьютер и сервер. Я думаю, что более поздние версии coffee-script-source должны зависеть от node.js вместе с другими гемами. У меня была идентичная ошибка без использования coffee-script-source.

Изменение "приложения" на "по умолчанию" - ужасное решение, потому что оно просто удаляет все стили CSS приложения. Я не рекомендую это вообще.

Наконец-то все заработало, какой вздох облегчения. Хотя я не совсем уверен, что заставило это работать. Перепробовал все следующее. 1) Установил node.js, добавил в него coffescript npm и перезапустил. 2) Добавлен gem для exec.js и изменен runtime.rb, чтобы он не мог использовать файл сценария Windows по умолчанию. Обратитесь к этой ссылке, чтобы узнать, как это сделать: [ https://github.com/sstephenson/execjs/issues/81][1]3) Чтобы быть в безопасности, также добавлен гем rubyracer gem 'therubyracer', платформы::ruby

В итоге добавлены два обработчика сценариев, nodejs и rubyracer, и добавлены execjs, чтобы он выбирал лучший обработчик сценариев, но не мог выбрать механизм сценариев Windows.

Я предполагаю, что простая установка только nodejs могла бы сработать после добавления execjs. Однако я не перезапустил (после установки nodejs) и попробовал все остальное.

На Windwos 10

Просто установите node.js и убедитесь, что исполняемый файл узла находится в переменной пути.

Для пользователей Windows Вы можете настроить путь выполнения execjs к Node

config/boot.rb

ENV['EXECJS_RUNTIME'] = 'Node'

Мы должны только изменить строку 6 с application в default в /app/views/layouts/application.html.erb . изменение строки 5 приведет к тому, что таблицы стилей не будут загружены.

(В Windows 10 - Rails 4.2.5): я решил так:

1) Установите node.js

2) Установите гем coffe-script-source

gem 'coffee-script-source', '1.8.0'

3) Добавьте эту строку в "config \ initializers \ assets.rb"

Rails.application.config.assets.precompile + =% w (application.css)

Вам необходимо прочитать инструкцию на странице рельсов. Вам нужен гем ExecJS и немного времени выполнения JS.

Более практично: 1.- Установите JS Runtime, например, node.js.

2.- получить execJS gem-> gem install execjs

Экспликация:

Со страницы рельсов:

"Компиляция CoffeeScript и сжатие ресурсов JavaScript требует наличия среды выполнения JavaScript, доступной в вашей системе, при отсутствии среды выполнения вы увидите ошибку execjs во время компиляции ресурсов. Обычно Mac OS X и Windows поставляются с установленной средой выполнения JavaScript. Rails добавляет therubyracer gem в сгенерированный Gemfile в закомментированной строке для новых приложений, и вы можете раскомментировать, если вам это нужно. время выполнения в ExecJS."

Из gitHub ExecJS:

"ExecJS позволяет вам запускать код JavaScript из Ruby. Он автоматически выбирает лучшую доступную среду выполнения для оценки вашей программы JavaScript, а затем возвращает результат в виде объекта Ruby.

ExecJS поддерживает следующие среды выполнения:

therubyracer - Google V8 embedded within Ruby
therubyrhino - Mozilla Rhino embedded within JRuby
Duktape.rb - Duktape JavaScript interpreter
Node.js
Apple JavaScriptCore - Included with Mac OS X
Microsoft Windows Script Host (JScript)
Google V8
mini_racer - Google V8 embedded within Ruby" 

ExecJS Readme GitHub

Другие вопросы по тегам