aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2013-02-05 10:25:08 -0800
committerAaron Patterson <aaron.patterson@gmail.com>2013-02-05 10:25:08 -0800
commit80f11e342d00a2177dd8e5684914855b87771c5b (patch)
treed85839732c622c1ebd9e2342e34538fd42994bd1
parentd8005bcb892b0a41901da2cc4baf5e15706cb583 (diff)
parent30a74c09e794a46eac6bd0719f1b0333704317b2 (diff)
downloadrails-80f11e342d00a2177dd8e5684914855b87771c5b.tar.gz
rails-80f11e342d00a2177dd8e5684914855b87771c5b.tar.bz2
rails-80f11e342d00a2177dd8e5684914855b87771c5b.zip
Merge pull request #161 from Noemj/master
Mysql2 prepared statements bind substitution fix
-rw-r--r--lib/arel/visitors/bind_visitor.rb10
-rw-r--r--test/visitors/test_bind_visitor.rb21
2 files changed, 30 insertions, 1 deletions
diff --git a/lib/arel/visitors/bind_visitor.rb b/lib/arel/visitors/bind_visitor.rb
index 0f1e38315b..77f91d9451 100644
--- a/lib/arel/visitors/bind_visitor.rb
+++ b/lib/arel/visitors/bind_visitor.rb
@@ -12,6 +12,15 @@ module Arel
end
private
+
+ def visit_Arel_Nodes_Assignment o
+ if o.right.is_a? Arel::Nodes::BindParam
+ "#{visit o.left} = #{visit o.right}"
+ else
+ super
+ end
+ end
+
def visit_Arel_Nodes_BindParam o
if @block
@block.call
@@ -19,6 +28,7 @@ module Arel
super
end
end
+
end
end
end
diff --git a/test/visitors/test_bind_visitor.rb b/test/visitors/test_bind_visitor.rb
index 92e5d1612c..dbcfb67df5 100644
--- a/test/visitors/test_bind_visitor.rb
+++ b/test/visitors/test_bind_visitor.rb
@@ -1,9 +1,28 @@
require 'helper'
require 'arel/visitors/bind_visitor'
+require 'support/fake_record'
module Arel
module Visitors
- class TestBindVisitor < MiniTest::Unit::TestCase
+ class TestBindVisitor < MiniTest::Unit::TestCase
+
+ ##
+ # Tests visit_Arel_Nodes_Assignment correctly
+ # substitutes binds with values from block
+ def test_assignment_binds_are_substituted
+ table = Table.new(:users)
+ um = Arel::UpdateManager.new Table.engine
+ bp = Nodes::BindParam.new '?'
+ um.set [[table[:name], bp]]
+ visitor = Class.new(Arel::Visitors::ToSql) {
+ include Arel::Visitors::BindVisitor
+ }.new Table.engine.connection
+
+ assignment = um.ast.values[0]
+ actual = visitor.accept(assignment) { "replace" }
+ actual.must_be_like "\"name\" = replace"
+ end
+
def test_visitor_yields_on_binds
visitor = Class.new(Arel::Visitors::Visitor) {
def initialize omg