[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Re: favico.js and sprockets 3



On Thursday 07 January 2016 02:02 AM, Pirate Praveen wrote:
> On Sunday 03 January 2016 12:26 PM, Pirate Praveen wrote:
>> reported against ruby-sprockets
>> http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=809707
>>
> sprockets 3 is causing more issues
> https://rubygems.org/gems/compass-rails wants sprockets < 2.13 and rake
> assets:precompile fails in diaspora. I think the best option is to embed
> sprockets 2.12 inside diaspora like we did bootstrap-sass. I don't think
> a proper fix will come any time soon
> https://github.com/Compass/compass-rails/issues/232
> 

I added sprockets 2.12.4 inside diaspora source and bundler happily
accepts it, but when I run rake assets:precompile it uses sprockets 3.3
from system path and fails

rake aborted!
TypeError: Cache is not a class
/usr/lib/ruby/vendor_ruby/sprockets/cache.rb:38:in `<module:Sprockets>'
/usr/lib/ruby/vendor_ruby/sprockets/cache.rb:4:in `<top (required)>'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `block
in require'

See full log attached.

If I remove ruby-sprockets 3.3 with dpkg -r --force-all ruby-sprockets
rake proceeds and precompile is successful.

I tried adding path to embedded sprockets to loadpath in Rakefile as
well as setting RUBYLIB variable from commandline, but both did not work.

# Work around for sprockets 2.12
$:.unshift '/usr/share/diaspora/vendor/gems/sprockets-2.12.4/lib'

RUBYLIB=/usr/share/diaspora/vendor/gems/sprockets-2.12.4/lib sudo -E -u
diaspora bundle exec rake assets:precompile --trace 2>&1 | tee
/tmp/assets-precompile.log

Any other way I missed which I can use to force bundler to use sprockets
2.12.4? I cannot add a conflict with ruby-sprockets >= 3.3 as sass-rails
and many other packages depend on ruby-sprockets (only 3.3 in the archive).

Any help fixing this issue is appreciated. This would make diaspora
installable again, its sad when people can't install it immediately
after entering testing.
** Invoke assets:precompile (first_time)
** Invoke assets:environment (first_time)
** Execute assets:environment
** Invoke environment (first_time)
** Execute environment
Using sprockets 
2.12.4
Rack::SSL is enabled
/usr/lib/ruby/vendor_ruby/i18n-inflector/api_strict.rb:60: warning: Enumerator.new without a block is deprecated; use Object#to_enum
rake aborted!
TypeError: Cache is not a class
/usr/lib/ruby/vendor_ruby/sprockets/cache.rb:38:in `<module:Sprockets>'
/usr/lib/ruby/vendor_ruby/sprockets/cache.rb:4:in `<top (required)>'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `block in require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:240:in `load_dependency'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/sprockets/base.rb:3:in `<top (required)>'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `block in require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:240:in `load_dependency'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/sprockets/environment.rb:1:in `<top (required)>'
/usr/lib/ruby/vendor_ruby/sprockets/railtie.rb:23:in `assets'
/usr/lib/ruby/vendor_ruby/handlebars_assets/engine.rb:6:in `block in <class:Engine>'
/usr/lib/ruby/vendor_ruby/rails/initializable.rb:30:in `instance_exec'
/usr/lib/ruby/vendor_ruby/rails/initializable.rb:30:in `run'
/usr/lib/ruby/vendor_ruby/rails/initializable.rb:55:in `block in run_initializers'
/usr/lib/ruby/2.2.0/tsort.rb:226:in `block in tsort_each'
/usr/lib/ruby/2.2.0/tsort.rb:348:in `block (2 levels) in each_strongly_connected_component'
/usr/lib/ruby/2.2.0/tsort.rb:429:in `each_strongly_connected_component_from'
/usr/lib/ruby/2.2.0/tsort.rb:347:in `block in each_strongly_connected_component'
/usr/lib/ruby/2.2.0/tsort.rb:345:in `each'
/usr/lib/ruby/2.2.0/tsort.rb:345:in `call'
/usr/lib/ruby/2.2.0/tsort.rb:345:in `each_strongly_connected_component'
/usr/lib/ruby/2.2.0/tsort.rb:224:in `tsort_each'
/usr/lib/ruby/2.2.0/tsort.rb:203:in `tsort_each'
/usr/lib/ruby/vendor_ruby/rails/initializable.rb:54:in `run_initializers'
/usr/lib/ruby/vendor_ruby/rails/application.rb:352:in `initialize!'
/usr/lib/ruby/vendor_ruby/rails/railtie.rb:194:in `public_send'
/usr/lib/ruby/vendor_ruby/rails/railtie.rb:194:in `method_missing'
/usr/share/diaspora/config/environment.rb:5:in `<top (required)>'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `block in require'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:240:in `load_dependency'
/usr/lib/ruby/vendor_ruby/active_support/dependencies.rb:274:in `require'
/usr/lib/ruby/vendor_ruby/rails/application.rb:328:in `require_environment!'
/usr/lib/ruby/vendor_ruby/rails/application.rb:457:in `block in run_tasks_blocks'
/usr/lib/ruby/vendor_ruby/rake/task.rb:240:in `call'
/usr/lib/ruby/vendor_ruby/rake/task.rb:240:in `block in execute'
/usr/lib/ruby/vendor_ruby/rake/task.rb:235:in `each'
/usr/lib/ruby/vendor_ruby/rake/task.rb:235:in `execute'
/usr/lib/ruby/vendor_ruby/rake/task.rb:179:in `block in invoke_with_call_chain'
/usr/lib/ruby/2.2.0/monitor.rb:211:in `mon_synchronize'
/usr/lib/ruby/vendor_ruby/rake/task.rb:172:in `invoke_with_call_chain'
/usr/lib/ruby/vendor_ruby/rake/task.rb:165:in `invoke'
/usr/lib/ruby/vendor_ruby/sprockets/rails/task.rb:64:in `block (2 levels) in define'
/usr/lib/ruby/vendor_ruby/rake/task.rb:240:in `call'
/usr/lib/ruby/vendor_ruby/rake/task.rb:240:in `block in execute'
/usr/lib/ruby/vendor_ruby/rake/task.rb:235:in `each'
/usr/lib/ruby/vendor_ruby/rake/task.rb:235:in `execute'
/usr/lib/ruby/vendor_ruby/rake/task.rb:179:in `block in invoke_with_call_chain'
/usr/lib/ruby/2.2.0/monitor.rb:211:in `mon_synchronize'
/usr/lib/ruby/vendor_ruby/rake/task.rb:172:in `invoke_with_call_chain'
/usr/lib/ruby/vendor_ruby/rake/task.rb:201:in `block in invoke_prerequisites'
/usr/lib/ruby/vendor_ruby/rake/task.rb:199:in `each'
/usr/lib/ruby/vendor_ruby/rake/task.rb:199:in `invoke_prerequisites'
/usr/lib/ruby/vendor_ruby/rake/task.rb:178:in `block in invoke_with_call_chain'
/usr/lib/ruby/2.2.0/monitor.rb:211:in `mon_synchronize'
/usr/lib/ruby/vendor_ruby/rake/task.rb:172:in `invoke_with_call_chain'
/usr/lib/ruby/vendor_ruby/rake/task.rb:165:in `invoke'
/usr/lib/ruby/vendor_ruby/rake/application.rb:150:in `invoke_task'
/usr/lib/ruby/vendor_ruby/rake/application.rb:106:in `block (2 levels) in top_level'
/usr/lib/ruby/vendor_ruby/rake/application.rb:106:in `each'
/usr/lib/ruby/vendor_ruby/rake/application.rb:106:in `block in top_level'
/usr/lib/ruby/vendor_ruby/rake/application.rb:115:in `run_with_threads'
/usr/lib/ruby/vendor_ruby/rake/application.rb:100:in `top_level'
/usr/lib/ruby/vendor_ruby/rake/application.rb:78:in `block in run'
/usr/lib/ruby/vendor_ruby/rake/application.rb:176:in `standard_exception_handling'
/usr/lib/ruby/vendor_ruby/rake/application.rb:75:in `run'
/usr/bin/rake:27:in `<main>'
Tasks: TOP => environment

Attachment: signature.asc
Description: OpenPGP digital signature


Reply to: