未定义方法`alias_method_chain'将Spree从3.2更新到3.3

如何解决未定义方法`alias_method_chain'将Spree从3.2更新到3.3

在按照https://guides.spreecommerce.org/developer/upgrades/three-dot-two-to-three-dot-three.html从3.2升级的步骤进行操作后,尝试运行Spree 3.3时出现错误。 我更新了Gemfile,运行bundle update,然后安装了迁移文件。由于相同的错误,我什至无法运行迁移:

/Users/vasco/.rvm/gems/ruby-2.4.9/gems/multi_fetch_fragments-0.0.17/lib/multi_fetch_fragments.rb:5:in `block in <module:MultiFetchFragments>': undefined method `alias_method_chain' for ActionView::PartialRenderer:Class (NoMethodError)
Did you mean?  alias_method
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/activesupport-5.1.7/lib/active_support/concern.rb:120:in `class_eval'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/activesupport-5.1.7/lib/active_support/concern.rb:120:in `append_features'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/multi_fetch_fragments-0.0.17/lib/multi_fetch_fragments.rb:95:in `include'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/multi_fetch_fragments-0.0.17/lib/multi_fetch_fragments.rb:95:in `block (2 levels) in <class:Railtie>'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/multi_fetch_fragments-0.0.17/lib/multi_fetch_fragments.rb:94:in `class_eval'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/multi_fetch_fragments-0.0.17/lib/multi_fetch_fragments.rb:94:in `block in <class:Railtie>'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/initializable.rb:30:in `instance_exec'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/initializable.rb:30:in `run'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/initializable.rb:59:in `block in run_initializers'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:228:in `block in tsort_each'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:350:in `block (2 levels) in each_strongly_connected_component'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:431:in `each_strongly_connected_component_from'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:349:in `block in each_strongly_connected_component'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:347:in `each'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:347:in `call'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:347:in `each_strongly_connected_component'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:226:in `tsort_each'
    from /Users/vasco/.rvm/rubies/ruby-2.4.9/lib/ruby/2.4.0/tsort.rb:205:in `tsort_each'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/initializable.rb:58:in `run_initializers'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/application.rb:353:in `initialize!'
    from /Users/vasco/Documents/rails/hello-coffee/config/environment.rb:5:in `<top (required)>'
    from config.ru:3:in `require_relative'
    from config.ru:3:in `block in <main>'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/builder.rb:116:in `eval'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/builder.rb:116:in `new_from_string'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/builder.rb:105:in `load_file'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/builder.rb:66:in `parse_file'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/server.rb:349:in `build_app_and_options_from_config'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/server.rb:249:in `app'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:24:in `app'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/rack-2.2.3/lib/rack/server.rb:422:in `wrapped_app'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:80:in `log_to_stdout'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:42:in `start'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:135:in `block in perform'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:130:in `tap'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands/server/server_command.rb:130:in `perform'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/thor-0.20.3/lib/thor/command.rb:27:in `run'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/thor-0.20.3/lib/thor/invocation.rb:126:in `invoke_command'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/thor-0.20.3/lib/thor.rb:387:in `dispatch'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/command/base.rb:63:in `perform'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/command.rb:44:in `invoke'
    from /Users/vasco/.rvm/gems/ruby-2.4.9/gems/railties-5.1.7/lib/rails/commands.rb:16:in `<top (required)>'
    from bin/rails:8:in `require'
    from bin/rails:8:in `<main>'

我在Ruby 2.4.9Bundler 2.1.4Rails 5.1.7Spree 3.3.6上。这是我的Gemfile:

source 'https://rubygems.org'

git_source(:github) do |repo_name|
  repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?("/")
  "https://github.com/#{repo_name}.git"
end

gem 'rails','~> 5.1.0'
gem 'pg'
# gem 'sqlite3'
gem 'activerecord-nulldb-adapter'
gem 'puma'
gem 'sass-rails'
gem 'uglifier'
# gem 'therubyracer',platforms: :ruby
gem 'coffee-rails'
gem 'turbolinks'
gem 'jbuilder'
gem 'jquery-rails'
gem "jquery-ui-rails"

group :development,:test do
  gem 'byebug'
  gem 'capybara'
  gem 'selenium-webdriver'
end

group :development do
  gem 'web-console'
  gem 'listen'
  gem 'spring'
  gem 'spring-watcher-listen'
  gem 'annotate'
end

gem 'dotenv-rails'
gem 'simple_form'
gem 'hamlit'
gem 'browser'
gem 'font-awesome-rails'

gem 'spree','~> 3.3.0'
gem 'spree_auth_devise','~> 3.3'
gem 'spree_gateway','~> 3.3'
gem 'spree_i18n',github: 'spree-contrib/spree_i18n'
gem 'spree_globalize',github: 'spree-contrib/spree_globalize'
gem 'spree_social',github: 'spree-contrib/spree_social'
gem 'spree_paypal_express',github: 'spree-contrib/better_spree_paypal_express'

gem 'braintree'

gem 'daemons'
gem 'delayed_job_active_record'
gem 'devise-async'
gem 'whenever',require: false
gem 'multi_fetch_fragments'
gem 'prowl'
gem 'redis'
gem 'i18n_data'
gem 'http_accept_language'
gem 'chartkick'
gem 'groupdate'
gem 'exception_notification'
gem 'sitemap_generator'
gem 'redcarpet'
gem 'roo'
gem 'roo-xls'
gem 'inky-rb',require: 'inky'
gem "business_time"
gem "holidays"
gem 'ancestry'
gem 'sortable_tree_rails'
gem 'friendly_id'
gem 'globalize'
gem 'maxminddb'
gem 'rb-readline'
gem 'rest-client'
gem 'aws-sdk'
gem 'aws-sdk-rails'
gem 'fog-aws'
gem 'asset_sync'
gem 'savon'

我该如何解决?

解决方法

对于碰到这个问题的任何其他人,multi_fetch_fragments宝石本身已合并到rails 5中,因此该行

gem 'multi_fetch_fragments'
罪魁祸首是我的Gemfile中的

。资料来源: https://github.com/n8/multi_fetch_fragments/issues/34https://github.com/rails/rails/pull/18948

从我的Gemfile中删除此gem后,错误消失了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-