mysql2 0.4.10-x86-mingw32 → 0.5.0-x86-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,9 +1,8 @@
1
- # encoding: UTF-8
2
1
  require './spec/spec_helper.rb'
3
2
 
4
3
  RSpec.describe Mysql2::Statement do
5
4
  before :each do
6
- @client = new_client(:encoding => "utf8")
5
+ @client = new_client(encoding: "utf8")
7
6
  end
8
7
 
9
8
  def stmt_count
@@ -87,6 +86,20 @@ RSpec.describe Mysql2::Statement do
87
86
  expect(result.to_a).to eq(['max1' => int64_max1, 'max2' => int64_max2, 'max3' => int64_max3, 'min1' => int64_min1, 'min2' => int64_min2, 'min3' => int64_min3])
88
87
  end
89
88
 
89
+ it "should accept keyword arguments on statement execute" do
90
+ stmt = @client.prepare 'SELECT 1 AS a'
91
+
92
+ expect(stmt.execute(as: :hash).first).to eq("a" => 1)
93
+ expect(stmt.execute(as: :array).first).to eq([1])
94
+ end
95
+
96
+ it "should accept bind arguments and keyword arguments on statement execute" do
97
+ stmt = @client.prepare 'SELECT ? AS a'
98
+
99
+ expect(stmt.execute(1, as: :hash).first).to eq("a" => 1)
100
+ expect(stmt.execute(1, as: :array).first).to eq([1])
101
+ end
102
+
90
103
  it "should keep its result after other query" do
91
104
  @client.query 'USE test'
92
105
  @client.query 'CREATE TABLE IF NOT EXISTS mysql2_stmt_q(a int)'
@@ -147,24 +160,16 @@ RSpec.describe Mysql2::Statement do
147
160
  now = Time.now
148
161
  statement = @client.prepare('SELECT ? AS a')
149
162
  result = statement.execute(now)
150
- if RUBY_VERSION =~ /1.8/
151
- expect(result.first['a'].strftime('%F %T %z')).to eql(now.strftime('%F %T %z'))
152
- else
153
- # microseconds is six digits after the decimal, but only test on 5 significant figures
154
- expect(result.first['a'].strftime('%F %T.%5N %z')).to eql(now.strftime('%F %T.%5N %z'))
155
- end
163
+ # microseconds is six digits after the decimal, but only test on 5 significant figures
164
+ expect(result.first['a'].strftime('%F %T.%5N %z')).to eql(now.strftime('%F %T.%5N %z'))
156
165
  end
157
166
 
158
167
  it "should prepare DateTime values with microseconds" do
159
168
  now = DateTime.now
160
169
  statement = @client.prepare('SELECT ? AS a')
161
170
  result = statement.execute(now)
162
- if RUBY_VERSION =~ /1.8/
163
- expect(result.first['a'].strftime('%F %T %z')).to eql(now.strftime('%F %T %z'))
164
- else
165
- # microseconds is six digits after the decimal, but only test on 5 significant figures
166
- expect(result.first['a'].strftime('%F %T.%5N %z')).to eql(now.strftime('%F %T.%5N %z'))
167
- end
171
+ # microseconds is six digits after the decimal, but only test on 5 significant figures
172
+ expect(result.first['a'].strftime('%F %T.%5N %z')).to eql(now.strftime('%F %T.%5N %z'))
168
173
  end
169
174
 
170
175
  it "should tell us about the fields" do
@@ -178,7 +183,7 @@ RSpec.describe Mysql2::Statement do
178
183
 
179
184
  it "should handle as a decimal binding a BigDecimal" do
180
185
  stmt = @client.prepare('SELECT ? AS decimal_test')
181
- test_result = stmt.execute(BigDecimal.new("123.45")).first
186
+ test_result = stmt.execute(BigDecimal("123.45")).first
182
187
  expect(test_result['decimal_test']).to be_an_instance_of(BigDecimal)
183
188
  expect(test_result['decimal_test']).to eql(123.45)
184
189
  end
@@ -188,17 +193,16 @@ RSpec.describe Mysql2::Statement do
188
193
  @client.query 'DROP TABLE IF EXISTS mysql2_stmt_decimal_test'
