Активы говорят "не предварительно скомпилированы", когда они предварительно скомпилированы

Итак, я получаю эту ошибку, когда пытаюсь использовать конвейер активов. Я не понимаю, что вызывает его.

Sprockets::Helpers::RailsHelper::AssetPaths::AssetNotPrecompiledError in Photos#show

Showing .../app/views/photos/_photo_view.html.haml where line #2 raised:

jquery.autocomplete isn't precompiled

Extracted source (around line #2):

1: - content_for :scripts do
2:  = javascript_include_tag 'jquery.autocomplete'

Однако это предварительно скомпилировано. Я запускал rake assets:precompile RAILS_ENV=production перед запуском сервера, а в моем каталоге public/assets у меня есть файл: jquery-5550a245a55b28927b5552cac182e612.autocomplete.js, а также .js.gz, и он точно отражается в манифесте:

#manifest.yml
---
application.js: application-4277323e3f7506b71f45c71e8a3a7c8f.js
jquery.autocomplete.js: jquery-5550a245a55b28927b5552cac182e612.autocomplete.js
jquery.cycle.all.min.js: jquery-183ef696b43944deaee5778d3094dbdd.cycle.all.min.js
jquery.fancybox.js: jquery-e52e44b2b4fb349bade9beb91461a810.fancybox.js
jquery.plupload.queue.js: jquery-f2e7f6ad7d2e5ca50235ed21f8d573cc.plupload.queue.js
jquery.tools.js: jquery-c53e304240fa56767fe0f2a00cb4bceb.tools.js
plupload.full.js: plupload-5dd26ee3fff6b627c19f196e9d1429dd.full.js
application.css: application-ce5217e1714cbc4e9c3ff6c5dfc9b221.css
fancybox.css: fancybox-9ee9c36f391086e4b0629b7df4042390.css
jquery.plupload.queue.css: jquery-661fbf3f503aa32ff11c004838c0820b.plupload.queue.css
jquery.js: jquery-4d23f0cfea862f56deb04f0a8ab1fcee.js
jquery.min.js: jquery-8a50feed8d29566738ad005e19fe1c2d.min.js

Данный файл javascript не загружается в мой файл application.js, потому что он мне нужен только в одном представлении и не использует его нигде в приложении. Чтобы учесть это (и для исправления звездочек, пытающихся скомпилировать sass partials), я сконфигурировал свое предварительное выражение regexp следующим образом:

#environments/production.rb
config.assets.precompile = [/^[a-zA-Z]*\..*/]

(приведенное выше regexp прекомпилирует любой файл, который начинается с символа буквы, и игнорирует файлы, начинающиеся с символа, отличного от буквы, например, подчеркивания).

Есть ли у кого-нибудь представление о том, что вызывает это и как его можно исправить? Конвейер активов заставляет меня вытащить мои волосы!

UPDATE

только что узнал, что Rails.configuration.assets.digests возвращает нуль в процессе производства. может быть, проблема есть, по какой-то причине звездочки не находят manifest.yml.

Возможно, я ошибаюсь, но похоже, что звездочки не используют атрибут assets_host в config при поиске manifest.yml.

https://github.com/rails/rails/blob/3-2-stable/actionpack/lib/sprockets/railtie.rb#L38

Ответ 1

Я сам боролся с проблемой, хотя с установкой config.assets.compile = false, поскольку я подозреваю, что пример выше был с флагом, установленным на true.

Невозможно настроить активы по конвейеру на локальных рельсах производства 3.1.3 сервер

Мои наблюдения дошли до того, что это ошибка Sprockets 2.0.3, как предложил UberNeet. Обходной путь состоял в том, чтобы либо удалить период из имени актива, либо включить его как часть манифеста, а не напрямую ссылаться на него.

Отчет об ошибке для этого здесь: https://github.com/rails/rails/issues/3398

Рассматривая ваш вопрос выше и подсчитав его своим опытом за последние два дня, я подозреваю, что есть связанная проблема с присвоением активов при установке config.assets.compile = true. Эта проблема, вероятно, связана с присвоением активов - ваш манифест имеет библиотеку jquery.autocomplete, перкомпилированную как:

jquery-5550a245a55b28927b5552cac182e612.autocomplete.js

Но когда вы перекомпилируете эти активы с помощью rake с помощью rake assets:precompile, я считаю, что они действительно скомпилированы для:

jquery.autocomplete-5550a245a55b28927b5552cac182e612.js

Вероятно, это несоответствие вызывает проблему, о которой вы упомянули. Возможно, стоит также подняться и на другую проблему github, хотя обходные пути перечислены выше, и я понимаю, что Rails 3.2 будет использовать Sprockets 2.1.0, который может содержать исправление для этой проблемы.

Ответ 2

Добавьте .js в

javascript_include_tag 'jquery.autocomplete.js'

Похоже, что есть недостающая функциональность. Когда имя файла имеет период '.' в имени расширение .js не будет добавлено при просмотре дайджеста.

Я выполнил некоторую отладку до Sprockets::Helpers::RailsHelper и кажется, что методы digest_for получают логический путь без .js.

Ответ 3

Будьте уверены, что это не требуется раньше в application.js, например.