tiny_tds 0.4.5.rc1-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.
@@ -0,0 +1,284 @@
1
+ # encoding: utf-8
2
+ require 'test_helper'
3
+
4
+ class SchemaTest < TinyTds::TestCase
5
+
6
+ context 'Casting SQL Server schema' do
7
+
8
+ setup do
9
+ @@current_schema_loaded ||= load_current_schema
10
+ @client ||= new_connection
11
+ @gif1px = ruby19? ? File.read('test/schema/1px.gif',:mode=>"rb:BINARY") : File.read('test/schema/1px.gif')
12
+ end
13
+
14
+ context 'for shared types' do
15
+
16
+ should 'cast bigint' do
17
+ assert_equal -9223372036854775807, find_value(11, :bigint)
18
+ assert_equal 9223372036854775806, find_value(12, :bigint)
19
+ end
20
+
21
+ should 'cast binary' do
22
+ binary_value = sqlserver_azure? ? @gif1px : @gif1px+"\000"
23
+ value = find_value(21, :binary_50)
24
+ assert_equal binary_value, value
25
+ assert_binary_encoding(value)
26
+ end
27
+
28
+ should 'cast bit' do
29
+ assert_equal true, find_value(31, :bit)
30
+ assert_equal false, find_value(32, :bit)
31
+ assert_equal nil, find_value(21, :bit)
32
+ end
33
+
34
+ should 'cast char' do
35
+ partial_char = sqlserver_azure? ? '12345678' : '12345678 '
36
+ assert_equal '1234567890', find_value(41, :char_10)
37
+ assert_equal partial_char, find_value(42, :char_10)
38
+ assert_utf8_encoding find_value(42, :char_10)
39
+ end
40
+
41
+ should 'cast datetime' do
42
+ # 1753-01-01T00:00:00.000
43
+ v = find_value 61, :datetime
44
+ assert_instance_of DateTime, v, 'not in range of Time class'
45
+ assert_equal 1753, v.year
46
+ assert_equal 01, v.month
47
+ assert_equal 01, v.day
48
+ assert_equal 0, v.hour
49
+ assert_equal 0, v.min
50
+ assert_equal 0, v.sec
51
+ assert_equal 0, v.usec
52
+ # 9999-12-31T23:59:59.997
53
+ v = find_value 62, :datetime
54
+ assert_instance_of DateTime, v, 'not in range of Time class'
55
+ assert_equal 9999, v.year
56
+ assert_equal 12, v.month
57
+ assert_equal 31, v.day
58
+ assert_equal 23, v.hour
59
+ assert_equal 59, v.min
60
+ assert_equal 59, v.sec
61
+ assert_equal 997000, v.usec unless ruby186?
62
+ assert_equal local_offset, find_value(61, :datetime, :timezone => :local).offset
63
+ assert_equal 0, find_value(61, :datetime, :timezone => :utc).offset
64
+ # 2010-01-01T12:34:56.123
65
+ v = find_value 63, :datetime
66
+ assert_instance_of Time, v, 'in range of Time class'
67
+ assert_equal 2010, v.year
68
+ assert_equal 01, v.month
69
+ assert_equal 01, v.day
70
+ assert_equal 12, v.hour
71
+ assert_equal 34, v.min
72
+ assert_equal 56, v.sec
73
+ assert_equal 123000, v.usec
74
+ assert_equal utc_offset, find_value(63, :datetime, :timezone => :local).utc_offset
75
+ assert_equal 0, find_value(63, :datetime, :timezone => :utc).utc_offset
76
+ end
77
+
78
+ should 'cast decimal' do
79
+ assert_instance_of BigDecimal, find_value(91, :decimal_9_2)
80
+ assert_equal BigDecimal.new('12345.01'), find_value(91, :decimal_9_2)
81
+ assert_equal BigDecimal.new('1234567.89'), find_value(92, :decimal_9_2)
82
+ assert_equal BigDecimal.new('0.0'), find_value(93, :decimal_16_4)
83
+ assert_equal BigDecimal.new('123456789012.3456'), find_value(94, :decimal_16_4)
84
+ end
85
+
86
+ should 'cast float' do
87
+ assert_equal 123.00000001, find_value(101,:float)
88
+ assert_equal 0.0, find_value(102,:float)
89
+ assert_equal find_value(102,:float).object_id, find_value(102,:float).object_id, 'use global zero float'
90
+ assert_equal 123.45, find_value(103,:float)
91
+ end
92
+
93
+ should 'cast image' do
94
+ value = find_value(141,:image)
95
+ assert_equal @gif1px, value
96
+ assert_binary_encoding(value)
97
+ end
98
+
99
+ should 'cast int' do
100
+ assert_equal -2147483647, find_value(151, :int)
101
+ assert_equal 2147483646, find_value(152, :int)
102
+ end
103
+
104
+ should 'cast money' do
105
+ assert_instance_of BigDecimal, find_value(161, :money)
106
+ assert_equal BigDecimal.new('4.20'), find_value(161, :money)
107
+ assert_equal BigDecimal.new('922337203685477.5806'), find_value(163 ,:money)
108
+ assert_equal BigDecimal.new('-922337203685477.5807'), find_value(162 ,:money)
109
+ end
110
+
111
+ should 'cast nchar' do
112
+ assert_equal '1234567890', find_value(171, :nchar_10)
113
+ assert_equal '123456åå ', find_value(172, :nchar_10)
114
+ assert_equal 'abc123 ', find_value(173, :nchar_10)
115
+ end
116
+
117
+ should 'cast ntext' do
118
+ assert_equal 'test ntext', find_value(181, :ntext)
119
+ assert_equal 'test ntext åå', find_value(182, :ntext)
120
+ assert_utf8_encoding find_value(182, :ntext)
121
+ # If this test fails, try setting the "text size" in your freetds.conf. See: http://www.freetds.org/faq.html#textdata
122
+ large_value = "x" * 5000
123
+ large_value_id = @client.execute("INSERT INTO [datatypes] ([ntext]) VALUES (N'#{large_value}')").insert
124
+ assert_equal large_value, find_value(large_value_id, :ntext)
125
+ end
126
+
127
+ should 'cast numeric' do
128
+ assert_instance_of BigDecimal, find_value(191, :numeric_18_0)
129
+ assert_equal BigDecimal('191'), find_value(191, :numeric_18_0)
130
+ assert_equal BigDecimal('123456789012345678'), find_value(192, :numeric_18_0)
131
+ assert_equal BigDecimal('12345678901234567890.01'), find_value(193, :numeric_36_2)
132
+ assert_equal BigDecimal('123.46'), find_value(194, :numeric_36_2)
133
+ end
134
+
135
+ should 'cast nvarchar' do
136
+ assert_equal 'test nvarchar_50', find_value(201, :nvarchar_50)
137
+ assert_equal 'test nvarchar_50 åå', find_value(202, :nvarchar_50)
138
+ assert_utf8_encoding find_value(202, :nvarchar_50)
139
+ end
140
+
141
+ should 'cast real' do
142
+ assert_in_delta 123.45, find_value(221, :real), 0.01
143
+ assert_equal 0.0, find_value(222, :real)
144
+ assert_equal find_value(222, :real).object_id, find_value(222, :real).object_id, 'use global zero float'
145
+ assert_in_delta 0.00001, find_value(223, :real), 0.000001
146
+ end
147
+
148
+ should 'cast smalldatetime' do
149
+ # 1901-01-01 15:45:00
150
+ v = find_value 231, :smalldatetime
151
+ assert_instance_of DateTime, v
152
+ assert_equal 1901, v.year
153
+ assert_equal 01, v.month
154
+ assert_equal 01, v.day
155
+ assert_equal 15, v.hour
156
+ assert_equal 45, v.min
157
+ assert_equal 00, v.sec
158
+ assert_equal local_offset, find_value(231, :smalldatetime, :timezone => :local).offset
159
+ assert_equal 0, find_value(231, :smalldatetime, :timezone => :utc).offset
160
+ # 2078-06-05 04:20:00
161
+ v = find_value 232, :smalldatetime
162
+ assert_instance_of DateTime, v
163
+ assert_equal 2078, v.year
164
+ assert_equal 06, v.month
165
+ assert_equal 05, v.day
166
+ assert_equal 04, v.hour
167
+ assert_equal 20, v.min
168
+ assert_equal 00, v.sec
169
+ assert_equal local_offset, find_value(232, :smalldatetime, :timezone => :local).offset
170
+ assert_equal 0, find_value(232, :smalldatetime, :timezone => :utc).offset
171
+ end
172
+
173
+ should 'cast smallint' do
174
+ assert_equal -32767, find_value(241, :smallint)
175
+ assert_equal 32766, find_value(242, :smallint)
176
+ end
177
+
178
+ should 'cast smallmoney' do
179
+ assert_instance_of BigDecimal, find_value(251, :smallmoney)
180
+ assert_equal BigDecimal.new("4.20"), find_value(251, :smallmoney)
181
+ assert_equal BigDecimal.new("-214748.3647"), find_value(252, :smallmoney)
182
+ assert_equal BigDecimal.new("214748.3646"), find_value(253, :smallmoney)
183
+ end
184
+
185
+ should 'cast text' do
186
+ assert_equal 'test text', find_value(271, :text)
187
+ assert_utf8_encoding find_value(271, :text)
188
+ end
189
+
190
+ should 'cast tinyint' do
191
+ assert_equal 0, find_value(301, :tinyint)
192
+ assert_equal 255, find_value(302, :tinyint)
193
+ end
194
+
195
+ should 'cast uniqueidentifier' do
196
+ assert_match %r|\w{8}-\w{4}-\w{4}-\w{4}-\w{12}|, find_value(311, :uniqueidentifier)
197
+ assert_utf8_encoding find_value(311, :uniqueidentifier)
198
+ end
199
+
200
+ should 'cast varbinary' do
201
+ value = find_value(321, :varbinary_50)
202
+ assert_equal @gif1px, value
203
+ assert_binary_encoding(value)
204
+ end
205
+
206
+ should 'cast varchar' do
207
+ assert_equal 'test varchar_50', find_value(341, :varchar_50)
208
+ assert_utf8_encoding find_value(341, :varchar_50)
209
+ end
210
+
211
+ end
212
+
213
+
214
+ context 'for 2005 and up' do
215
+
216
+ should 'cast nvarchar(max)' do
217
+ assert_equal 'test nvarchar_max', find_value(211, :nvarchar_max)
218
+ assert_equal 'test nvarchar_max åå', find_value(212, :nvarchar_max)
219
+ assert_utf8_encoding find_value(212, :nvarchar_max)
220
+ end
221
+
222
+ should 'cast varbinary(max)' do
223
+ value = find_value(331, :varbinary_max)
224
+ assert_equal @gif1px, value
225
+ assert_binary_encoding(value)
226
+ end
227
+
228
+ should 'cast varchar(max)' do
229
+ value = find_value(351, :varchar_max)
230
+ assert_equal 'test varchar_max', value
231
+ assert_utf8_encoding(value)
232
+ end
233
+
234
+ should 'cast xml' do
235
+ value = find_value(361, :xml)
236
+ assert_equal '<foo><bar>batz</bar></foo>', value
237
+ assert_utf8_encoding(value)
238
+ end
239
+
240
+ end if sqlserver_2005? || sqlserver_2008? || sqlserver_azure?
241
+
242
+
243
+ context 'for 2008 and up' do
244
+
245
+ should 'cast date' do
246
+
247
+ end
248
+
249
+ should 'cast datetime2' do
250
+
251
+ end
252
+
253
+ should 'cast datetimeoffset' do
254
+
255
+ end
256
+
257
+ should 'cast geography' do
258
+
259
+ end
260
+
261
+ should 'cast geometry' do
262
+
263
+ end
264
+
265
+ should 'cast hierarchyid' do
266
+
267
+ end
268
+
269
+ should 'cast time' do
270
+
271
+ end
272
+
273
+ end if sqlserver_2008? || sqlserver_azure?
274
+
275
+ end
276
+
277
+
278
+
279
+ end
280
+
281
+
282
+
283
+
284
+
@@ -0,0 +1,190 @@
1
+ # encoding: UTF-8
2
+ require 'rubygems'
3
+ require 'bundler'
4
+ Bundler.setup
5
+ require 'tiny_tds'
6
+ require 'mini_shoulda'
7
+ require 'minitest/autorun'
8
+
9
+ class DateTime
10
+ def usec
11
+ if RUBY_VERSION >= '1.9'
12
+ (sec_fraction * 1_000_000).to_i
13
+ else
14
+ (sec_fraction * 60 * 60 * 24 * (10**6)).to_i
15
+ end
16
+ end
17
+ end
18
+
19
+ TINYTDS_SCHEMAS = ['sqlserver_2000', 'sqlserver_2005', 'sqlserver_2008', 'sqlserver_azure'].freeze
20
+
21
+ module TinyTds
22
+ class TestCase < MiniTest::Spec
23
+
24
+ class << self
25
+
26
+ def current_schema
27
+ ENV['TINYTDS_SCHEMA'] || 'sqlserver_2008'
28
+ end
29
+
30
+ TINYTDS_SCHEMAS.each do |schema|
31
+ define_method "#{schema}?" do
32
+ schema == self.current_schema
33
+ end
34
+ end
35
+
36
+ end
37
+
38
+
39
+ protected
40
+
41
+ TINYTDS_SCHEMAS.each do |schema|
42
+ define_method "#{schema}?" do
43
+ schema == self.class.current_schema
44
+ end
45
+ end
46
+
47
+ def current_schema
48
+ self.class.current_schema
49
+ end
50
+
51
+ def new_connection(options={})
52
+ client = TinyTds::Client.new(connection_options(options))
53
+ unless sqlserver_azure?
54
+ client.execute("SET ANSI_DEFAULTS ON").do
55
+ client.execute("SET IMPLICIT_TRANSACTIONS OFF").do
56
+ client.execute("SET CURSOR_CLOSE_ON_COMMIT OFF").do
57
+ end
58
+ client
59
+ end
60
+
61
+ def connection_options(options={})
62
+ username = sqlserver_azure? ? ENV['TINYTDS_UNIT_AZURE_USER'] : 'tinytds'
63
+ password = sqlserver_azure? ? ENV['TINYTDS_UNIT_AZURE_PASS'] : ''
64
+ { :dataserver => ENV['TINYTDS_UNIT_DATASERVER'],
65
+ :host => ENV['TINYTDS_UNIT_HOST'],
66
+ :username => username,
67
+ :password => password,
68
+ :database => 'tinytdstest',
69
+ :appname => 'TinyTds Dev',
70
+ :login_timeout => 5,
71
+ :timeout => 5,
72
+ :azure => sqlserver_azure?
73
+ }.merge(options)
74
+ end
75
+
76
+ def assert_client_works(client)
77
+ client.execute("SELECT 'client_works' as [client_works]").each
78
+ end
79
+
80
+ def assert_new_connections_work
81
+ client = new_connection
82
+ client.execute("SELECT 'new_connections_work' as [new_connections_work]").each
83
+ end
84
+
85
+ def assert_raise_tinytds_error(action)
86
+ error_raised = false
87
+ begin
88
+ action.call
89
+ rescue TinyTds::Error => e
90
+ error_raised = true
91
+ end
92
+ assert error_raised, 'expected a TinyTds::Error but none happened'
93
+ yield e
94
+ end
95
+
96
+ def inspect_tinytds_exception
97
+ begin
98
+ yield
99
+ rescue TinyTds::Error => e
100
+ props = { :source => e.source, :message => e.message, :severity => e.severity,
101
+ :db_error_number => e.db_error_number, :os_error_number => e.os_error_number }
102
+ raise "TinyTds::Error - #{props.inspect}"
103
+ end
104
+ end
105
+
106
+ def assert_binary_encoding(value)
107
+ assert_equal Encoding.find('BINARY'), value.encoding if ruby19?
108
+ end
109
+
110
+ def assert_utf8_encoding(value)
111
+ assert_equal Encoding.find('UTF-8'), value.encoding if ruby19?
112
+ end
113
+
114
+ def ruby18?
115
+ RUBY_VERSION < '1.9'
116
+ end
117
+
118
+ def ruby186?
119
+ RUBY_VERSION == '1.8.6'
120
+ end
121
+
122
+ def ruby19?
123
+ RUBY_VERSION >= '1.9'
124
+ end
125
+
126
+ def ruby192?
127
+ RUBY_VERSION == '1.9.2'
128
+ end
129
+
130
+ def rubyRbx?
131
+ RUBY_DESCRIPTION =~ /rubinius/i
132
+ end
133
+
134
+ def load_current_schema
135
+ loader = new_connection
136
+ schema_file = File.expand_path File.join(File.dirname(__FILE__), 'schema', "#{current_schema}.sql")
137
+ schema_sql = ruby18? ? File.read(schema_file) : File.open(schema_file,"rb:UTF-8") { |f|f.read }
138
+ loader.execute(drop_sql).each
139
+ loader.execute(schema_sql).cancel
140
+ loader.execute(sp_sql).cancel
141
+ loader.close
142
+ true
143
+ end
144
+
145
+ def drop_sql
146
+ %|IF EXISTS (
147
+ SELECT TABLE_NAME
148
+ FROM INFORMATION_SCHEMA.TABLES
149
+ WHERE TABLE_CATALOG = 'tinytdstest'
150
+ AND TABLE_TYPE = 'BASE TABLE'
151
+ AND TABLE_NAME = 'datatypes'
152
+ ) DROP TABLE [datatypes]
153
+ IF EXISTS (
154
+ SELECT name FROM sysobjects
155
+ WHERE name = 'tinytds_TestReturnCodes' AND type = 'P'
156
+ ) DROP PROCEDURE tinytds_TestReturnCodes|
157
+ end
158
+
159
+ def sp_sql
160
+ %|CREATE PROCEDURE tinytds_TestReturnCodes
161
+ AS
162
+ SELECT 1 as [one]
163
+ RETURN(420) |
164
+ end
165
+
166
+ def find_value(id, column, query_options={})
167
+ query_options[:timezone] ||= :utc
168
+ sql = "SELECT [#{column}] FROM [datatypes] WHERE [id] = #{id}"
169
+ @client.execute(sql).each(query_options).first[column.to_s]
170
+ end
171
+
172
+ def local_offset
173
+ TinyTds::Client.local_offset
174
+ end
175
+
176
+ def utc_offset
177
+ ::Time.local(2010).utc_offset
178
+ end
179
+
180
+ def rollback_transaction(client)
181
+ client.execute("BEGIN TRANSACTION").do
182
+ yield
183
+ ensure
184
+ client.execute("ROLLBACK TRANSACTION").do
185
+ end
186
+
187
+
188
+ end
189
+ end
190
+
metadata ADDED
@@ -0,0 +1,117 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: tiny_tds
3
+ version: !ruby/object:Gem::Version
4
+ hash: 15424127
5
+ prerelease: 6
6
+ segments:
7
+ - 0
8
+ - 4
9
+ - 5
10
+ - rc
11
+ - 1
12
+ version: 0.4.5.rc1
13
+ platform: x86-mingw32
14
+ authors:
15
+ - Ken Collins
16
+ - Erik Bryn
17
+ autorequire:
18
+ bindir: bin
19
+ cert_chain: []
20
+
21
+ date: 2011-04-15 00:00:00 -04:00
22
+ default_executable:
23
+ dependencies: []
24
+
25
+ description: TinyTDS - A modern, simple and fast FreeTDS library for Ruby using DB-Library. Developed for the ActiveRecord SQL Server adapter.
26
+ email:
27
+ - ken@metaskills.net
28
+ executables: []
29
+
30
+ extensions: []
31
+
32
+ extra_rdoc_files: []
33
+
34
+ files:
35
+ - .gitignore
36
+ - CHANGELOG
37
+ - Gemfile
38
+ - MIT-LICENSE
39
+ - NOTES
40
+ - README.rdoc
41
+ - Rakefile
42
+ - ext/tiny_tds/client.c
43
+ - ext/tiny_tds/client.h
44
+ - ext/tiny_tds/extconf.rb
45
+ - ext/tiny_tds/result.c
46
+ - ext/tiny_tds/result.h
47
+ - ext/tiny_tds/tiny_tds_ext.c
48
+ - ext/tiny_tds/tiny_tds_ext.h
49
+ - lib/tiny_tds.rb
50
+ - lib/tiny_tds/client.rb
51
+ - lib/tiny_tds/error.rb
52
+ - lib/tiny_tds/result.rb
53
+ - lib/tiny_tds/version.rb
54
+ - tasks/ports.rake
55
+ - test/benchmark/query.rb
56
+ - test/benchmark/query_odbc.rb
57
+ - test/benchmark/query_tinytds.rb
58
+ - test/client_test.rb
59
+ - test/result_test.rb
60
+ - test/schema/1px.gif
61
+ - test/schema/sqlserver_2000.sql
62
+ - test/schema/sqlserver_2005.sql
63
+ - test/schema/sqlserver_2008.sql
64
+ - test/schema/sqlserver_azure.sql
65
+ - test/schema_test.rb
66
+ - test/test_helper.rb
67
+ - lib/tiny_tds/1.8/tiny_tds.so
68
+ - lib/tiny_tds/1.9/tiny_tds.so
69
+ has_rdoc: true
70
+ homepage: http://github.com/rails-sqlserver/tiny_tds
71
+ licenses: []
72
+
73
+ post_install_message:
74
+ rdoc_options:
75
+ - --charset=UTF-8
76
+ require_paths:
77
+ - lib
78
+ required_ruby_version: !ruby/object:Gem::Requirement
79
+ none: false
80
+ requirements:
81
+ - - ">="
82
+ - !ruby/object:Gem::Version
83
+ hash: 3
84
+ segments:
85
+ - 0
86
+ version: "0"
87
+ required_rubygems_version: !ruby/object:Gem::Requirement
88
+ none: false
89
+ requirements:
90
+ - - ">"
91
+ - !ruby/object:Gem::Version
92
+ hash: 25
93
+ segments:
94
+ - 1
95
+ - 3
96
+ - 1
97
+ version: 1.3.1
98
+ requirements: []
99
+
100
+ rubyforge_project:
101
+ rubygems_version: 1.6.2
102
+ signing_key:
103
+ specification_version: 3
104
+ summary: TinyTDS - A modern, simple and fast FreeTDS library for Ruby using DB-Library.
105
+ test_files:
106
+ - test/benchmark/query.rb
107
+ - test/benchmark/query_odbc.rb
108
+ - test/benchmark/query_tinytds.rb
109
+ - test/client_test.rb
110
+ - test/result_test.rb
111
+ - test/schema/1px.gif
112
+ - test/schema/sqlserver_2000.sql
113
+ - test/schema/sqlserver_2005.sql
114
+ - test/schema/sqlserver_2008.sql
115
+ - test/schema/sqlserver_azure.sql
116
+ - test/schema_test.rb
117
+ - test/test_helper.rb