189
194
  @client.query 'CREATE TABLE mysql2_stmt_decimal_test (decimal_test DECIMAL(10,3))'
190
195
 
191
- @client.prepare("INSERT INTO mysql2_stmt_decimal_test VALUES (?)").execute(BigDecimal.new("123.45"))
196
+ @client.prepare("INSERT INTO mysql2_stmt_decimal_test VALUES (?)").execute(BigDecimal("123.45"))
192
197
 
193
198
  test_result = @client.query("SELECT * FROM mysql2_stmt_decimal_test").first
194
199
  expect(test_result['decimal_test']).to eql(123.45)
195
200
  end
196
201
 
197
202
  it "should warn but still work if cache_rows is set to false" do
198
- @client.query_options.merge!(:cache_rows => false)
199
203
  statement = @client.prepare 'SELECT 1'
200
204
  result = nil
201
- expect { result = statement.execute.to_a }.to output(/:cache_rows is forced for prepared statements/).to_stderr
205
+ expect { result = statement.execute(cache_rows: false).to_a }.to output(/:cache_rows is forced for prepared statements/).to_stderr
202
206
  expect(result.length).to eq(1)
203
207
  end
204
208
 
@@ -217,7 +221,7 @@ RSpec.describe Mysql2::Statement do
217
221
 
218
222
  it "should be able to retrieve utf8 field names correctly" do
219
223
  stmt = @client.prepare 'SELECT * FROM `テーブル`'
220
- expect(stmt.fields).to eq(%w(整数 文字列))
224
+ expect(stmt.fields).to eq(%w[整数 文字列])
221
225
  result = stmt.execute
222
226
 
223
227
  expect(result.to_a).to eq([{ "整数" => 1, "文字列" => "イチ" }, { "整数" => 2, "文字列" => "弐" }, { "整数" => 3, "文字列" => "さん" }])
@@ -241,16 +245,13 @@ RSpec.describe Mysql2::Statement do
241
245
 
242
246
  expect(result.to_a).to eq([{ "整数" => 1 }])
243
247
  end
244
- end if defined? Encoding
248
+ end
245
249
 
246
250
  context "streaming result" do
247
251
  it "should be able to stream query result" do
248
252
  n = 1
249
253
  stmt = @client.prepare("SELECT 1 UNION SELECT 2")
250
-
251
- @client.query_options.merge!(:stream => true, :cache_rows => false, :as => :array)
252
-
253
- stmt.execute.each do |r|
254
+ stmt.execute(stream: true, cache_rows: false, as: :array).each do |r|
254
255
  case n
255
256
  when 1
256
257
  expect(r).to eq([1])
@@ -276,23 +277,17 @@ RSpec.describe Mysql2::Statement do
276
277
  end
277
278
 
278
279
  it "should yield rows as hash's with symbol keys if :symbolize_keys was set to true" do
279
- @client.query_options[:symbolize_keys] = true
280
- @result = @client.prepare("SELECT 1").execute
280
+ @result = @client.prepare("SELECT 1").execute(symbolize_keys: true)
281
281
  @result.each do |row|
282
282
  expect(row.keys.first).to be_an_instance_of(Symbol)
283
283
  end
284
- @client.query_options[:symbolize_keys] = false
285
284
  end
286
285
 
287
286
  it "should be able to return results as an array" do
288
- @client.query_options[:as] = :array
289
-
290
- @result = @client.prepare("SELECT 1").execute
287
+ @result = @client.prepare("SELECT 1").execute(as: :array)
291
288
  @result.each do |row|
292
289
  expect(row).to be_an_instance_of(Array)
293
290
  end
294
-
295
- @client.query_options[:as] = :hash
296
291
  end
297
292
 
298
293
  it "should cache previously yielded results by default" do
@@ -301,35 +296,21 @@ RSpec.describe Mysql2::Statement do
301
296
  end
302
297
 
303
298
  it "should yield different value for #first if streaming" do
304
- @client.query_options[:stream] = true
305
- @client.query_options[:cache_rows] = false
306
-
307
- result = @client.prepare("SELECT 1 UNION SELECT 2").execute
299
+ result = @client.prepare("SELECT 1 UNION SELECT 2").execute(stream: true, cache_rows: true)
308
300
  expect(result.first).not_to eql(result.first)
309
-
310
- @client.query_options[:stream] = false
311
- @client.query_options[:cache_rows] = true
312
301
  end
313
302
 
314
303
  it "should yield the same value for #first if streaming is disabled" do
315
- @client.query_options[:stream] = false
316
- result = @client.prepare("SELECT 1 UNION SELECT 2").execute
304
+ result = @client.prepare("SELECT 1 UNION SELECT 2").execute(stream: false)
317
305
  expect(result.first).to eql(result.first)
318
306
  end
319
307
 
320
308
  it "should throw an exception if we try to iterate twice when streaming is enabled" do
321
- @client.query_options[:stream] = true
322
- @client.query_options[:cache_rows] = false
323
-
324
- result = @client.prepare("SELECT 1 UNION SELECT 2").execute
325
-
326
- expect {
309
+ result = @client.prepare("SELECT 1 UNION SELECT 2").execute(stream: true, cache_rows: false)
310
+ expect do
327
311
  result.each {}
328
312
  result.each {}
329
- }.to raise_exception(Mysql2::Error)
330
-
331
- @client.query_options[:stream] = false
332
- @client.query_options[:cache_rows] = true
313
+ end.to raise_exception(Mysql2::Error)
333
314
  end
334
315
  end
335
316
 
@@ -341,7 +322,7 @@ RSpec.describe Mysql2::Statement do
341
322
 
342
323
  it "should return an array of field names in proper order" do
343
324
  stmt = @client.prepare("SELECT 'a', 'b', 'c'")
344
- expect(stmt.fields).to eql(%w(a b c))
325
+ expect(stmt.fields).to eql(%w[a b c])
345
326
  end
346
327
 
347
328
  it "should return nil for statement with no result fields" do
@@ -351,48 +332,44 @@ RSpec.describe Mysql2::Statement do
351
332
  end
352
333
 
353
334
  context "row data type mapping" do
354
- before(:each) do
355
- @client.query "USE test"
356
- @test_result = @client.prepare("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").execute.first
357
- end
335
+ let(:test_result) { @client.prepare("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").execute.first }
358
336
 
359
337
  it "should return nil for a NULL value" do
360
- expect(@test_result['null_test']).to be_an_instance_of(NilClass)
361
- expect(@test_result['null_test']).to eql(nil)
338
+ expect(test_result['null_test']).to be_an_instance_of(NilClass)
339
+ expect(test_result['null_test']).to eql(nil)
362
340
  end
363
341
 
364
342
  it "should return String for a BIT(64) value" do
365
- expect(@test_result['bit_test']).to be_an_instance_of(String)
366
- expect(@test_result['bit_test']).to eql("\000\000\000\000\000\000\000\005")
343
+ expect(test_result['bit_test']).to be_an_instance_of(String)
344
+ expect(test_result['bit_test']).to eql("\000\000\000\000\000\000\000\005")
367
345
  end
368
346
 
369
347
  it "should return String for a BIT(1) value" do
370
- expect(@test_result['single_bit_test']).to be_an_instance_of(String)
371
- expect(@test_result['single_bit_test']).to eql("\001")
348
+ expect(test_result['single_bit_test']).to be_an_instance_of(String)
349
+ expect(test_result['single_bit_test']).to eql("\001")
372
350
  end
373
351
 
374
352
  it "should return Fixnum for a TINYINT value" do
375
- expect([Fixnum, Bignum]).to include(@test_result['tiny_int_test'].class)
376
- expect(@test_result['tiny_int_test']).to eql(1)
353
+ expect(num_classes).to include(test_result['tiny_int_test'].class)
354
+ expect(test_result['tiny_int_test']).to eql(1)
377
355
  end
378
356
 
379
357
  context "cast booleans for TINYINT if :cast_booleans is enabled" do
380
358
  # rubocop:disable Style/Semicolon
