diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index 951e0b7b..2fbd5e8f 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -48,7 +48,6 @@ jobs: run: bin/setup - name: Run tests run: bundle exec rake - continue-on-error: ${{ matrix.rails-version == '7.2' || matrix.rails-version == '7.1'}} - name: Report code coverage if: ${{ github.ref == 'refs/heads/master' && matrix.ruby-version == '3.3' && matrix.rails-version == '7.0' }} continue-on-error: true diff --git a/spec/migrations/20241017013023_reencrypt_password_scramsha_spec.rb b/spec/migrations/20241017013023_reencrypt_password_scramsha_spec.rb index 5bacb2f7..e11f2363 100644 --- a/spec/migrations/20241017013023_reencrypt_password_scramsha_spec.rb +++ b/spec/migrations/20241017013023_reencrypt_password_scramsha_spec.rb @@ -9,9 +9,9 @@ username = ActiveRecord::Base.connection_db_config.configuration_hash[:username] - expect(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).exactly(10).times.and_call_original - expect(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).and_wrap_original do |original_method, *args, &block| - original_method.call(*args, &block).dup.tap { |i| i[:password] ||= "abc" } + allow(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).and_wrap_original do |original_method, *args, &block| + # set a value for any calls originating from the migration file, not from rails itself + original_method.call(*args, &block).dup.tap { |i| i[:password] ||= "abc" if caller_locations.any? {|loc| loc.path.include?(migration_path)} } end expect(ActiveRecord::Base.connection).to receive(:execute).with(a_string_matching(/ALTER ROLE #{username} WITH PASSWORD \'SCRAM-SHA-256.*\'\;/)) @@ -23,9 +23,9 @@ username = ActiveRecord::Base.connection_db_config.configuration_hash[:username] - expect(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).exactly(10).times.and_call_original - expect(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).and_wrap_original do |original_method, *args, &block| - original_method.call(*args, &block).dup.tap { |i| i.delete(:password) } + allow(ActiveRecord::Base.connection_db_config).to receive(:configuration_hash).and_wrap_original do |original_method, *args, &block| + # set a value for any calls originating from the migration file, not from rails itself + original_method.call(*args, &block).dup.tap { |i| i.delete(:password) if caller_locations.any? {|loc| loc.path.include?(migration_path)} } end expect(ActiveRecord::Base.connection).not_to receive(:execute).with(a_string_matching(/ALTER ROLE.*\'\;/)) diff --git a/spec/support/migration_name_helper.rb b/spec/support/migration_name_helper.rb index 6e264dd8..a701b882 100644 --- a/spec/support/migration_name_helper.rb +++ b/spec/support/migration_name_helper.rb @@ -1,6 +1,8 @@ def require_migration - spec_name = caller_locations.first.path - migration_name = spec_name.sub("spec/migrations", "db/migrate").sub("_spec.rb", ".rb") + require migration_path +end - require migration_name +def migration_path + spec_name = caller_locations.detect {|loc| loc.path.end_with?("_spec.rb")}.path + spec_name.sub("spec/migrations", "db/migrate").sub("_spec.rb", ".rb") end