aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/adapters/postgresql
diff options
context:
space:
mode:
authorMatthew Draper <matthew@trebex.net>2014-04-07 22:54:58 +0930
committerMatthew Draper <matthew@trebex.net>2014-04-08 00:36:30 +0930
commitc4bdca19a7a61eb12c75c4a3225e54b69b486a15 (patch)
treeaee1a37d4138b1dcd4348a2231522b4c5c8317d8 /activerecord/test/cases/adapters/postgresql
parent67e67063a4a39530ec0f49d979edb7c2897b8280 (diff)
downloadrails-c4bdca19a7a61eb12c75c4a3225e54b69b486a15.tar.gz
rails-c4bdca19a7a61eb12c75c4a3225e54b69b486a15.tar.bz2
rails-c4bdca19a7a61eb12c75c4a3225e54b69b486a15.zip
Use connection-specific bytea escaping
In our normal usage, it's rare for this to make a difference... but is more technically correct. As well as a spec that proves this is a good idea, let's also add a more sane-looking one that just covers basic to_sql functionality. There aren't many places where we actually use escape_bytea, but that's one that won't be going away.
Diffstat (limited to 'activerecord/test/cases/adapters/postgresql')
-rw-r--r--activerecord/test/cases/adapters/postgresql/bytea_test.rb17
1 files changed, 17 insertions, 0 deletions
diff --git a/activerecord/test/cases/adapters/postgresql/bytea_test.rb b/activerecord/test/cases/adapters/postgresql/bytea_test.rb
index c3394d7712..84fa199f17 100644
--- a/activerecord/test/cases/adapters/postgresql/bytea_test.rb
+++ b/activerecord/test/cases/adapters/postgresql/bytea_test.rb
@@ -70,6 +70,23 @@ class PostgresqlByteaTest < ActiveRecord::TestCase
assert_equal(data, record.payload)
end
+ def test_via_to_sql
+ data = "'\u001F\\"
+ record = ByteaDataType.create(payload: data)
+ sql = ByteaDataType.where(payload: data).select(:payload).to_sql
+ result = @connection.query(sql)
+ assert_equal([[data]], result)
+ end
+
+ def test_via_to_sql_with_complicating_connection
+ Thread.new do
+ other_conn = ActiveRecord::Base.connection
+ other_conn.execute('SET standard_conforming_strings = off')
+ end.join
+
+ test_via_to_sql
+ end
+
def test_write_binary
data = File.read(File.join(File.dirname(__FILE__), '..', '..', '..', 'assets', 'example.log'))
assert(data.size > 1)