-
Notifications
You must be signed in to change notification settings - Fork 188
/
Copy pathschema_test.rb
417 lines (384 loc) · 14.2 KB
/
schema_test.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
require "test_helper"
class SchemaTest < TinyTds::TestCase
describe "Casting SQL Server schema" do
before do
@@current_schema_loaded ||= load_current_schema
@client = new_connection
@gif1px = File.read("test/schema/1px.gif", mode: "rb:BINARY")
end
it "casts bigint" do
assert_equal(-9223372036854775807, find_value(11, :bigint))
assert_equal 9223372036854775806, find_value(12, :bigint)
end
it "casts binary" do
value = find_value(21, :binary_50)
assert_equal @gif1px + "\000", value
assert_binary_encoding(value)
end
it "casts bit" do
assert_equal true, find_value(31, :bit)
assert_equal false, find_value(32, :bit)
assert_nil find_value(21, :bit)
end
it "casts char" do
partial_char = "12345678 "
assert_equal "1234567890", find_value(41, :char_10)
assert_equal partial_char, find_value(42, :char_10)
assert_utf8_encoding find_value(42, :char_10)
end
it "casts datetime" do
# 1753-01-01T00:00:00.000
v = find_value 61, :datetime
assert_instance_of Time, v, "not in range of Time class"
assert_equal 1753, v.year
assert_equal 0o1, v.month
assert_equal 0o1, v.day
assert_equal 0, v.hour
assert_equal 0, v.min
assert_equal 0, v.sec
assert_equal 0, v.usec
# 9999-12-31T23:59:59.997
v = find_value 62, :datetime
assert_instance_of Time, v, "not in range of Time class"
assert_equal 9999, v.year
assert_equal 12, v.month
assert_equal 31, v.day
assert_equal 23, v.hour
assert_equal 59, v.min
assert_equal 59, v.sec
assert_equal 997000, v.usec
assert_equal utc_offset, find_value(62, :datetime, timezone: :local).utc_offset
assert_equal 0, find_value(62, :datetime, timezone: :utc).utc_offset
# 2010-01-01T12:34:56.123
v = find_value 63, :datetime
assert_instance_of Time, v, "in range of Time class"
assert_equal 2010, v.year
assert_equal 0o1, v.month
assert_equal 0o1, v.day
assert_equal 12, v.hour
assert_equal 34, v.min
assert_equal 56, v.sec
assert_equal 123000, v.usec
assert_equal utc_offset, find_value(63, :datetime, timezone: :local).utc_offset
assert_equal 0, find_value(63, :datetime, timezone: :utc).utc_offset
end
it "casts decimal" do
assert_instance_of BigDecimal, find_value(91, :decimal_9_2)
assert_equal BigDecimal("12345.01"), find_value(91, :decimal_9_2)
assert_equal BigDecimal("1234567.89"), find_value(92, :decimal_9_2)
assert_equal BigDecimal("0.0"), find_value(93, :decimal_16_4)
assert_equal BigDecimal("123456789012.3456"), find_value(94, :decimal_16_4)
end
it "casts float" do
assert_equal 123.00000001, find_value(101, :float)
assert_equal 0.0, find_value(102, :float)
assert_equal find_value(102, :float).object_id, find_value(102, :float).object_id, "use global zero float"
assert_equal 123.45, find_value(103, :float)
end
it "casts image" do
value = find_value(141, :image)
assert_equal @gif1px, value
assert_binary_encoding(value)
end
it "casts int" do
assert_equal(-2147483647, find_value(151, :int))
assert_equal 2147483646, find_value(152, :int)
end
it "casts money" do
assert_instance_of BigDecimal, find_value(161, :money)
assert_equal BigDecimal("4.20"), find_value(161, :money)
assert_equal BigDecimal("922337203685477.5806"), find_value(163, :money)
assert_equal BigDecimal("-922337203685477.5807"), find_value(162, :money)
end
it "casts nchar" do
assert_equal "1234567890", find_value(171, :nchar_10)
assert_equal "123456åå ", find_value(172, :nchar_10)
assert_equal "abc123 ", find_value(173, :nchar_10)
end
it "casts ntext" do
assert_equal "test ntext", find_value(181, :ntext)
assert_equal "test ntext åå", find_value(182, :ntext)
assert_utf8_encoding find_value(182, :ntext)
# If this test fails, try setting the "text size" in your freetds.conf. See: http://www.freetds.org/faq.html#textdata
large_value = "x" * 5000
large_value_id = @client.execute("INSERT INTO [datatypes] ([ntext]) VALUES (N'#{large_value}')").insert
assert_equal large_value, find_value(large_value_id, :ntext)
end
it "casts numeric" do
assert_instance_of BigDecimal, find_value(191, :numeric_18_0)
assert_equal BigDecimal("191"), find_value(191, :numeric_18_0)
assert_equal BigDecimal("123456789012345678"), find_value(192, :numeric_18_0)
assert_equal BigDecimal("12345678901234567890.01"), find_value(193, :numeric_36_2)
assert_equal BigDecimal("123.46"), find_value(194, :numeric_36_2)
end
it "casts nvarchar" do
assert_equal "test nvarchar_50", find_value(201, :nvarchar_50)
assert_equal "test nvarchar_50 åå", find_value(202, :nvarchar_50)
assert_utf8_encoding find_value(202, :nvarchar_50)
end
it "casts real" do
assert_in_delta 123.45, find_value(221, :real), 0.01
assert_equal 0.0, find_value(222, :real)
assert_equal find_value(222, :real).object_id, find_value(222, :real).object_id, "use global zero float"
assert_in_delta 0.00001, find_value(223, :real), 0.000001
end
it "casts smalldatetime" do
# 1901-01-01 15:45:00
v = find_value 231, :smalldatetime
assert_instance_of Time, v
assert_equal 1901, v.year
assert_equal 0o1, v.month
assert_equal 0o1, v.day
assert_equal 15, v.hour
assert_equal 45, v.min
assert_equal 0o0, v.sec
assert_equal Time.local(1901).utc_offset, find_value(231, :smalldatetime, timezone: :local).utc_offset
assert_equal 0, find_value(231, :smalldatetime, timezone: :utc).utc_offset
# 2078-06-05 04:20:00
v = find_value 232, :smalldatetime
assert_instance_of Time, v
assert_equal 2078, v.year
assert_equal 0o6, v.month
assert_equal 0o5, v.day
assert_equal 0o4, v.hour
assert_equal 20, v.min
assert_equal 0o0, v.sec
assert_equal Time.local(2078, 6).utc_offset, find_value(232, :smalldatetime, timezone: :local).utc_offset
assert_equal 0, find_value(232, :smalldatetime, timezone: :utc).utc_offset
end
it "casts smallint" do
assert_equal(-32767, find_value(241, :smallint))
assert_equal 32766, find_value(242, :smallint)
end
it "casts smallmoney" do
assert_instance_of BigDecimal, find_value(251, :smallmoney)
assert_equal BigDecimal("4.20"), find_value(251, :smallmoney)
assert_equal BigDecimal("-214748.3647"), find_value(252, :smallmoney)
assert_equal BigDecimal("214748.3646"), find_value(253, :smallmoney)
end
it "casts text" do
assert_equal "test text", find_value(271, :text)
assert_utf8_encoding find_value(271, :text)
end
it "casts tinyint" do
assert_equal 0, find_value(301, :tinyint)
assert_equal 255, find_value(302, :tinyint)
end
it "casts uniqueidentifier" do
assert_match %r|\w{8}-\w{4}-\w{4}-\w{4}-\w{12}|, find_value(311, :uniqueidentifier)
assert_utf8_encoding find_value(311, :uniqueidentifier)
end
it "casts varbinary" do
value = find_value(321, :varbinary_50)
assert_equal @gif1px, value
assert_binary_encoding(value)
end
it "casts varchar" do
assert_equal "test varchar_50", find_value(341, :varchar_50)
assert_utf8_encoding find_value(341, :varchar_50)
end
it "casts nvarchar(max)" do
assert_equal "test nvarchar_max", find_value(211, :nvarchar_max)
assert_equal "test nvarchar_max åå", find_value(212, :nvarchar_max)
assert_utf8_encoding find_value(212, :nvarchar_max)
end
it "casts varbinary(max)" do
value = find_value(331, :varbinary_max)
assert_equal @gif1px, value
assert_binary_encoding(value)
end
it "casts varchar(max)" do
value = find_value(351, :varchar_max)
assert_equal "test varchar_max", value
assert_utf8_encoding(value)
end
it "casts xml" do
value = find_value(361, :xml)
assert_equal "<foo><bar>batz</bar></foo>", value
assert_utf8_encoding(value)
end
it "casts date" do
# 0001-01-01
v = find_value 51, :date
if @client.tds_73?
assert_instance_of Date, v
assert_equal 1, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
else
assert_equal "0001-01-01", v
end
# 9999-12-31
v = find_value 52, :date
if @client.tds_73?
assert_instance_of Date, v
assert_equal 9999, v.year, "Year"
assert_equal 12, v.month, "Month"
assert_equal 31, v.day, "Day"
else
assert_equal "9999-12-31", v
end
end
it "casts time" do
# 15:45:00.709714966
v = find_value 281, :time_2
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1900, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
assert_equal 15, v.hour, "Hour"
assert_equal 45, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 710000, v.usec, "Microseconds"
assert_equal 710000000, v.nsec, "Nanoseconds"
else
assert_equal "15:45:00.71", v
end
# 04:20:00.288321545
v = find_value 282, :time_2
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1900, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
assert_equal 4, v.hour, "Hour"
assert_equal 20, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 290000, v.usec, "Microseconds"
assert_equal 290000000, v.nsec, "Nanoseconds"
else
assert_equal "04:20:00.29", v
end
# 15:45:00.709714966
v = find_value 283, :time_7
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1900, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
assert_equal 15, v.hour, "Hour"
assert_equal 45, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 709715, v.usec, "Microseconds"
assert_equal 709715000, v.nsec, "Nanoseconds"
else
assert_equal "15:45:00.7097150", v
end
# 04:20:00.288321545
v = find_value 284, :time_7
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1900, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
assert_equal 4, v.hour, "Hour"
assert_equal 20, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 288321, v.usec, "Microseconds"
assert_equal 288321500, v.nsec, "Nanoseconds"
else
assert_equal "04:20:00.2883215", v
end
end
it "casts datetime2" do
# 0001-01-01 00:00:00.0000000
v = find_value 71, :datetime2_7
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 1, v.day, "Day"
assert_equal 0, v.hour, "Hour"
assert_equal 0, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 0, v.usec, "Microseconds"
assert_equal 0, v.nsec, "Nanoseconds"
else
assert_equal "0001-01-01 00:00:00.0000000", v
end
# 1984-01-24 04:20:00.0000000
v = find_value 72, :datetime2_7
if @client.tds_73?
assert_instance_of Time, v
assert_equal 1984, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 24, v.day, "Day"
assert_equal 4, v.hour, "Hour"
assert_equal 20, v.min, "Minute"
assert_equal 0, v.sec, "Second"
assert_equal 0, v.usec, "Microseconds"
assert_equal 0, v.nsec, "Nanoseconds"
else
assert_equal "1984-01-24 04:20:00.0000000", v
end
# 9999-12-31 23:59:59.9999999
v = find_value 73, :datetime2_7
if @client.tds_73?
assert_instance_of Time, v
assert_equal 9999, v.year, "Year"
assert_equal 12, v.month, "Month"
assert_equal 31, v.day, "Day"
assert_equal 23, v.hour, "Hour"
assert_equal 59, v.min, "Minute"
assert_equal 59, v.sec, "Second"
assert_equal 999999, v.usec, "Microseconds"
assert_equal 999999900, v.nsec, "Nanoseconds"
else
assert_equal "9999-12-31 23:59:59.9999999", v
end
# 9999-12-31 23:59:59.123456789
v = find_value 74, :datetime2_2
if @client.tds_73?
assert_instance_of Time, v
assert_equal 9999, v.year, "Year"
assert_equal 12, v.month, "Month"
assert_equal 31, v.day, "Day"
assert_equal 23, v.hour, "Hour"
assert_equal 59, v.min, "Minute"
assert_equal 59, v.sec, "Second"
assert_equal 120000, v.usec, "Microseconds"
assert_equal 120000000, v.nsec, "Nanoseconds"
else
assert_equal "9999-12-31 23:59:59.12", v
end
end
it "casts datetimeoffset" do
# 1984-01-24T04:20:00.1234567-08:00
v = find_value 84, :datetimeoffset_7
if @client.tds_73?
assertions = lambda {
assert_instance_of Time, v
assert_equal 1984, v.year, "Year"
assert_equal 1, v.month, "Month"
assert_equal 24, v.day, "Day"
assert_equal 4, v.hour, "Hour"
assert_equal 20, v.min, "Minute"
assert_equal 59, v.sec, "Second"
assert_equal 123456, v.usec, "Microseconds"
assert_equal 123456700, v.nsec, "Nanoseconds"
assert_equal(-28800, v.utc_offset, "Offset")
}
assertions.call
v = find_value 84, :datetimeoffset_7, timezone: :local
assertions.call # Ignores timezone query option.
else
assert_equal "1984-01-24 04:20:59.1234567 -08:00", v
end
end
# it 'casts geography' do
# value = find_value 111, :geography
# assert_equal '', value
# end
#
# it 'casts geometry' do
# value = find_value 121, :geometry
# assert_equal '', value
# end
#
# it 'casts hierarchyid' do
# value = find_value 131, :hierarchyid
# assert_equal '', value
# end
end
end