Giter Site home page Giter Site logo

Comments (11)

djezzzl avatar djezzzl commented on June 1, 2024 1

Thank you! I'm looking into it and will try to provide a fix ASAP.

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Hi, thank you for letting me know. It's known issue, could you please try latest version and let me if it didn't help.

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Feel free to reopen the issue if needed.

from database_consistency.

denys-husiev avatar denys-husiev commented on June 1, 2024

after updating to 0.8.7 I still have the same issue (the only change is that row shifted to 101)

<===begin===> �[1mTraceback�[m (most recent call last): 24: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/ruby_executable_hooks:24:in

'
23: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/ruby_executable_hooks:24:in eval' 22: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/database_consistency:23:in '
21: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/database_consistency:23:in load' 20: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/bin/database_consistency:44:in <top (required)>'
19: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency.rb:46:in run' 18: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in reports'
17: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in flat_map' 16: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in each'
15: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:13:in block in reports' 14: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:28:in reports'
13: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in check' 12: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in flat_map'
11: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in each' 10: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in block in check'
9: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in flat_map' 8: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in each'
7: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:19:in block (2 levels) in check' 6: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:19:in map'
5: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:21:in block (3 levels) in check' 4: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/base_checker.rb:30:in report_if_enabled?'
3: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/base_checker.rb:23:in report' 2: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:36:in check'
1: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:108:in converted_type' /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:101:in type': �[1mundefined method sql_type' for nil:NilClass (�[1;4mNoMethodError�[m�[1m)�[m <===end===> <===begin===> �[1mTraceback�[m (most recent call last): 24: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/ruby_executable_hooks:24:in '
23: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/ruby_executable_hooks:24:in eval' 22: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/database_consistency:23:in '
21: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/bin/database_consistency:23:in load' 20: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/bin/database_consistency:44:in <top (required)>'
19: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency.rb:46:in run' 18: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in reports'
17: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in flat_map' 16: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:12:in each'
15: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:13:in block in reports' 14: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/base_processor.rb:28:in reports'
13: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in check' 12: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in flat_map'
11: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:15:in each' 10: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in block in check'
9: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in flat_map' 8: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:18:in each'
7: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:19:in block (2 levels) in check' 6: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:19:in map'
5: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/processors/associations_processor.rb:21:in block (3 levels) in check' 4: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/base_checker.rb:30:in report_if_enabled?'
3: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/base_checker.rb:23:in report' 2: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:36:in check'
1: from /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:108:in converted_type' /Users/user/.rvm/gems/ruby-2.7.1@my_project/gems/database_consistency-0.8.7/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb:101:in type': �[1mundefined method sql_type' for nil:NilClass (�[1;4mNoMethodError�[m�[1m)�[m <===end===>

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Then I need a little bit more context, could you please debug it and give the context how the association (which raises such issue is defined)? Let me please know if you need a help to track it

from database_consistency.

denys-husiev avatar denys-husiev commented on June 1, 2024

If you have some practice of how to find the association which causes the error, it would be helpful

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Yes, on the method "type" where checker does "sql_type" add "p association if column.nil?" before, that should help to understand which association fails

from database_consistency.

denys-husiev avatar denys-husiev commented on June 1, 2024

I found model which caused an error (and I think it's default implementation of Rolify gem):

  • association:
#<ActiveRecord::Reflection::HasAndBelongsToManyReflection:0x00007fcca75de2f8
 @active_record=
  User(id: integer, first_name: string, last_name: string, sign_in_count: integer, current_sign_in_at: datetime, last_sign_in_at: datetime, current_sign_in_ip: inet, last_sign_in_ip: inet, created_at: datetime, updated_at: datetime),
 @active_record_primary_key="id",
 @association_scope_cache=#<Concurrent::Map:0x00007fcca75de1e0 entries=0 default_proc=nil>,
 @class_name="Role",
 @constructable=true,
 @foreign_key="user_id",
 @foreign_type=nil,
 @klass=Role(id: integer, name: string, resource_type: string, resource_id: integer, created_at: datetime, updated_at: datetime),
 @name=:roles,
 @options={:class_name=>"Role", :join_table=>"users_roles"},
 @plural_name="roles",
 @scope=nil,
 @type=nil>
  • Role model:
class Role < ApplicationRecord
  scopify

  has_many :users_roles, dependent: :destroy
  has_many :users, through: :users_roles
  belongs_to :resource, polymorphic: true, optional: true

  enum name: { admin: 'admin' }

  validates :resource_type, inclusion: { in: Rolify.resource_types }, allow_nil: true
  validates :name, presence: true
end
  • UsersRole model:
class UsersRole < ApplicationRecord
  belongs_to :user
  belongs_to :role
end
  • migration for these models:
class RolifyCreateRoles < ActiveRecord::Migration[6.0]
  def change
    create_table(:roles) do |t|
      t.string :name, null: false
      t.references :resource, polymorphic: true

      t.timestamps
    end

    create_table(:users_roles) do |t|
      t.references :user, null: false, foreign_key: true
      t.references :role, null: false, foreign_key: true

      t.timestamps
    end

    add_index(:roles, %i[name resource_type resource_id])
    add_index(:users_roles, %i[user_id role_id])
  end
end

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Hey @denys-husiev , I believe I have fixed it in 0.8.8. Could you please try it out and let me know if it still has the issue? Feel free to reopen the issue.

from database_consistency.

denys-husiev avatar denys-husiev commented on June 1, 2024

Hi @djezzzl , error disappeared. Thank you very much for your work and such quick reaction!

from database_consistency.

djezzzl avatar djezzzl commented on June 1, 2024

Thank you too!

from database_consistency.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.