sqlanywhere 0.1.4 → 0.1.6
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +5 -0
- data/LICENSE +1 -1
- data/README +1 -1
- data/Rakefile +9 -12
- data/ext/extconf.rb +1 -1
- data/ext/sacapi.h +529 -298
- data/ext/sacapidll.c +16 -1
- data/ext/sacapidll.h +91 -12
- data/ext/sqlanywhere.c +290 -223
- data/test/sqlanywhere_test.rb +27 -17
- data/test/test.sql +5 -0
- metadata +48 -43
data/test/sqlanywhere_test.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
#====================================================
|
2
2
|
#
|
3
|
-
# Copyright 2008-
|
3
|
+
# Copyright 2008-2010 iAnywhere Solutions, Inc.
|
4
4
|
#
|
5
5
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
6
|
# you may not use this file except in compliance with the License.
|
@@ -27,7 +27,6 @@ require 'date'
|
|
27
27
|
|
28
28
|
begin
|
29
29
|
require 'rubygems'
|
30
|
-
gem 'sqlanywhere'
|
31
30
|
unless defined? SQLAnywhere
|
32
31
|
require 'sqlanywhere'
|
33
32
|
end
|
@@ -123,7 +122,8 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
123
122
|
end
|
124
123
|
|
125
124
|
def test_column_info
|
126
|
-
|
125
|
+
is_iq = is_iq_table?("types")
|
126
|
+
rs = exec_direct_with_test("SELECT TOP 2 * FROM \"types\" ORDER BY \"id\"")
|
127
127
|
assert_equal 22, @api.sqlany_num_cols(rs)
|
128
128
|
assert_column_info(rs, 0, "id", Types::A_VAL32, 4)
|
129
129
|
assert_column_info(rs, 1, "_binary_", Types::A_BINARY, 8)
|
@@ -136,10 +136,10 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
136
136
|
assert_column_info(rs, 8, "_signed_int_", Types::A_VAL32, 4)
|
137
137
|
assert_column_info(rs, 9, "_unsigned_int_", Types::A_UVAL32, 4)
|
138
138
|
assert_column_info(rs, 10, "_signed_smallint_", Types::A_VAL16, 2)
|
139
|
-
assert_column_info(rs, 11, "_unsigned_smallint_", Types::A_UVAL16, 2)
|
140
|
-
assert_column_info(rs, 12, "_signed_tinyint_", Types::
|
141
|
-
assert_column_info(rs, 13, "_unsigned_tinyint_", Types::
|
142
|
-
assert_column_info(rs, 14, "_bit_", Types::
|
139
|
+
assert_column_info(rs, 11, "_unsigned_smallint_", Types::A_UVAL16, 2) unless is_iq #IQ Does not have an unsigned small int datatype
|
140
|
+
assert_column_info(rs, 12, "_signed_tinyint_", Types::A_UVAL8, 1)
|
141
|
+
assert_column_info(rs, 13, "_unsigned_tinyint_", Types::A_UVAL8, 1)
|
142
|
+
assert_column_info(rs, 14, "_bit_", Types::A_VAL8, 1)
|
143
143
|
assert_column_info(rs, 15, "_date_", Types::A_STRING, 10)
|
144
144
|
assert_column_info(rs, 16, "_datetime_", Types::A_STRING, 23)
|
145
145
|
assert_column_info(rs, 17, "_smalldatetime_", Types::A_STRING, 23)
|
@@ -151,7 +151,8 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
151
151
|
end
|
152
152
|
|
153
153
|
def test_bounds_on_types
|
154
|
-
|
154
|
+
is_iq = is_iq_table?("types")
|
155
|
+
rs = exec_direct_with_test("SELECT TOP 2 * FROM \"types\" ORDER BY \"id\"")
|
155
156
|
assert_succeeded @api.sqlany_fetch_next(rs)
|
156
157
|
assert_class_and_value(rs, String, 1, "x")
|
157
158
|
assert_class_and_value(rs, String, 2, "1.1")
|
@@ -163,7 +164,7 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
163
164
|
assert_class_and_value(rs, Bignum, 8, 2147483647)
|
164
165
|
assert_class_and_value(rs, Bignum, 9, 4294967295)
|
165
166
|
assert_class_and_value(rs, Fixnum, 10, 32767)
|
166
|
-
assert_class_and_value(rs, Fixnum, 11, 65535)
|
167
|
+
assert_class_and_value(rs, Fixnum, 11, 65535) unless is_iq #IQ Does not have an unsigned small int datatype
|
167
168
|
assert_class_and_value(rs, Fixnum, 12, 255)
|
168
169
|
assert_class_and_value(rs, Fixnum, 13, 255)
|
169
170
|
assert_class_and_value(rs, Fixnum, 14, 1)
|
@@ -186,7 +187,7 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
186
187
|
assert_class_and_value(rs, Bignum, 8, -2147483648)
|
187
188
|
assert_class_and_value(rs, Fixnum, 9, 0)
|
188
189
|
assert_class_and_value(rs, Fixnum, 10, -32768)
|
189
|
-
assert_class_and_value(rs, Fixnum, 11, 0)
|
190
|
+
assert_class_and_value(rs, Fixnum, 11, 0) unless is_iq #IQ Does not have an unsigned small int datatype
|
190
191
|
assert_class_and_value(rs, Fixnum, 12, 0)
|
191
192
|
assert_class_and_value(rs, Fixnum, 13, 0)
|
192
193
|
assert_class_and_value(rs, Fixnum, 14, 0)
|
@@ -201,9 +202,10 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
201
202
|
end
|
202
203
|
|
203
204
|
def test_prepared_stmt
|
204
|
-
|
205
|
+
is_iq = is_iq_table?("types")
|
206
|
+
stmt = @api.sqlany_prepare(@conn, "SELECT * FROM \"types\" WHERE \"id\" = ?")
|
205
207
|
assert_not_nil stmt
|
206
|
-
assert_failed @api.sqlany_execute(stmt)
|
208
|
+
assert_failed @api.sqlany_execute(stmt) unless is_iq #IQ does not throw an error here
|
207
209
|
assert_equal 1, @api.sqlany_num_params(stmt)
|
208
210
|
res, param = @api.sqlany_describe_bind_param(stmt, 0)
|
209
211
|
assert_not_equal 0, res
|
@@ -271,8 +273,9 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
271
273
|
end
|
272
274
|
|
273
275
|
def test_insert_uint16
|
274
|
-
|
275
|
-
|
276
|
+
is_iq = is_iq_table?("types") #IQ Does not have an unsigned small int datatype
|
277
|
+
assert_insert("_unsigned_smallint_", 65535, Fixnum) unless is_iq
|
278
|
+
assert_insert("_unsigned_smallint_", 0, Fixnum) unless is_iq
|
276
279
|
end
|
277
280
|
|
278
281
|
def test_insert_int8
|
@@ -281,8 +284,9 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
281
284
|
end
|
282
285
|
|
283
286
|
def test_insert_uint8
|
284
|
-
|
285
|
-
|
287
|
+
is_iq = is_iq_table?("types") #IQ Does not have an unsigned small int datatype
|
288
|
+
assert_insert("_unsigned_smallint_", 255, Fixnum) unless is_iq
|
289
|
+
assert_insert("_unsigned_smallint_", 0, Fixnum) unless is_iq
|
286
290
|
end
|
287
291
|
|
288
292
|
def test_insert_date
|
@@ -311,7 +315,13 @@ class SQLAnywhere_Test < Test::Unit::TestCase
|
|
311
315
|
|
312
316
|
def test_insert_real
|
313
317
|
assert_insert("_real_", 3.402823e+38, Float, 1e+32)
|
314
|
-
end
|
318
|
+
end
|
319
|
+
|
320
|
+
def is_iq_table?(table_name)
|
321
|
+
rs = @api.sqlany_execute_direct(@conn, "SELECT server_type FROM SYS.SYSTABLE WHERE table_name = '#{table_name}'")
|
322
|
+
@api.sqlany_fetch_next(rs)
|
323
|
+
return @api.sqlany_get_column(rs, 0)[1] == 'IQ'
|
324
|
+
end
|
315
325
|
|
316
326
|
def assert_insert(column_name, value, type, delta = nil)
|
317
327
|
stmt = @api.sqlany_prepare(@conn, 'INSERT INTO "types"("id", "' + column_name + '", "_bit_") VALUES(3, ?, 1)')
|
data/test/test.sql
CHANGED
@@ -1,3 +1,8 @@
|
|
1
|
+
// *****************************************************
|
2
|
+
// Copyright (c) 2008-2010 iAnywhere Solutions, Inc.
|
3
|
+
// Portions copyright (c) 1988-2010 Sybase, Inc.
|
4
|
+
// All rights reserved. All unpublished rights reserved.
|
5
|
+
// *****************************************************
|
1
6
|
IF EXISTS( SELECT * FROM "SYS"."SYSTAB" WHERE "table_name" = 'test') THEN
|
2
7
|
DROP TABLE "test";
|
3
8
|
END IF;
|
metadata
CHANGED
@@ -1,34 +1,29 @@
|
|
1
|
-
--- !ruby/object:Gem::Specification
|
2
|
-
rubygems_version: 0.9.4
|
3
|
-
specification_version: 1
|
1
|
+
--- !ruby/object:Gem::Specification
|
4
2
|
name: sqlanywhere
|
5
|
-
version: !ruby/object:Gem::Version
|
6
|
-
version: 0.1.
|
7
|
-
|
8
|
-
summary: SQL Anywhere library for Ruby
|
9
|
-
require_paths:
|
10
|
-
- lib
|
11
|
-
email: eric.farrar@ianywhere.com
|
12
|
-
homepage: http://sqlanywhere.rubyforge.org
|
13
|
-
rubyforge_project: sqlanywhere
|
14
|
-
description: SQL Anywhere Driver for Ruby
|
15
|
-
autorequire: sqlanywhere
|
16
|
-
default_executable:
|
17
|
-
bindir: bin
|
18
|
-
has_rdoc: true
|
19
|
-
required_ruby_version: !ruby/object:Gem::Version::Requirement
|
20
|
-
requirements:
|
21
|
-
- - ">="
|
22
|
-
- !ruby/object:Gem::Version
|
23
|
-
version: 1.8.6
|
24
|
-
version:
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.1.6
|
5
|
+
prerelease:
|
25
6
|
platform: ruby
|
26
|
-
|
27
|
-
cert_chain:
|
28
|
-
post_install_message:
|
29
|
-
authors:
|
7
|
+
authors:
|
30
8
|
- Eric Farrar
|
31
|
-
|
9
|
+
autorequire:
|
10
|
+
bindir: bin
|
11
|
+
cert_chain: []
|
12
|
+
date: 2011-12-14 00:00:00.000000000 Z
|
13
|
+
dependencies: []
|
14
|
+
description: ! ' SQL Anywhere Driver for Ruby
|
15
|
+
|
16
|
+
'
|
17
|
+
email: eric.farrar@ianywhere.com
|
18
|
+
executables: []
|
19
|
+
extensions:
|
20
|
+
- ext/extconf.rb
|
21
|
+
extra_rdoc_files:
|
22
|
+
- README
|
23
|
+
- CHANGELOG
|
24
|
+
- LICENSE
|
25
|
+
- ext/sqlanywhere.c
|
26
|
+
files:
|
32
27
|
- ext/extconf.rb
|
33
28
|
- ext/sacapi.h
|
34
29
|
- ext/sacapidll.c
|
@@ -40,24 +35,34 @@ files:
|
|
40
35
|
- LICENSE
|
41
36
|
- README
|
42
37
|
- Rakefile
|
43
|
-
|
44
|
-
|
45
|
-
|
38
|
+
homepage: http://sqlanywhere.rubyforge.org
|
39
|
+
licenses: []
|
40
|
+
post_install_message:
|
41
|
+
rdoc_options:
|
46
42
|
- --title
|
47
43
|
- SQL Anywhere Ruby Driver
|
48
44
|
- --main
|
49
45
|
- README
|
50
46
|
- --line-numbers
|
51
|
-
|
52
|
-
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
47
|
+
require_paths:
|
48
|
+
- lib
|
49
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
50
|
+
none: false
|
51
|
+
requirements:
|
52
|
+
- - ! '>='
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: 1.8.6
|
55
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
56
|
+
none: false
|
57
|
+
requirements:
|
58
|
+
- - ! '>='
|
59
|
+
- !ruby/object:Gem::Version
|
60
|
+
version: '0'
|
60
61
|
requirements: []
|
61
|
-
|
62
|
-
|
63
|
-
|
62
|
+
rubyforge_project: sqlanywhere
|
63
|
+
rubygems_version: 1.8.12
|
64
|
+
signing_key:
|
65
|
+
specification_version: 3
|
66
|
+
summary: SQL Anywhere library for Ruby
|
67
|
+
test_files:
|
68
|
+
- test/sqlanywhere_test.rb
|