aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_insert_manager.rb
diff options
context:
space:
mode:
authorRafael França <rafaelmfranca@gmail.com>2017-05-04 12:39:13 -0700
committerGitHub <noreply@github.com>2017-05-04 12:39:13 -0700
commit6d105c7f891a14316eab47dfff3bf1b94f3204e7 (patch)
treeb3ca61f5ff9a083f0b64611788554480d94d36dd /test/test_insert_manager.rb
parent437aa3a4bb8ad4f3f4eba299dbb1112852f9c7ac (diff)
parent5d6d14cb6be217abc04253da0fe49721d09e9575 (diff)
downloadrails-6d105c7f891a14316eab47dfff3bf1b94f3204e7.tar.gz
rails-6d105c7f891a14316eab47dfff3bf1b94f3204e7.tar.bz2
rails-6d105c7f891a14316eab47dfff3bf1b94f3204e7.zip
Merge pull request #482 from kirs/multiple-insert
Support multiple inserts
Diffstat (limited to 'test/test_insert_manager.rb')
-rw-r--r--test/test_insert_manager.rb19
1 files changed, 19 insertions, 0 deletions
diff --git a/test/test_insert_manager.rb b/test/test_insert_manager.rb
index b9ee6f76ac..46549c1ae4 100644
--- a/test/test_insert_manager.rb
+++ b/test/test_insert_manager.rb
@@ -28,6 +28,25 @@ module Arel
}
end
+ it 'inserts multiple values' do
+ table = Table.new(:users)
+ manager = Arel::InsertManager.new
+ manager.into table
+
+ manager.columns << table[:id]
+ manager.columns << table[:name]
+
+ manager.values = manager.create_tuple([
+ manager.create_values(%w{ 1 david }),
+ manager.create_values(%w{ 2 kirs }),
+ manager.create_values(["3", Arel.sql('DEFAULT')], []),
+ ])
+
+ manager.to_sql.must_be_like %{
+ INSERT INTO \"users\" (\"id\", \"name\") VALUES ('1', 'david'), ('2', 'kirs'), ('3', DEFAULT)
+ }
+ end
+
it "inserts false" do
table = Table.new(:users)
manager = Arel::InsertManager.new