populator icon indicating copy to clipboard operation
populator copied to clipboard

NoMethodError: undefined method `sanitize' with Rails 5.1.0.rc2

Open Kuchitama opened this issue 7 years ago • 3 comments

I got below error.

$ rails db:seed

rails aborted!
NoMethodError: undefined method `sanitize' for #<Class:0x000000034e8ba0>
/home/k2/.rvm/gems/ruby-2.4.0/gems/activerecord-5.1.0.rc2/lib/active_record/dynamic_matchers.rb:22:i
n `method_missing'
/home/k2/.rvm/gems/ruby-2.4.0/gems/populator-1.0.0/lib/populator/factory.rb:85:in `block (2 levels) 
in rows_sql_arr'
/home/k2/.rvm/gems/ruby-2.4.0/gems/populator-1.0.0/lib/populator/factory.rb:85:in `map'
/home/k2/.rvm/gems/ruby-2.4.0/gems/populator-1.0.0/lib/populator/factory.rb:85:in `block in rows_sq$
_arr'
/home/k2/.rvm/gems/ruby-2.4.0/gems/populator-1.0.0/lib/populator/factory.rb:84:in `map'
/home/k2/.rvm/gems/ruby-2.4.0/gems/populator-1.0.0/lib/populator/factory.rb:84:in `rows_sql_arr'
...

I'm using rails that versioned 5.1.0.rc2 .

and I tried with 5.0.2, db:seed passed. this problem occurs only rails 5.1.0.rc2.

Kuchitama avatar Apr 27 '17 09:04 Kuchitama

NoMethodError: undefined method sanitize' for #Class:0x00000006c7fbb8 /home/vagrant/.rvm/gems/ruby-2.4.1/gems/activerecord-5.1.3/lib/active_record/dynamic_matchers.rb:22:in method_missing' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:85:in block (2 levels) in rows_sql_arr' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:85:in map' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:85:in block in rows_sql_arr' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:84:in map' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:84:in rows_sql_arr' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:61:in save_records' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:54:in block in build_records' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:50:in times' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:50:in build_records' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:43:in block in populate' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:29:in remember_depth' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/factory.rb:42:in populate' /home/vagrant/.rvm/gems/ruby-2.4.1/gems/populator-1.0.0/lib/populator/model_additions.rb:25:in populate'`

i used rake db:populate and got the above error, after unpacking gem i saw sanitize method still being called.

sehgalmayank001 avatar Aug 09 '17 13:08 sehgalmayank001

I'm facing the same issue reported, the rails version is 5.1.4

→ rails db:seed

rails aborted!
NoMethodError: undefined method `sanitize' for #<Class:0x007fb8f28082e0>
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/activerecord-5.1.4/lib/active_record/dynamic_matchers.rb:22:in `method_missing'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:85:in `block (2 levels) in rows_sql_arr'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:85:in `map'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:85:in `block in rows_sql_arr'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:84:in `map'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:84:in `rows_sql_arr'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:61:in `save_records'
/Users/fulvio/Developer/projects/dganga/vendor/bundle/gems/populator-1.0.0/lib/populator/factory.rb:19:in `block in save_remaining_records'

It passed with the solution of @norikt, thx!

   def rows_sql_arr
      @records.map do |record|
        quoted_attributes = record.attribute_values.map { |v| @model_class.connection.quote(v) }
        "(#{quoted_attributes.join(', ')})"
      end
    end

fulvi0 avatar Sep 10 '17 18:09 fulvi0

This has been fixed in a few forks of Populator. But if you want to keep using the original Populator, you can monkey-patch in a solution. Create a file populator_fixes.rb with contents:

module Populator
  # Builds multiple Populator::Record instances and saves them to the database
  class Factory
    def rows_sql_arr
      @records.map do |record|
        quoted_attributes = record.attribute_values.map { |v| @model_class.connection.quote(v) }
        "(#{quoted_attributes.join(', ')})"
      end
    end
  end
end

and then require it before using Populator

require 'populator_fixes.rb'

# ... do populate stuff here

willkoehler avatar Oct 31 '18 16:10 willkoehler