Подтвердить что ты не робот

Rake assets: precompile не работает на heroku

Мой сайт работал, и Heroku предварительно скомпилировал активы и все остальное. Теперь, казалось бы, из ниоткуда, я начал получать rake aborted! stack level too deep при развертывании.

Удаление строки *= require_tree . из моего файла application.css кажется исправленным stack level too deep, но затем я получаю следующее:

Running: rake assets:precompile
(in /tmp/build_b8o2t4k8frce)
/usr/local/bin/ruby /tmp/build_b8o2t4k8frce/vendor/bundle/ruby/1.9.1/bin/rake assets:precompile:nondigest RAILS_ENV=production RAILS_GROUPS=assets
(in /tmp/build_b8o2t4k8frce)

Все мои ссылки на изображения нарушены (я использую image-url() в моем файле css). Что может быть проблемой и как ее исправить?

Я использую кедровый стек, и это мой gemfile:

gem 'rails', '3.1.0'
gem 'rake', '0.8.7'
gem 'devise'

group :production do
  gem 'pg'
  gem 'thin'
end

group :assets do
  gem 'sass-rails', "  ~> 3.1.0"
  gem 'coffee-rails', "~> 3.1.0"
  gem 'uglifier'
end

И вот версии, используемые героем:

Using rake (0.8.7)
Using rails (3.1.0)
Using sass (3.1.15)
Using sass-rails (3.1.6)

Здесь мой файл application.rb

if defined?(Bundler)
  # If you precompile assets before deploying to production, use this line
  Bundler.require *Rails.groups(:assets => %w(development test))
  # If you want your assets lazily compiled in production, use this line
  # Bundler.require(:default, :assets, Rails.env)
end

module App
  class Application < Rails::Application

    # Enable the asset pipeline
    config.assets.enabled = true

    # Version of your assets, change this if you want to expire all your assets.
    config.assets.version = '1.0'
  end
end

И вот мой файл production.rb

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

# Enable Rails static asset server (Apache or nginx will not need this)
config.serve_static_assets = true

# Set expire header of 30 days for static files
config.static_cache_control = "public, max-age=2592000"

# Allow JavaScript and CSS compression
config.assets.compress = true

# Compress JavaScript by removing whitespace, shortening variable names, ...
config.assets.js_compressor = :uglifier

# 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
4b9b3361

Ответ 1

У меня была аналогичная проблема, и я нашел ответ здесь: https://github.com/rails/sass-rails/issues/78. В принципе, переход на sass-rails v3.1.4. Надеюсь, что это поможет

Ответ 2

Вам не нужно было удалять этот *= require tree . из application.css, потому что он загружает все ваши стили. просто добавьте его и настройте файл config/production.rb следующим образом:

config.assets.precompile = %w{application.js}

и запустите RAILS_ENV = производственные грабли: precompile

ИЗМЕНИТЬ попробуйте использовать эту конфигурацию:

config.assets.digest  = true

Ответ 3

По-видимому, сасс перестала работать, и у меня закончилось терпение, поэтому я решил больше не использовать его. Вместо этого:

#theme.css.scss
background-image:image-url('image.png');

Теперь я просто использую файл erb:

#theme.css.erb
background-image:url(<%= asset_path 'image.png' %>);

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