1
0
Fork 0
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:
Rafael França 2017-03-22 19:10:49 -04:00 committed by GitHub
commit 0709b60fbe
3 changed files with 73 additions and 73 deletions

View file

@ -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

View file

@ -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

View file

@ -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