imparcial 0.0.4 → 0.0.5
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +2 -5
- data/Manifest.txt +79 -5
- data/README.txt +71 -7
- data/Rakefile +1 -1
- data/lib/imparcial/driver/abstract/expression/column.rb +313 -0
- data/lib/imparcial/driver/abstract/expression/constraint.rb +149 -0
- data/lib/imparcial/driver/abstract/expression/delete.rb +88 -0
- data/lib/imparcial/driver/abstract/expression/index.rb +206 -0
- data/lib/imparcial/driver/abstract/expression/insert.rb +49 -0
- data/lib/imparcial/driver/abstract/expression/lock.rb +11 -0
- data/lib/imparcial/driver/abstract/expression/record.rb +41 -0
- data/lib/imparcial/driver/abstract/expression/select.rb +38 -0
- data/lib/imparcial/driver/abstract/expression/sequence.rb +260 -0
- data/lib/imparcial/driver/abstract/expression/statement.rb +128 -0
- data/lib/imparcial/driver/abstract/expression/table.rb +416 -0
- data/lib/imparcial/driver/abstract/expression/transaction.rb +143 -0
- data/lib/imparcial/driver/abstract/expression/update.rb +50 -0
- data/lib/imparcial/driver/abstract/expression.rb +23 -0
- data/lib/imparcial/driver/abstract/result.rb +95 -0
- data/lib/imparcial/driver/abstract/sql/column.rb +103 -0
- data/lib/imparcial/driver/abstract/sql/constraint.rb +42 -0
- data/lib/imparcial/driver/abstract/sql/delete.rb +22 -0
- data/lib/imparcial/driver/abstract/sql/index.rb +45 -0
- data/lib/imparcial/driver/abstract/sql/insert.rb +63 -0
- data/lib/imparcial/driver/abstract/sql/record.rb +19 -0
- data/lib/imparcial/driver/abstract/sql/select.rb +101 -0
- data/lib/imparcial/driver/abstract/sql/sequence.rb +55 -0
- data/lib/imparcial/driver/abstract/sql/table.rb +42 -0
- data/lib/imparcial/driver/abstract/sql/transaction.rb +43 -0
- data/lib/imparcial/driver/abstract/sql/update.rb +29 -0
- data/lib/imparcial/driver/abstract/sql.rb +21 -0
- data/lib/imparcial/driver/abstract/typemap.rb +168 -0
- data/lib/imparcial/driver/abstract/util.rb +53 -0
- data/lib/imparcial/driver/abstract.rb +255 -0
- data/lib/imparcial/driver/mysql/expression/table.rb +17 -0
- data/lib/imparcial/driver/mysql/expression.rb +11 -0
- data/lib/imparcial/driver/mysql/result.rb +33 -0
- data/lib/imparcial/driver/mysql/sql/column.rb +59 -0
- data/lib/imparcial/driver/mysql/sql/constraint.rb +39 -0
- data/lib/imparcial/driver/mysql/sql/index.rb +42 -0
- data/lib/imparcial/driver/mysql/sql/sequence.rb +39 -0
- data/lib/imparcial/driver/mysql/sql/table.rb +67 -0
- data/lib/imparcial/driver/mysql/sql.rb +15 -0
- data/lib/imparcial/driver/mysql/typemap.rb +13 -0
- data/lib/imparcial/driver/mysql/util.rb +13 -0
- data/lib/imparcial/driver/mysql.rb +49 -0
- data/lib/imparcial/driver/postgre/expression.rb +32 -0
- data/lib/imparcial/driver/postgre/result.rb +35 -0
- data/lib/imparcial/driver/postgre/sql/column.rb +53 -0
- data/lib/imparcial/driver/postgre/sql/constraint.rb +37 -0
- data/lib/imparcial/driver/postgre/sql/index.rb +53 -0
- data/lib/imparcial/driver/postgre/sql/sequence.rb +30 -0
- data/lib/imparcial/driver/postgre/sql/table.rb +46 -0
- data/lib/imparcial/driver/postgre/sql.rb +15 -0
- data/lib/imparcial/driver/postgre/typemap.rb +36 -0
- data/lib/imparcial/driver/postgre/util.rb +19 -0
- data/lib/imparcial/driver/postgre.rb +43 -0
- data/lib/imparcial/driver.rb +1 -0
- data/lib/imparcial/exception.rb +71 -0
- data/lib/imparcial/extension.rb +90 -0
- data/lib/imparcial/initializer.rb +30 -0
- data/lib/imparcial.rb +1 -1
- data/test/unit/base/common/tc_quote.rb +30 -0
- data/test/unit/base/expression/tc_column.rb +84 -0
- data/test/unit/base/expression/tc_constraint.rb +39 -0
- data/test/unit/base/expression/tc_delete.rb +51 -0
- data/test/unit/base/expression/tc_index.rb +43 -0
- data/test/unit/base/expression/tc_insert.rb +44 -0
- data/test/unit/base/expression/tc_select.rb +142 -0
- data/test/unit/base/expression/tc_sequence.rb +48 -0
- data/test/unit/base/expression/tc_table.rb +68 -0
- data/test/unit/base/expression/tc_table_diff.rb +41 -0
- data/test/unit/base/expression/tc_transaction.rb +46 -0
- data/test/unit/base/expression/tc_update.rb +29 -0
- data/test/unit/base/statement/tc_conditions.rb +84 -0
- data/test/unit/base/statement/tc_limit.rb +25 -0
- data/test/unit/base/statement/tc_order.rb +25 -0
- data/test/unit/helper.rb +64 -0
- data/test/unit/mysql/tc_sequence.rb +41 -0
- metadata +102 -10
@@ -0,0 +1,68 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
context 'Abstract Adapter Creating Table' do
|
4
|
+
|
5
|
+
specify 'should create a single table' do
|
6
|
+
|
7
|
+
assert_nothing_raised do
|
8
|
+
abstract_adapter.drop_all_tables
|
9
|
+
fields = []
|
10
|
+
fields << {:name => :id, :type => :integer}
|
11
|
+
fields << {:name => :name, :type => :string, :size => 50}
|
12
|
+
abstract_adapter.create_table :table_name => 'bla',:fields => fields
|
13
|
+
end
|
14
|
+
|
15
|
+
assert_equal 1, abstract_adapter.get_tables.length
|
16
|
+
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
20
|
+
|
21
|
+
context 'Abstract Adapter Dropping Table' do
|
22
|
+
|
23
|
+
specify 'should not raise when dropping a table by a specific command' do
|
24
|
+
|
25
|
+
assert_nothing_raised do
|
26
|
+
abstract_adapter.drop_table_if_necessary:table_name => 'bla'
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
specify 'should raise when dropping a non existent table' do
|
32
|
+
|
33
|
+
assert_raise Imparcial::TableDropError do
|
34
|
+
abstract_adapter.drop_table :table_name => 'bla'
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|
38
|
+
|
39
|
+
end
|
40
|
+
|
41
|
+
context 'Abstract Adapter Table Features' do
|
42
|
+
|
43
|
+
def setup
|
44
|
+
|
45
|
+
abstract_adapter.drop_all_tables
|
46
|
+
abstract_adapter.create_table :table_name => 'bla',:fields => [{:name => :id, :type => :integer}]
|
47
|
+
|
48
|
+
end
|
49
|
+
|
50
|
+
specify 'should retrieve tables' do
|
51
|
+
|
52
|
+
assert_equal 1, abstract_adapter.get_tables.length
|
53
|
+
assert_equal 'bla', abstract_adapter.get_tables[0]
|
54
|
+
abstract_adapter.drop_table :table_name => 'bla'
|
55
|
+
assert_equal 0, abstract_adapter.get_tables.length
|
56
|
+
|
57
|
+
end
|
58
|
+
|
59
|
+
specify 'should verify if table exists' do
|
60
|
+
|
61
|
+
assert_equal true, abstract_adapter.table_exists?(:table_name =>'bla')
|
62
|
+
assert_equal true, !abstract_adapter.table_not_exists?(:table_name =>'bla')
|
63
|
+
abstract_adapter.drop_table :table_name =>'bla'
|
64
|
+
assert_equal false, abstract_adapter.table_exists?(:table_name =>'bla')
|
65
|
+
|
66
|
+
end
|
67
|
+
|
68
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
context 'Abstract Adapter Table Features' do
|
4
|
+
|
5
|
+
def setup
|
6
|
+
|
7
|
+
abstract_adapter.drop_table_if_necessary :table_name => 'bla'
|
8
|
+
abstract_adapter.create_table :table_name => 'bla',:fields => [{:name => :id, :type => :integer}]
|
9
|
+
|
10
|
+
end
|
11
|
+
|
12
|
+
specify 'should report new columns' do
|
13
|
+
|
14
|
+
fields = []
|
15
|
+
fields << {:name => :id, :type => :integer}
|
16
|
+
fields << {:name => :name, :type => :string}
|
17
|
+
|
18
|
+
new = abstract_adapter.report_new_columns :table_name => 'bla', :fields => fields
|
19
|
+
|
20
|
+
assert_equal 1, new.length
|
21
|
+
assert_equal 'name', new[0][:name]
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
specify 'should report old columns' do
|
26
|
+
|
27
|
+
old = abstract_adapter.report_old_columns :table_name => 'bla', :fields =>[{:name => :name, :type => :string}]
|
28
|
+
assert_equal 1, old.length
|
29
|
+
assert_equal 'id', old[0][:name]
|
30
|
+
|
31
|
+
end
|
32
|
+
|
33
|
+
specify 'should report modified columns' do
|
34
|
+
|
35
|
+
modified = abstract_adapter.report_modified_columns :table_name => 'bla', :fields =>[{:name => :id, :type => :string}]
|
36
|
+
assert_equal 1, modified.length
|
37
|
+
assert_equal 'id', modified[0][:name]
|
38
|
+
|
39
|
+
end
|
40
|
+
|
41
|
+
end
|
@@ -0,0 +1,46 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
context 'Abstract Adapter' do
|
4
|
+
|
5
|
+
def setup
|
6
|
+
|
7
|
+
abstract_adapter.drop_all_tables
|
8
|
+
fields = []
|
9
|
+
fields << {:name => :id, :type => :integer}
|
10
|
+
fields << {:name => :name, :type => :string}
|
11
|
+
abstract_adapter.create_table :table_name => 'bla', :fields => fields
|
12
|
+
|
13
|
+
end
|
14
|
+
|
15
|
+
specify 'should make a transaction' do
|
16
|
+
|
17
|
+
abstract_adapter.initialize_transaction
|
18
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 1, :name => 'jota'}
|
19
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 2, :name => 'mauricio'}
|
20
|
+
abstract_adapter.terminate_transaction
|
21
|
+
|
22
|
+
assert_equal 2, abstract_adapter.total_of_records(:table_name =>'bla')
|
23
|
+
|
24
|
+
end
|
25
|
+
|
26
|
+
specify 'should savepoints' do
|
27
|
+
|
28
|
+
assert_equal 0, abstract_adapter.total_of_records(:table_name =>'bla')
|
29
|
+
|
30
|
+
abstract_adapter.initialize_transaction
|
31
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 1, :name => 'jota'}
|
32
|
+
abstract_adapter.create_savepoint :savepoint_name => 'here'
|
33
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 2, :name => 'mauricio'}
|
34
|
+
begin
|
35
|
+
abstract_adapter.query 'simulating an error'
|
36
|
+
rescue
|
37
|
+
abstract_adapter.restore_savepoint :savepoint_name => 'here'
|
38
|
+
ensure
|
39
|
+
abstract_adapter.terminate_transaction
|
40
|
+
end
|
41
|
+
|
42
|
+
assert_equal 1, abstract_adapter.total_of_records(:table_name =>'bla')
|
43
|
+
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
context 'Abstract Adapter' do
|
4
|
+
|
5
|
+
def setup
|
6
|
+
|
7
|
+
abstract_adapter.drop_all_tables
|
8
|
+
fields = []
|
9
|
+
fields << {:name => :id, :type => :integer}
|
10
|
+
fields << {:name => :name, :type => :string}
|
11
|
+
abstract_adapter.create_table :table_name => 'bla', :fields => fields
|
12
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 1, :name => 'jota'}
|
13
|
+
abstract_adapter.insert :table_name => 'bla', :values => {:id => 2, :name => 'mauricio'}
|
14
|
+
|
15
|
+
end
|
16
|
+
|
17
|
+
specify 'should update fields' do
|
18
|
+
|
19
|
+
assert_nothing_raised do
|
20
|
+
abstract_adapter.update :table_name => 'bla', :values => {:name => 'maria'}, :conditions => ['id = 1']
|
21
|
+
end
|
22
|
+
|
23
|
+
abstract_adapter.select :table_name => 'bla', :fields => [:name], :conditions => ['id = 1']
|
24
|
+
maria_row = abstract_adapter.result.fetch_first_row
|
25
|
+
assert_equal 'maria', maria_row.value
|
26
|
+
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
abstract_adapter.class.module_eval do
|
4
|
+
def conditions ( options )
|
5
|
+
parse_conditions options
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
context 'Conditions' do
|
10
|
+
|
11
|
+
def quote_value ( val )
|
12
|
+
abstract_adapter.quote_value(val)
|
13
|
+
end
|
14
|
+
def quote ( val )
|
15
|
+
abstract_adapter.quote(val)
|
16
|
+
end
|
17
|
+
|
18
|
+
specify 'should accept an ad-hoc statement' do
|
19
|
+
|
20
|
+
sql = abstract_adapter.conditions ['id = 1']
|
21
|
+
assert_equal " WHERE #{quote('id')} = 1", sql
|
22
|
+
|
23
|
+
sql = abstract_adapter.conditions ['id = 1 AND age = 22']
|
24
|
+
assert_equal " WHERE #{quote('id')} = 1 AND #{quote('age')} = 22", sql
|
25
|
+
|
26
|
+
sql = abstract_adapter.conditions ['id = 1 AND age = 22 OR id = 3']
|
27
|
+
assert_equal " WHERE #{quote('id')} = 1 AND #{quote('age')} = 22 OR #{quote('id')} = 3", sql
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
specify 'should accept not well formatted statements' do
|
32
|
+
|
33
|
+
sql = abstract_adapter.conditions ['id=?',1]
|
34
|
+
assert_equal " WHERE #{quote('id')} = 1", sql
|
35
|
+
|
36
|
+
sql = abstract_adapter.conditions ['id =?',1]
|
37
|
+
assert_equal " WHERE #{quote('id')} = 1", sql
|
38
|
+
|
39
|
+
sql = abstract_adapter.conditions ['id= ?',1]
|
40
|
+
assert_equal " WHERE #{quote('id')} = 1", sql
|
41
|
+
|
42
|
+
end
|
43
|
+
|
44
|
+
specify 'should accept array of values' do
|
45
|
+
|
46
|
+
sql = abstract_adapter.conditions ["id = ? AND name = 'juca'",[1,2]]
|
47
|
+
assert_equal " WHERE #{quote('id')} IN (1,2) AND #{quote('name')} = 'juca'", sql
|
48
|
+
|
49
|
+
sql = abstract_adapter.conditions ["id != ? AND name = 'juca'",[1,2]]
|
50
|
+
assert_equal " WHERE #{quote('id')} NOT IN (1,2) AND #{quote('name')} = 'juca'", sql
|
51
|
+
|
52
|
+
sql = abstract_adapter.conditions ["id != ? AND age = ?",[1,2],[21,22]]
|
53
|
+
assert_equal " WHERE #{quote('id')} NOT IN (1,2) AND #{quote('age')} IN (21,22)", sql
|
54
|
+
|
55
|
+
sql = abstract_adapter.conditions ["name != ?",['pedro','joao']]
|
56
|
+
assert_equal " WHERE #{quote('name')} NOT IN (#{quote_value('pedro')},#{quote_value('joao')})", sql
|
57
|
+
|
58
|
+
end
|
59
|
+
|
60
|
+
specify 'should accept a simple statement' do
|
61
|
+
|
62
|
+
sql = abstract_adapter.conditions ['id = ?',12]
|
63
|
+
assert_equal " WHERE #{quote('id')} = 12", sql
|
64
|
+
|
65
|
+
end
|
66
|
+
|
67
|
+
specify 'should accept an advanced simple statement' do
|
68
|
+
|
69
|
+
sql = abstract_adapter.conditions ['id = ? AND name = ?',1,'juca']
|
70
|
+
assert_equal " WHERE #{quote('id')} = 1 AND #{quote('name')} = #{quote_value('juca')}", sql
|
71
|
+
|
72
|
+
sql = abstract_adapter.conditions ['x = ? AND y = ? AND z = ?',1,2,3]
|
73
|
+
assert_equal " WHERE #{quote('x')} = 1 AND #{quote('y')} = 2 AND #{quote('z')} = 3", sql
|
74
|
+
|
75
|
+
end
|
76
|
+
|
77
|
+
specify 'should accept ad-hoc, simple and compost statement' do
|
78
|
+
|
79
|
+
sql = abstract_adapter.conditions ['x = 1 AND y = ? OR z = ?',5,[2,3]]
|
80
|
+
assert_equal " WHERE #{quote('x')} = 1 AND #{quote('y')} = 5 OR #{quote('z')} IN (2,3)", sql
|
81
|
+
|
82
|
+
end
|
83
|
+
|
84
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
abstract_adapter.class.module_eval do
|
4
|
+
def limit ( n )
|
5
|
+
parse_limit n
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
context 'Limt' do
|
10
|
+
|
11
|
+
specify 'should make a single one' do
|
12
|
+
|
13
|
+
sql = abstract_adapter.limit 1
|
14
|
+
assert_equal " LIMIT 1", sql
|
15
|
+
|
16
|
+
end
|
17
|
+
|
18
|
+
specify 'should make a complex one' do
|
19
|
+
|
20
|
+
sql = abstract_adapter.limit 1..3
|
21
|
+
assert_equal " LIMIT 1,3", sql
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../helper'
|
2
|
+
|
3
|
+
abstract_adapter.class.module_eval do
|
4
|
+
def order ( order )
|
5
|
+
parse_order order
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
context 'Order' do
|
10
|
+
|
11
|
+
specify 'should make desc' do
|
12
|
+
|
13
|
+
sql = abstract_adapter.order( {:order_desc => :id})
|
14
|
+
assert_equal " ORDER BY #{abstract_adapter.quote('id')} DESC", sql
|
15
|
+
|
16
|
+
end
|
17
|
+
|
18
|
+
specify 'should make asc' do
|
19
|
+
|
20
|
+
sql = abstract_adapter.order( {:order_asc => :id})
|
21
|
+
assert_equal " ORDER BY #{abstract_adapter.quote('id')} ASC", sql
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
data/test/unit/helper.rb
ADDED
@@ -0,0 +1,64 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
require 'test_tool_box'
|
3
|
+
include TestToolBox::UnitTestDSL
|
4
|
+
|
5
|
+
require 'imparcial'
|
6
|
+
|
7
|
+
def mysql_adapter
|
8
|
+
|
9
|
+
return @adapter if @adapter
|
10
|
+
|
11
|
+
@adapter = Imparcial::Initializer.adapter(:mysql) do |config|
|
12
|
+
|
13
|
+
config.username = 'guilherme'
|
14
|
+
config.password = '1a2s3d'
|
15
|
+
config.database = 'rdbal'
|
16
|
+
config.logger = Logger.new(STDERR)
|
17
|
+
|
18
|
+
end
|
19
|
+
|
20
|
+
@adapter.connect
|
21
|
+
@adapter
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
def postgre_adapter
|
26
|
+
|
27
|
+
return @adapter if @adapter
|
28
|
+
|
29
|
+
@adapter = Imparcial::Initializer.adapter(:postgre) do |config|
|
30
|
+
|
31
|
+
config.username = 'guilherme'
|
32
|
+
config.password = '1a2s3d'
|
33
|
+
config.database = 'rdbal'
|
34
|
+
config.host = '/var/run/postgresql2'
|
35
|
+
config.port = 5433
|
36
|
+
config.logger = Logger.new(STDERR)
|
37
|
+
|
38
|
+
end
|
39
|
+
|
40
|
+
@adapter.connect
|
41
|
+
@adapter
|
42
|
+
|
43
|
+
end
|
44
|
+
|
45
|
+
|
46
|
+
def abstract_adapter
|
47
|
+
|
48
|
+
case $ADAPTER
|
49
|
+
|
50
|
+
when 'mysql'
|
51
|
+
|
52
|
+
mysql_adapter
|
53
|
+
|
54
|
+
when 'postgre'
|
55
|
+
|
56
|
+
postgre_adapter
|
57
|
+
|
58
|
+
else
|
59
|
+
|
60
|
+
nil
|
61
|
+
|
62
|
+
end
|
63
|
+
|
64
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../helper'
|
2
|
+
|
3
|
+
context 'Mysql' do
|
4
|
+
|
5
|
+
specify 'should not support creating a sequence' do
|
6
|
+
|
7
|
+
assert_raise RDBAL::FeatureNotFound do
|
8
|
+
mysql_adapter.create_sequence :sequence_name => 'seq_id'
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
specify 'should not support dropping a sequence' do
|
14
|
+
|
15
|
+
assert_raise RDBAL::FeatureNotFound do
|
16
|
+
mysql_adapter.drop_sequence :sequence_name => 'seq_id'
|
17
|
+
end
|
18
|
+
|
19
|
+
assert_raise RDBAL::FeatureNotFound do
|
20
|
+
mysql_adapter.drop_sequence_if_necessary :sequence_name => 'seq_id'
|
21
|
+
end
|
22
|
+
|
23
|
+
end
|
24
|
+
|
25
|
+
specify 'should not support retrieve sequences' do
|
26
|
+
|
27
|
+
assert_raise RDBAL::FeatureNotFound do
|
28
|
+
mysql_adapter.retrieve_sequences
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
|
33
|
+
specify 'should not support finding sequences' do
|
34
|
+
|
35
|
+
assert_raise RDBAL::FeatureNotFound do
|
36
|
+
mysql_adapter.sequence_exists? :sequence_name => 'seq_id'
|
37
|
+
end
|
38
|
+
|
39
|
+
end
|
40
|
+
|
41
|
+
end
|
metadata
CHANGED
@@ -3,8 +3,8 @@ rubygems_version: 0.9.4.3
|
|
3
3
|
specification_version: 1
|
4
4
|
name: imparcial
|
5
5
|
version: !ruby/object:Gem::Version
|
6
|
-
version: 0.0.
|
7
|
-
date: 2007-09-
|
6
|
+
version: 0.0.5
|
7
|
+
date: 2007-09-18 00:00:00 -03:00
|
8
8
|
summary: A Powerful Database Abstraction Layer
|
9
9
|
require_paths:
|
10
10
|
- lib
|
@@ -29,20 +29,94 @@ post_install_message:
|
|
29
29
|
authors:
|
30
30
|
- Guilherme Antoniolo Ferreira
|
31
31
|
files:
|
32
|
-
-
|
33
|
-
-
|
34
|
-
-
|
35
|
-
-
|
36
|
-
-
|
32
|
+
- ./Manifest.txt
|
33
|
+
- ./Rakefile
|
34
|
+
- ./History.txt
|
35
|
+
- ./test/unit/base/expression/tc_select.rb
|
36
|
+
- ./test/unit/base/expression/tc_table_diff.rb
|
37
|
+
- ./test/unit/base/expression/tc_constraint.rb
|
38
|
+
- ./test/unit/base/expression/tc_transaction.rb
|
39
|
+
- ./test/unit/base/expression/tc_update.rb
|
40
|
+
- ./test/unit/base/expression/tc_sequence.rb
|
41
|
+
- ./test/unit/base/expression/tc_column.rb
|
42
|
+
- ./test/unit/base/expression/tc_index.rb
|
43
|
+
- ./test/unit/base/expression/tc_insert.rb
|
44
|
+
- ./test/unit/base/expression/tc_table.rb
|
45
|
+
- ./test/unit/base/expression/tc_delete.rb
|
46
|
+
- ./test/unit/base/common/tc_quote.rb
|
47
|
+
- ./test/unit/base/statement/tc_limit.rb
|
48
|
+
- ./test/unit/base/statement/tc_conditions.rb
|
49
|
+
- ./test/unit/base/statement/tc_order.rb
|
50
|
+
- ./test/unit/helper.rb
|
51
|
+
- ./test/unit/mysql/tc_sequence.rb
|
52
|
+
- ./lib/imparcial/extension.rb
|
53
|
+
- ./lib/imparcial/driver/abstract/expression/select.rb
|
54
|
+
- ./lib/imparcial/driver/abstract/expression/record.rb
|
55
|
+
- ./lib/imparcial/driver/abstract/expression/table.rb
|
56
|
+
- ./lib/imparcial/driver/abstract/expression/transaction.rb
|
57
|
+
- ./lib/imparcial/driver/abstract/expression/constraint.rb
|
58
|
+
- ./lib/imparcial/driver/abstract/expression/delete.rb
|
59
|
+
- ./lib/imparcial/driver/abstract/expression/sequence.rb
|
60
|
+
- ./lib/imparcial/driver/abstract/expression/insert.rb
|
61
|
+
- ./lib/imparcial/driver/abstract/expression/index.rb
|
62
|
+
- ./lib/imparcial/driver/abstract/expression/column.rb
|
63
|
+
- ./lib/imparcial/driver/abstract/expression/lock.rb
|
64
|
+
- ./lib/imparcial/driver/abstract/expression/statement.rb
|
65
|
+
- ./lib/imparcial/driver/abstract/expression/update.rb
|
66
|
+
- ./lib/imparcial/driver/abstract/result.rb
|
67
|
+
- ./lib/imparcial/driver/abstract/typemap.rb
|
68
|
+
- ./lib/imparcial/driver/abstract/expression.rb
|
69
|
+
- ./lib/imparcial/driver/abstract/util.rb
|
70
|
+
- ./lib/imparcial/driver/abstract/sql/select.rb
|
71
|
+
- ./lib/imparcial/driver/abstract/sql/record.rb
|
72
|
+
- ./lib/imparcial/driver/abstract/sql/table.rb
|
73
|
+
- ./lib/imparcial/driver/abstract/sql/transaction.rb
|
74
|
+
- ./lib/imparcial/driver/abstract/sql/constraint.rb
|
75
|
+
- ./lib/imparcial/driver/abstract/sql/delete.rb
|
76
|
+
- ./lib/imparcial/driver/abstract/sql/sequence.rb
|
77
|
+
- ./lib/imparcial/driver/abstract/sql/insert.rb
|
78
|
+
- ./lib/imparcial/driver/abstract/sql/index.rb
|
79
|
+
- ./lib/imparcial/driver/abstract/sql/column.rb
|
80
|
+
- ./lib/imparcial/driver/abstract/sql/update.rb
|
81
|
+
- ./lib/imparcial/driver/abstract/sql.rb
|
82
|
+
- ./lib/imparcial/driver/abstract.rb
|
83
|
+
- ./lib/imparcial/driver/postgre.rb
|
84
|
+
- ./lib/imparcial/driver/mysql.rb
|
85
|
+
- ./lib/imparcial/driver/mysql/expression/table.rb
|
86
|
+
- ./lib/imparcial/driver/mysql/result.rb
|
87
|
+
- ./lib/imparcial/driver/mysql/typemap.rb
|
88
|
+
- ./lib/imparcial/driver/mysql/expression.rb
|
89
|
+
- ./lib/imparcial/driver/mysql/util.rb
|
90
|
+
- ./lib/imparcial/driver/mysql/sql/table.rb
|
91
|
+
- ./lib/imparcial/driver/mysql/sql/constraint.rb
|
92
|
+
- ./lib/imparcial/driver/mysql/sql/sequence.rb
|
93
|
+
- ./lib/imparcial/driver/mysql/sql/index.rb
|
94
|
+
- ./lib/imparcial/driver/mysql/sql/column.rb
|
95
|
+
- ./lib/imparcial/driver/mysql/sql.rb
|
96
|
+
- ./lib/imparcial/driver/postgre/result.rb
|
97
|
+
- ./lib/imparcial/driver/postgre/typemap.rb
|
98
|
+
- ./lib/imparcial/driver/postgre/expression.rb
|
99
|
+
- ./lib/imparcial/driver/postgre/util.rb
|
100
|
+
- ./lib/imparcial/driver/postgre/sql/table.rb
|
101
|
+
- ./lib/imparcial/driver/postgre/sql/constraint.rb
|
102
|
+
- ./lib/imparcial/driver/postgre/sql/sequence.rb
|
103
|
+
- ./lib/imparcial/driver/postgre/sql/index.rb
|
104
|
+
- ./lib/imparcial/driver/postgre/sql/column.rb
|
105
|
+
- ./lib/imparcial/driver/postgre/sql.rb
|
106
|
+
- ./lib/imparcial/driver.rb
|
107
|
+
- ./lib/imparcial/initializer.rb
|
108
|
+
- ./lib/imparcial/exception.rb
|
109
|
+
- ./lib/imparcial.rb
|
110
|
+
- ./README.txt
|
37
111
|
test_files: []
|
38
112
|
|
39
113
|
rdoc_options:
|
40
114
|
- --main
|
41
115
|
- README.txt
|
42
116
|
extra_rdoc_files:
|
43
|
-
-
|
44
|
-
-
|
45
|
-
- README.txt
|
117
|
+
- ./Manifest.txt
|
118
|
+
- ./History.txt
|
119
|
+
- ./README.txt
|
46
120
|
executables: []
|
47
121
|
|
48
122
|
extensions: []
|
@@ -59,6 +133,24 @@ dependencies:
|
|
59
133
|
- !ruby/object:Gem::Version
|
60
134
|
version: 0.0.0
|
61
135
|
version:
|
136
|
+
- !ruby/object:Gem::Dependency
|
137
|
+
name: rake
|
138
|
+
version_requirement:
|
139
|
+
version_requirements: !ruby/object:Gem::Version::Requirement
|
140
|
+
requirements:
|
141
|
+
- - ">"
|
142
|
+
- !ruby/object:Gem::Version
|
143
|
+
version: 0.0.0
|
144
|
+
version:
|
145
|
+
- !ruby/object:Gem::Dependency
|
146
|
+
name: hoe
|
147
|
+
version_requirement:
|
148
|
+
version_requirements: !ruby/object:Gem::Version::Requirement
|
149
|
+
requirements:
|
150
|
+
- - ">"
|
151
|
+
- !ruby/object:Gem::Version
|
152
|
+
version: 0.0.0
|
153
|
+
version:
|
62
154
|
- !ruby/object:Gem::Dependency
|
63
155
|
name: hoe
|
64
156
|
version_requirement:
|