mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Merge pull request #28526 from kamipo/fix_log_subscriber_to_allow_legacy_binds
Fix `LogSubscriber` to allow legacy `binds`
This commit is contained in:
commit
0709b60fbe
3 changed files with 73 additions and 73 deletions
|
@ -152,9 +152,7 @@ module ActiveRecord
|
|||
"'#{quote_string(value.to_s)}'"
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def type_casted_binds(binds)
|
||||
def type_casted_binds(binds) # :nodoc:
|
||||
if binds.first.is_a?(Array)
|
||||
binds.map { |column, value| type_cast(value, column) }
|
||||
else
|
||||
|
@ -162,6 +160,7 @@ module ActiveRecord
|
|||
end
|
||||
end
|
||||
|
||||
private
|
||||
def id_value_for_database(value)
|
||||
if primary_key = value.class.primary_key
|
||||
value.instance_variable_get(:@attributes)[primary_key].value_for_database
|
||||
|
|
|
@ -44,17 +44,17 @@ module ActiveRecord
|
|||
private
|
||||
|
||||
def type_casted_binds(binds, casted_binds)
|
||||
casted_binds || binds.map { |attr| type_cast attr.value_for_database }
|
||||
casted_binds || ActiveRecord::Base.connection.type_casted_binds(binds)
|
||||
end
|
||||
|
||||
def render_bind(attr, type_casted_value)
|
||||
value = if attr.type.binary? && attr.value
|
||||
"<#{attr.value_for_database.to_s.bytesize} bytes of binary data>"
|
||||
else
|
||||
type_casted_value
|
||||
def render_bind(attr, value)
|
||||
if attr.is_a?(Array)
|
||||
attr = attr.first
|
||||
elsif attr.type.binary? && attr.value
|
||||
value = "<#{attr.value_for_database.to_s.bytesize} bytes of binary data>"
|
||||
end
|
||||
|
||||
[attr.name, value]
|
||||
[attr && attr.name, value]
|
||||
end
|
||||
|
||||
def colorize_payload_name(name, payload_name)
|
||||
|
@ -89,10 +89,6 @@ module ActiveRecord
|
|||
def logger
|
||||
ActiveRecord::Base.logger
|
||||
end
|
||||
|
||||
def type_cast(value)
|
||||
ActiveRecord::Base.connection.type_cast(value)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
|
|
@ -3,7 +3,9 @@ require "models/topic"
|
|||
require "models/author"
|
||||
require "models/post"
|
||||
|
||||
module ActiveRecord
|
||||
if ActiveRecord::Base.connection.supports_statement_cache? &&
|
||||
ActiveRecord::Base.connection.prepared_statements
|
||||
module ActiveRecord
|
||||
class BindParameterTest < ActiveRecord::TestCase
|
||||
fixtures :topics, :authors, :posts
|
||||
|
||||
|
@ -27,12 +29,10 @@ module ActiveRecord
|
|||
@subscription = ActiveSupport::Notifications.subscribe("sql.active_record", @subscriber)
|
||||
end
|
||||
|
||||
teardown do
|
||||
def teardown
|
||||
ActiveSupport::Notifications.unsubscribe(@subscription)
|
||||
end
|
||||
|
||||
if ActiveRecord::Base.connection.supports_statement_cache? &&
|
||||
ActiveRecord::Base.connection.prepared_statements
|
||||
def test_bind_from_join_in_subquery
|
||||
subquery = Author.joins(:thinking_posts).where(name: "David")
|
||||
scope = Author.from(subquery, "authors").where(id: 1)
|
||||
|
@ -56,15 +56,25 @@ module ActiveRecord
|
|||
assert message, "expected a message with binds"
|
||||
end
|
||||
|
||||
def test_logs_bind_vars_after_type_cast
|
||||
def test_logs_binds_after_type_cast
|
||||
binds = [Relation::QueryAttribute.new("id", "10", Type::Integer.new)]
|
||||
type_casted_binds = binds.map { |attr| type_cast(attr.value_for_database) }
|
||||
assert_logs_binds(binds)
|
||||
end
|
||||
|
||||
def test_logs_legacy_binds_after_type_cast
|
||||
binds = [[@pk, "10"]]
|
||||
assert_logs_binds(binds)
|
||||
end
|
||||
|
||||
private
|
||||
def assert_logs_binds(binds)
|
||||
payload = {
|
||||
name: "SQL",
|
||||
sql: "select * from topics where id = ?",
|
||||
binds: binds,
|
||||
type_casted_binds: type_casted_binds
|
||||
type_casted_binds: @connection.type_casted_binds(binds)
|
||||
}
|
||||
|
||||
event = ActiveSupport::Notifications::Event.new(
|
||||
"foo",
|
||||
Time.now,
|
||||
|
@ -74,6 +84,7 @@ module ActiveRecord
|
|||
|
||||
logger = Class.new(ActiveRecord::LogSubscriber) {
|
||||
attr_reader :debugs
|
||||
|
||||
def initialize
|
||||
super
|
||||
@debugs = []
|
||||
|
@ -84,15 +95,9 @@ module ActiveRecord
|
|||
end
|
||||
}.new
|
||||
|
||||
logger.sql event
|
||||
logger.sql(event)
|
||||
assert_match([[@pk.name, 10]].inspect, logger.debugs.first)
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def type_cast(value)
|
||||
ActiveRecord::Base.connection.type_cast(value)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue