make specs a little finer grained, fix a few issues found along the way

This commit is contained in:
Brian Lopez 2010-04-29 10:01:25 -07:00
parent 61e748ddc4
commit dfca514562
2 changed files with 90 additions and 48 deletions

View File

@ -352,8 +352,10 @@ static VALUE rb_mysql_result_fetch_row(int argc, VALUE * argv, VALUE self) {
case MYSQL_TYPE_NULL: // NULL-type field case MYSQL_TYPE_NULL: // NULL-type field
val = Qnil; val = Qnil;
break; break;
case MYSQL_TYPE_TINY: // TINYINT field
case MYSQL_TYPE_BIT: // BIT field (MySQL 5.0.3 and up) case MYSQL_TYPE_BIT: // BIT field (MySQL 5.0.3 and up)
val = rb_str_new(row[i], fieldLengths[i]);
break;
case MYSQL_TYPE_TINY: // TINYINT field
case MYSQL_TYPE_SHORT: // SMALLINT field case MYSQL_TYPE_SHORT: // SMALLINT field
case MYSQL_TYPE_LONG: // INTEGER field case MYSQL_TYPE_LONG: // INTEGER field
case MYSQL_TYPE_INT24: // MEDIUMINT field case MYSQL_TYPE_INT24: // MEDIUMINT field

View File

@ -52,8 +52,9 @@ describe Mysql2::Result do
@client.query "USE test" @client.query "USE test"
@client.query %[ @client.query %[
CREATE TABLE IF NOT EXISTS mysql2_test ( CREATE TABLE IF NOT EXISTS mysql2_test (
id MEDIUMINT NOT NULL AUTO_INCREMENT,
null_test VARCHAR(10), null_test VARCHAR(10),
bit_test BIT, bit_test BIT(64),
tiny_int_test TINYINT, tiny_int_test TINYINT,
small_int_test SMALLINT, small_int_test SMALLINT,
medium_int_test MEDIUMINT, medium_int_test MEDIUMINT,
@ -80,7 +81,8 @@ describe Mysql2::Result do
long_blob_test LONGBLOB, long_blob_test LONGBLOB,
long_text_test LONGTEXT, long_text_test LONGTEXT,
enum_test ENUM('val1', 'val2'), enum_test ENUM('val1', 'val2'),
set_test SET('val1', 'val2') set_test SET('val1', 'val2'),
PRIMARY KEY (id)
) )
] ]
@client.query %[ @client.query %[
@ -93,14 +95,18 @@ describe Mysql2::Result do
) )
VALUES ( VALUES (
NULL, 1, 1, 10, 10, 10, 10, NULL, b'101', 1, 10, 10, 10, 10,
10.3, 10.3, 10.3, '2010-4-4', '2010-4-4 11:44:00', '2010-4-4 11:44:00', '11:44:00', 10.3, 10.3, 10.3, '2010-4-4', '2010-4-4 11:44:00', '2010-4-4 11:44:00', '11:44:00',
2009, "test", "test", "test", "test", "test", 2009, "test", "test", "test", "test", "test",
"test", "test", "test", "test", "test", "test", "test", "test", "test", "test",
"test", "test", 'val1', 'val1,val2' "test", "test", 'val1', 'val1,val2'
) )
] ]
@test_result = @client.query("SELECT * FROM mysql2_test LIMIT 1").first @test_result = @client.query("SELECT * FROM mysql2_test ORDER BY id DESC LIMIT 1").first
end
after(:all) do
@client.query("DELETE FROM mysql2_test WHERE id=#{@test_result['id']}")
end end
it "should return nil for a NULL value" do it "should return nil for a NULL value" do
@ -108,59 +114,94 @@ describe Mysql2::Result do
@test_result['null_test'].should eql(nil) @test_result['null_test'].should eql(nil)
end end
{ it "should return Fixnum for a BIT value" do
'bit_test' => 'BIT', @test_result['bit_test'].class.should eql(String)
'tiny_int_test' => 'TINYINT', @test_result['bit_test'].should eql("\000\000\000\000\000\000\000\005")
'small_int_test' => 'SMALLINT',
'medium_int_test' => 'MEDIUMINT',
'int_test' => 'INT',
'big_int_test' => 'BIGINT',
'year_test' => 'YEAR'
}.each do |field, type|
it "should return a Fixnum for #{type}" do
[Fixnum, Bignum].should include(@test_result[field].class)
end
end end
{ it "should return Fixnum for a TINYINT value" do
'decimal_test' => 'DECIMAL' [Fixnum, Bignum].should include(@test_result['tiny_int_test'].class)
}.each do |field, type| @test_result['tiny_int_test'].should eql(1)
it "should return a Fixnum for #{type}" do
@test_result[field].class.should eql(BigDecimal)
end
end end
{ it "should return Fixnum for a SMALLINT value" do
'float_test' => 'FLOAT', [Fixnum, Bignum].should include(@test_result['small_int_test'].class)
'double_test' => 'DOUBLE' @test_result['small_int_test'].should eql(10)
}.each do |field, type|
it "should return a Float for #{type}" do
@test_result[field].class.should eql(Float)
end
end end
{ it "should return Fixnum for a MEDIUMINT value" do
'date_time_test' => 'DATETIME', [Fixnum, Bignum].should include(@test_result['medium_int_test'].class)
'timestamp_test' => 'TIMESTAMP', @test_result['medium_int_test'].should eql(10)
'time_test' => 'TIME'
}.each do |field, type|
it "should return a Time for #{type}" do
@test_result[field].class.should eql(Time)
end
end end
{ it "should return Fixnum for an INT value" do
'date_test' => 'DATE' [Fixnum, Bignum].should include(@test_result['int_test'].class)
}.each do |field, type| @test_result['int_test'].should eql(10)
it "should return a Date for #{type}" do end
@test_result[field].class.should eql(Date)
end it "should return Fixnum for a BIGINT value" do
[Fixnum, Bignum].should include(@test_result['big_int_test'].class)
@test_result['big_int_test'].should eql(10)
end
it "should return Fixnum for a YEAR value" do
[Fixnum, Bignum].should include(@test_result['year_test'].class)
@test_result['year_test'].should eql(2009)
end
it "should return BigDecimal for a DECIMAL value" do
@test_result['decimal_test'].class.should eql(BigDecimal)
@test_result['decimal_test'].should eql(10.3)
end
it "should return Float for a FLOAT value" do
@test_result['float_test'].class.should eql(Float)
@test_result['float_test'].should eql(10.3)
end
it "should return Float for a DOUBLE value" do
@test_result['double_test'].class.should eql(Float)
@test_result['double_test'].should eql(10.3)
end
it "should return Time for a DATETIME value" do
@test_result['date_time_test'].class.should eql(Time)
@test_result['date_time_test'].strftime("%F %T").should eql('2010-04-04 11:44:00')
end
it "should return Time for a TIMESTAMP value" do
@test_result['timestamp_test'].class.should eql(Time)
@test_result['timestamp_test'].strftime("%F %T").should eql('2010-04-04 11:44:00')
end
it "should return Time for a TIME value" do
@test_result['time_test'].class.should eql(Time)
@test_result['time_test'].strftime("%F %T").should eql('2000-01-01 11:44:00')
end
it "should return Date for a DATE value" do
@test_result['date_test'].class.should eql(Date)
@test_result['date_test'].strftime("%F").should eql('2010-04-04')
end
it "should return String for an ENUM value" do
@test_result['enum_test'].class.should eql(String)
@test_result['enum_test'].should eql('val1')
end
it "should return String for a SET value" do
@test_result['set_test'].class.should eql(String)
@test_result['set_test'].should eql('val1,val2')
end
it "should return String for a BINARY value" do
@test_result['binary_test'].class.should eql(String)
@test_result['binary_test'].should eql("test#{"\000"*6}")
end end
{ {
'char_test' => 'CHAR', 'char_test' => 'CHAR',
'varchar_test' => 'VARCHAR', 'varchar_test' => 'VARCHAR',
'binary_test' => 'BINARY',
'varbinary_test' => 'VARBINARY', 'varbinary_test' => 'VARBINARY',
'tiny_blob_test' => 'TINYBLOB', 'tiny_blob_test' => 'TINYBLOB',
'tiny_text_test' => 'TINYTEXT', 'tiny_text_test' => 'TINYTEXT',
@ -169,12 +210,11 @@ describe Mysql2::Result do
'medium_blob_test' => 'MEDIUMBLOB', 'medium_blob_test' => 'MEDIUMBLOB',
'medium_text_test' => 'MEDIUMTEXT', 'medium_text_test' => 'MEDIUMTEXT',
'long_blob_test' => 'LONGBLOB', 'long_blob_test' => 'LONGBLOB',
'long_text_test' => 'LONGTEXT', 'long_text_test' => 'LONGTEXT'
'enum_test' => 'ENUM',
'set_test' => 'SET'
}.each do |field, type| }.each do |field, type|
it "should return a String for #{type}" do it "should return a String for #{type}" do
@test_result[field].class.should eql(String) @test_result[field].class.should eql(String)
@test_result[field].should eql("test")
end end
end end
end end