381
- let(:client) { new_client(:cast_booleans => true) }
382
- let(:id1) { client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES ( 1)'; client.last_id }
383
- let(:id2) { client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES ( 0)'; client.last_id }
384
- let(:id3) { client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES (-1)'; client.last_id }
359
+ let(:id1) { @client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES ( 1)'; @client.last_id }
360
+ let(:id2) { @client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES ( 0)'; @client.last_id }
361
+ let(:id3) { @client.query 'INSERT INTO mysql2_test (bool_cast_test) VALUES (-1)'; @client.last_id }
385
362
  # rubocop:enable Style/Semicolon
386
363
 
387
364
  after do
388
- client.query "DELETE from mysql2_test WHERE id IN(#{id1},#{id2},#{id3})"
365
+ @client.query "DELETE from mysql2_test WHERE id IN(#{id1},#{id2},#{id3})"
389
366
  end
390
367
 
391
368
  it "should return TrueClass or FalseClass for a TINYINT value if :cast_booleans is enabled" do
392
- query = client.prepare 'SELECT bool_cast_test FROM mysql2_test WHERE id = ?'
393
- result1 = query.execute id1
394
- result2 = query.execute id2
395
- result3 = query.execute id3
369
+ query = @client.prepare 'SELECT bool_cast_test FROM mysql2_test WHERE id = ?'
370
+ result1 = query.execute id1, cast_booleans: true
371
+ result2 = query.execute id2, cast_booleans: true
372
+ result3 = query.execute id3, cast_booleans: true
396
373
  expect(result1.first['bool_cast_test']).to be true
397
374
  expect(result2.first['bool_cast_test']).to be false
398
375
  expect(result3.first['bool_cast_test']).to be true
@@ -401,134 +378,96 @@ RSpec.describe Mysql2::Statement do
401
378
 
402
379
  context "cast booleans for BIT(1) if :cast_booleans is enabled" do
403
380
  # rubocop:disable Style/Semicolon
404
- let(:client) { new_client(:cast_booleans => true) }
405
- let(:id1) { client.query 'INSERT INTO mysql2_test (single_bit_test) VALUES (1)'; client.last_id }
406
- let(:id2) { client.query 'INSERT INTO mysql2_test (single_bit_test) VALUES (0)'; client.last_id }
381
+ let(:id1) { @client.query 'INSERT INTO mysql2_test (single_bit_test) VALUES (1)'; @client.last_id }
382
+ let(:id2) { @client.query 'INSERT INTO mysql2_test (single_bit_test) VALUES (0)'; @client.last_id }
407
383
  # rubocop:enable Style/Semicolon
408
384
 
409
385
  after do
410
- client.query "DELETE from mysql2_test WHERE id IN(#{id1},#{id2})"
386
+ @client.query "DELETE from mysql2_test WHERE id IN(#{id1},#{id2})"
411
387
  end
412
388
 
413
389
  it "should return TrueClass or FalseClass for a BIT(1) value if :cast_booleans is enabled" do
414
- query = client.prepare 'SELECT single_bit_test FROM mysql2_test WHERE id = ?'
415
- result1 = query.execute id1
416
- result2 = query.execute id2
390
+ query = @client.prepare 'SELECT single_bit_test FROM mysql2_test WHERE id = ?'
391
+ result1 = query.execute id1, cast_booleans: true
392
+ result2 = query.execute id2, cast_booleans: true
417
393
  expect(result1.first['single_bit_test']).to be true
418
394
  expect(result2.first['single_bit_test']).to be false
419
395
  end
420
396
  end
421
397
 
422
398
  it "should return Fixnum for a SMALLINT value" do
423
- expect([Fixnum, Bignum]).to include(@test_result['small_int_test'].class)
424
- expect(@test_result['small_int_test']).to eql(10)
399
+ expect(num_classes).to include(test_result['small_int_test'].class)
400
+ expect(test_result['small_int_test']).to eql(10)
425
401
  end
426
402
 
427
403
  it "should return Fixnum for a MEDIUMINT value" do
428
- expect([Fixnum, Bignum]).to include(@test_result['medium_int_test'].class)
429
- expect(@test_result['medium_int_test']).to eql(10)
404
+ expect(num_classes).to include(test_result['medium_int_test'].class)
405
+ expect(test_result['medium_int_test']).to eql(10)
430
406
  end
431
407
 
432
408
  it "should return Fixnum for an INT value" do
433
- expect([Fixnum, Bignum]).to include(@test_result['int_test'].class)
434
- expect(@test_result['int_test']).to eql(10)
409
+ expect(num_classes).to include(test_result['int_test'].class)
410
+ expect(test_result['int_test']).to eql(10)
435
411
  end
436
412
 
437
413
  it "should return Fixnum for a BIGINT value" do
438
- expect([Fixnum, Bignum]).to include(@test_result['big_int_test'].class)
439
- expect(@test_result['big_int_test']).to eql(10)
414
+ expect(num_classes).to include(test_result['big_int_test'].class)
415
+ expect(test_result['big_int_test']).to eql(10)
440
416
  end
441
417
 
442
418
  it "should return Fixnum for a YEAR value" do
443
- expect([Fixnum, Bignum]).to include(@test_result['year_test'].class)
444
- expect(@test_result['year_test']).to eql(2009)
419
+ expect(num_classes).to include(test_result['year_test'].class)
420
+ expect(test_result['year_test']).to eql(2009)
445
421
  end
446
422
 
447
423
  it "should return BigDecimal for a DECIMAL value" do
448
- expect(@test_result['decimal_test']).to be_an_instance_of(BigDecimal)
449
- expect(@test_result['decimal_test']).to eql(10.3)
424
+ expect(test_result['decimal_test']).to be_an_instance_of(BigDecimal)
425
+ expect(test_result['decimal_test']).to eql(10.3)
450
426
  end
451
427
 
452
428
  it "should return Float for a FLOAT value" do
453
- expect(@test_result['float_test']).to be_an_instance_of(Float)
454
- expect(@test_result['float_test']).to be_within(1e-5).of(10.3)
429
+ expect(test_result['float_test']).to be_an_instance_of(Float)
430
+ expect(test_result['float_test']).to be_within(1e-5).of(10.3)
455
431
  end
456
432
 
457
433
  it "should return Float for a DOUBLE value" do
458
- expect(@test_result['double_test']).to be_an_instance_of(Float)
459
- expect(@test_result['double_test']).to eql(10.3)
434
+ expect(test_result['double_test']).to be_an_instance_of(Float)
435
+ expect(test_result['double_test']).to eql(10.3)
460
436
  end
461
437
 
462
438
  it "should return Time for a DATETIME value when within the supported range" do
463
- expect(@test_result['date_time_test']).to be_an_instance_of(Time)
464
- expect(@test_result['date_time_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2010-04-04 11:44:00')
439
+ expect(test_result['date_time_test']).to be_an_instance_of(Time)
440
+ expect(test_result['date_time_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2010-04-04 11:44:00')
465
441
  end
466
442
 
467
- if 1.size == 4 # 32bit
468
- klass = if RUBY_VERSION =~ /1.8/
469
- DateTime
470
- else
471
- Time
472
- end
473
-
474
- it "should return DateTime when timestamp is < 1901-12-13 20:45:52" do
475
- # 1901-12-13T20:45:52 is the min for 32bit Ruby 1.8
476
- r = @client.prepare("SELECT CAST('1901-12-13 20:45:51' AS DATETIME) as test").execute
477
- expect(r.first['test']).to be_an_instance_of(klass)
478
- end
479
-
480
- it "should return DateTime when timestamp is > 2038-01-19T03:14:07" do
481
- # 2038-01-19T03:14:07 is the max for 32bit Ruby 1.8
482
- r = @client.prepare("SELECT CAST('2038-01-19 03:14:08' AS DATETIME) as test").execute
483
- expect(r.first['test']).to be_an_instance_of(klass)
484
- end
485
- elsif 1.size == 8 # 64bit
486
- if RUBY_VERSION =~ /1.8/
487
- it "should return Time when timestamp is > 0138-12-31 11:59:59" do
488
- r = @client.prepare("SELECT CAST('0139-1-1 00:00:00' AS DATETIME) as test").execute
489
- expect(r.first['test']).to be_an_instance_of(Time)
490
- end
491
-
492
- it "should return DateTime when timestamp is < 0139-1-1T00:00:00" do
493
- r = @client.prepare("SELECT CAST('0138-12-31 11:59:59' AS DATETIME) as test").execute
494
- expect(r.first['test']).to be_an_instance_of(DateTime)
495
- end
496
-
497
- it "should return Time when timestamp is > 2038-01-19T03:14:07" do
498
- r = @client.prepare("SELECT CAST('2038-01-19 03:14:08' AS DATETIME) as test").execute
499
- expect(r.first['test']).to be_an_instance_of(Time)
500
- end
501
- else
502
- it "should return Time when timestamp is < 1901-12-13 20:45:52" do
503
- r = @client.prepare("SELECT CAST('1901-12-13 20:45:51' AS DATETIME) as test").execute
504
- expect(r.first['test']).to be_an_instance_of(Time)
505
- end
443
+ it "should return Time when timestamp is < 1901-12-13 20:45:52" do
444
+ r = @client.prepare("SELECT CAST('1901-12-13 20:45:51' AS DATETIME) as test").execute
445
+ expect(r.first['test']).to be_an_instance_of(Time)
446
+ end
506
447
 
507
- it "should return Time when timestamp is > 2038-01-19T03:14:07" do
508
- r = @client.prepare("SELECT CAST('2038-01-19 03:14:08' AS DATETIME) as test").execute
509
- expect(r.first['test']).to be_an_instance_of(Time)
510
- end
511
- end
448
+ it "should return Time when timestamp is > 2038-01-19T03:14:07" do
449
+ r = @client.prepare("SELECT CAST('2038-01-19 03:14:08' AS DATETIME) as test").execute
450
+ expect(r.first['test']).to be_an_instance_of(Time)
512
451
  end
513
452
 
514
453
  it "should return Time for a TIMESTAMP value when within the supported range" do
515
- expect(@test_result['timestamp_test']).to be_an_instance_of(Time)
516
- expect(@test_result['timestamp_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2010-04-04 11:44:00')
454
+ expect(test_result['timestamp_test']).to be_an_instance_of(Time)
455
+ expect(test_result['timestamp_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2010-04-04 11:44:00')
517
456
  end
518
457
 
519
458
  it "should return Time for a TIME value" do
520
- expect(@test_result['time_test']).to be_an_instance_of(Time)
521
- expect(@test_result['time_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2000-01-01 11:44:00')
459
+ expect(test_result['time_test']).to be_an_instance_of(Time)
460
+ expect(test_result['time_test'].strftime("%Y-%m-%d %H:%M:%S")).to eql('2000-01-01 11:44:00')
522
461
  end
523
462
 
524
463
  it "should return Date for a DATE value" do
525
- expect(@test_result['date_test']).to be_an_instance_of(Date)
526
- expect(@test_result['date_test'].strftime("%Y-%m-%d")).to eql('2010-04-04')
464
+ expect(test_result['date_test']).to be_an_instance_of(Date)
465
+ expect(test_result['date_test'].strftime("%Y-%m-%d")).to eql('2010-04-04')
527
466
  end
528
467
 
529
468
  it "should return String for an ENUM value" do
530
- expect(@test_result['enum_test']).to be_an_instance_of(String)
531
- expect(@test_result['enum_test']).to eql('val1')
469
+ expect(test_result['enum_test']).to be_an_instance_of(String)
470
+ expect(test_result['enum_test']).to eql('val1')
532
471
  end
533
472
 
534
473
  it "should raise an error given an invalid DATETIME" do
@@ -537,14 +476,12 @@ RSpec.describe Mysql2::Statement do
537
476
  end
538
477
 
539
478
  context "string encoding for ENUM values" do
540
- before { pending('Encoding is undefined') unless defined?(Encoding) }
541
-
542
479
  it "should default to the connection's encoding if Encoding.default_internal is nil" do
543
480
  with_internal_encoding nil do
544
481
  result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
545
482
  expect(result['enum_test'].encoding).to eql(Encoding::UTF_8)
546
483
 
547
- client2 = new_client(:encoding => 'ascii')
484
+ client2 = new_client(encoding: 'ascii')
548
485
  result = client2.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
549
486
  expect(result['enum_test'].encoding).to eql(Encoding::US_ASCII)
550
487
  end
@@ -564,19 +501,17 @@ RSpec.describe Mysql2::Statement do
564
501
  end
565
502
 
566
503
  it "should return String for a SET value" do
567
- expect(@test_result['set_test']).to be_an_instance_of(String)
568
- expect(@test_result['set_test']).to eql('val1,val2')
504
+ expect(test_result['set_test']).to be_an_instance_of(String)
505
+ expect(test_result['set_test']).to eql('val1,val2')
569
506
  end
570
507
 
571
508
  context "string encoding for SET values" do
572
- before { pending('Encoding is undefined') unless defined?(Encoding) }
573
-
574
509
  it "should default to the connection's encoding if Encoding.default_internal is nil" do
575
510
  with_internal_encoding nil do
576
511
  result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
577
512
  expect(result['set_test'].encoding).to eql(Encoding::UTF_8)
578
513
 
579
- client2 = new_client(:encoding => 'ascii')
514
+ client2 = new_client(encoding: 'ascii')
580
515
  result = client2.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
581
516
  expect(result['set_test'].encoding).to eql(Encoding::US_ASCII)
582
517
  end
@@ -596,13 +531,11 @@ RSpec.describe Mysql2::Statement do
596
531
  end
597
532
 
598
533
  it "should return String for a BINARY value" do
599
- expect(@test_result['binary_test']).to be_an_instance_of(String)
600
- expect(@test_result['binary_test']).to eql("test#{"\000" * 6}")
534
+ expect(test_result['binary_test']).to be_an_instance_of(String)
535
+ expect(test_result['binary_test']).to eql("test#{"\000" * 6}")
601
536
  end
602
537
 
603
538
  context "string encoding for BINARY values" do
604
- before { pending('Encoding is undefined') unless defined?(Encoding) }
605
-
606
539
  it "should default to binary if Encoding.default_internal is nil" do
607
540
  with_internal_encoding nil do
608
541
  result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
@@ -637,14 +570,12 @@ RSpec.describe Mysql2::Statement do
637
570
  'long_text_test' => 'LONGTEXT',
638
571
  }.each do |field, type|
639
572
  it "should return a String for #{type}" do
640
- expect(@test_result[field]).to be_an_instance_of(String)
641
- expect(@test_result[field]).to eql("test")
573
+ expect(test_result[field]).to be_an_instance_of(String)
574
+ expect(test_result[field]).to eql("test")
642
575
  end
643
576
 
644
577
  context "string encoding for #{type} values" do
645
- before { pending('Encoding is undefined') unless defined?(Encoding) }
646
-
647
- if %w(VARBINARY TINYBLOB BLOB MEDIUMBLOB LONGBLOB).include?(type)
578
+ if %w[VARBINARY TINYBLOB BLOB MEDIUMBLOB LONGBLOB].include?(type)
648
579
  it "should default to binary if Encoding.default_internal is nil" do
649
580
  with_internal_encoding nil do
650
581
  result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
@@ -669,7 +600,7 @@ RSpec.describe Mysql2::Statement do
669
600
  result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
670
601
  expect(result[field].encoding).to eql(Encoding::UTF_8)
671
602
 
672
- client2 = new_client(:encoding => 'ascii')
603
+ client2 = new_client(encoding: 'ascii')
673
604
  result = client2.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
674
605
  expect(result[field].encoding).to eql(Encoding::US_ASCII)
675
606
  end
@@ -731,7 +662,6 @@ RSpec.describe Mysql2::Statement do
731
662
 
732
663
  it 'should return number of rows affected by an insert' do
733
664
  stmt = @client.prepare 'INSERT INTO lastIdTest (blah) VALUES (?)'
734
- expect(stmt.affected_rows).to eq 0
735
665
  stmt.execute 1
736
666
  expect(stmt.affected_rows).to eq 1
737
667
  end
@@ -764,7 +694,9 @@ RSpec.describe Mysql2::Statement do
764
694
  context 'close' do
765
695
  it 'should free server resources' do
766
696
  stmt = @client.prepare 'SELECT 1'
697
+ GC.disable
767
698
  expect { stmt.close }.to change(&method(:stmt_count)).by(-1)
699
+ GC.enable
768
700
  end
769
701
 
770
702
  it 'should raise an error on subsequent execution' do