composite_primary_keys 3.1.5 → 3.1.6
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +8 -1
- data/lib/composite_primary_keys.rb +1 -0
- data/lib/composite_primary_keys/associations/association_proxy.rb +3 -2
- data/lib/composite_primary_keys/validations/uniqueness.rb +1 -1
- data/lib/composite_primary_keys/version.rb +1 -1
- data/lib/composite_primary_keys/write.rb +18 -0
- data/test/fixtures/db_definitions/db2-create-tables.sql +7 -0
- data/test/fixtures/db_definitions/db2-drop-tables.sql +1 -0
- data/test/fixtures/db_definitions/mysql.sql +7 -0
- data/test/fixtures/db_definitions/oracle.drop.sql +1 -0
- data/test/fixtures/db_definitions/oracle.sql +6 -0
- data/test/fixtures/db_definitions/postgresql.sql +7 -0
- data/test/fixtures/db_definitions/sqlite.sql +7 -0
- data/test/fixtures/seats.yml +5 -0
- data/test/fixtures/way_node.rb +3 -0
- data/test/test_ids.rb +26 -10
- data/test/test_validations.rb +6 -3
- metadata +6 -4
data/History.txt
CHANGED
@@ -1,7 +1,14 @@
|
|
1
|
+
== 3.1.6 2011-04-03
|
2
|
+
* Updated belongs_to association to be a bit more flexible with non-CPK
|
3
|
+
base models (Jacques Fuentes)
|
4
|
+
* Fix uniqueness check (David Rueck)
|
5
|
+
* Fix write issue when one of they keys in a composite key is
|
6
|
+
called id (Tom Hughes)
|
7
|
+
|
1
8
|
== 3.1.5 2011-03-24
|
2
9
|
* Fix simple calculation methods
|
3
10
|
* Fix instantiation of cpk records via associations.
|
4
|
-
* Fix Relation#
|
11
|
+
* Fix Relation#delete
|
5
12
|
* Fix Relation#destroy
|
6
13
|
|
7
14
|
== 3.1.4 2011-03-06
|
@@ -62,6 +62,7 @@ require 'composite_primary_keys/persistence'
|
|
62
62
|
require 'composite_primary_keys/reflection'
|
63
63
|
require 'composite_primary_keys/relation'
|
64
64
|
require 'composite_primary_keys/read'
|
65
|
+
require 'composite_primary_keys/write'
|
65
66
|
require 'composite_primary_keys/finder_methods'
|
66
67
|
require 'composite_primary_keys/base'
|
67
68
|
require 'composite_primary_keys/calculations'
|
@@ -18,10 +18,11 @@ module ActiveRecord
|
|
18
18
|
record["#{@reflection.options[:as]}_type"] = @owner.class.base_class.name.to_s
|
19
19
|
else
|
20
20
|
unless @owner.new_record?
|
21
|
-
|
21
|
+
primary_keys = Array(@reflection.options[:primary_key] || :id)
|
22
22
|
# CPK
|
23
23
|
# record[@reflection.primary_key_name] = @owner.send(primary_key)
|
24
|
-
|
24
|
+
# Need to flatten because a key may be :id giving a composite key
|
25
|
+
values = primary_keys.map {|key| @owner.send(key)}.flatten
|
25
26
|
key_values = @reflection.cpk_primary_key.zip(values)
|
26
27
|
key_values.each {|key, value| record[key] = value}
|
27
28
|
end
|
@@ -26,7 +26,7 @@ module ActiveRecord
|
|
26
26
|
predicate = nil
|
27
27
|
record.ids_hash.each do |key, value|
|
28
28
|
neq = relation.table[key].not_eq(value)
|
29
|
-
predicate = predicate ? predicate.
|
29
|
+
predicate = predicate ? predicate.or(neq) : neq
|
30
30
|
end
|
31
31
|
relation = relation.where(predicate)
|
32
32
|
else
|
@@ -0,0 +1,18 @@
|
|
1
|
+
module ActiveRecord
|
2
|
+
module AttributeMethods
|
3
|
+
module Write
|
4
|
+
def write_attribute(attr_name, value)
|
5
|
+
attr_name = attr_name.to_s
|
6
|
+
# CPK
|
7
|
+
# attr_name = self.class.primary_key if attr_name == 'id'
|
8
|
+
attr_name = self.class.primary_key if (attr_name == 'id' and !self.composite?)
|
9
|
+
@attributes_cache.delete(attr_name)
|
10
|
+
if (column = column_for_attribute(attr_name)) && column.number?
|
11
|
+
@attributes[attr_name] = convert_number_column_value(value)
|
12
|
+
else
|
13
|
+
@attributes[attr_name] = value
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -111,3 +111,10 @@ create table restaurants_suburbs (
|
|
111
111
|
city_id integer not null,
|
112
112
|
suburb_id integer not null
|
113
113
|
);
|
114
|
+
|
115
|
+
create table way_nodes (
|
116
|
+
id integer not null,
|
117
|
+
node_id integer not null,
|
118
|
+
sequence_id integer not null,
|
119
|
+
primary key (id, sequence_id)
|
120
|
+
);
|
@@ -184,3 +184,10 @@ create table capitols (
|
|
184
184
|
city varchar(100) default null,
|
185
185
|
primary key (country, city)
|
186
186
|
) type=InnoDB;
|
187
|
+
|
188
|
+
create table way_nodes (
|
189
|
+
id int(11) not null,
|
190
|
+
node_id int(11) not null,
|
191
|
+
sequence_id int(11) not null,
|
192
|
+
primary key (id, sequence_id)
|
193
|
+
) type=InnoDB;
|
@@ -186,3 +186,9 @@ create table room_assignments (
|
|
186
186
|
room_id number(11) not null
|
187
187
|
);
|
188
188
|
|
189
|
+
create table way_nodes (
|
190
|
+
id number(11) not null,
|
191
|
+
node_id number(11) not null,
|
192
|
+
sequence_id number(11) not null,
|
193
|
+
constraint way_nodes_pk primary key (id, sequence_id)
|
194
|
+
);
|
data/test/fixtures/seats.yml
CHANGED
data/test/test_ids.rb
CHANGED
@@ -8,27 +8,27 @@ class TestIds < ActiveSupport::TestCase
|
|
8
8
|
:class => ReferenceType,
|
9
9
|
:primary_keys => [:reference_type_id],
|
10
10
|
},
|
11
|
-
:dual => {
|
11
|
+
:dual => {
|
12
12
|
:class => ReferenceCode,
|
13
13
|
:primary_keys => [:reference_type_id, :reference_code],
|
14
14
|
},
|
15
|
-
:dual_strs => {
|
15
|
+
:dual_strs => {
|
16
16
|
:class => ReferenceCode,
|
17
17
|
:primary_keys => ['reference_type_id', 'reference_code'],
|
18
18
|
},
|
19
19
|
}
|
20
|
-
|
20
|
+
|
21
21
|
def setup
|
22
22
|
self.class.classes = CLASSES
|
23
23
|
end
|
24
|
-
|
24
|
+
|
25
25
|
def test_id
|
26
26
|
testing_with do
|
27
27
|
assert_equal @first.id, @first.ids if composite?
|
28
28
|
assert_kind_of(CompositePrimaryKeys::CompositeKeys, @first.id) if composite?
|
29
29
|
end
|
30
30
|
end
|
31
|
-
|
31
|
+
|
32
32
|
def test_ids_to_s
|
33
33
|
testing_with do
|
34
34
|
order = @klass.primary_key.is_a?(String) ? @klass.primary_key : @klass.primary_key.join(',')
|
@@ -37,7 +37,7 @@ class TestIds < ActiveSupport::TestCase
|
|
37
37
|
assert_equal '1,1;1,2', @klass.ids_to_s(to_test, ',', ';', '', '') if @key_test == :dual
|
38
38
|
end
|
39
39
|
end
|
40
|
-
|
40
|
+
|
41
41
|
def test_set_ids_string
|
42
42
|
testing_with do
|
43
43
|
array = @primary_keys.collect {|key| 5}
|
@@ -46,7 +46,7 @@ class TestIds < ActiveSupport::TestCase
|
|
46
46
|
assert_equal expected, @first.id
|
47
47
|
end
|
48
48
|
end
|
49
|
-
|
49
|
+
|
50
50
|
def test_set_ids_array
|
51
51
|
testing_with do
|
52
52
|
array = @primary_keys.collect {|key| 5}
|
@@ -55,7 +55,7 @@ class TestIds < ActiveSupport::TestCase
|
|
55
55
|
assert_equal expected, @first.id
|
56
56
|
end
|
57
57
|
end
|
58
|
-
|
58
|
+
|
59
59
|
def test_set_ids_comp
|
60
60
|
testing_with do
|
61
61
|
array = @primary_keys.collect {|key| 5}
|
@@ -64,7 +64,7 @@ class TestIds < ActiveSupport::TestCase
|
|
64
64
|
assert_equal expected, @first.id
|
65
65
|
end
|
66
66
|
end
|
67
|
-
|
67
|
+
|
68
68
|
def test_primary_keys
|
69
69
|
testing_with do
|
70
70
|
if composite?
|
@@ -79,4 +79,20 @@ class TestIds < ActiveSupport::TestCase
|
|
79
79
|
end
|
80
80
|
end
|
81
81
|
end
|
82
|
-
|
82
|
+
|
83
|
+
def test_assign_ids
|
84
|
+
ref_code = ReferenceCode.new
|
85
|
+
assert_equal([nil, nil], ref_code.id)
|
86
|
+
|
87
|
+
ref_code.id = [2,1]
|
88
|
+
assert_equal([2,1], ref_code.id)
|
89
|
+
end
|
90
|
+
|
91
|
+
def test_id_as_component
|
92
|
+
way_node = WayNode.new
|
93
|
+
assert_equal([nil, nil], way_node.id)
|
94
|
+
|
95
|
+
way_node.id = [2,1]
|
96
|
+
assert_equal([2,1], way_node.id)
|
97
|
+
end
|
98
|
+
end
|
data/test/test_validations.rb
CHANGED
@@ -3,8 +3,11 @@ require 'abstract_unit'
|
|
3
3
|
class TestValidations < ActiveSupport::TestCase
|
4
4
|
fixtures :seats
|
5
5
|
|
6
|
-
def
|
7
|
-
|
8
|
-
assert
|
6
|
+
def test_uniqueness_validation_persisted
|
7
|
+
seat = Seat.find([1,1])
|
8
|
+
assert(seat.valid?)
|
9
|
+
|
10
|
+
seat.customer = 2
|
11
|
+
assert(!seat.valid?)
|
9
12
|
end
|
10
13
|
end
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: composite_primary_keys
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 15
|
5
5
|
prerelease:
|
6
6
|
segments:
|
7
7
|
- 3
|
8
8
|
- 1
|
9
|
-
-
|
10
|
-
version: 3.1.
|
9
|
+
- 6
|
10
|
+
version: 3.1.6
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Dr Nic Williams
|
@@ -16,7 +16,7 @@ autorequire:
|
|
16
16
|
bindir: bin
|
17
17
|
cert_chain: []
|
18
18
|
|
19
|
-
date: 2011-03
|
19
|
+
date: 2011-04-03 00:00:00 -06:00
|
20
20
|
default_executable:
|
21
21
|
dependencies:
|
22
22
|
- !ruby/object:Gem::Dependency
|
@@ -94,6 +94,7 @@ files:
|
|
94
94
|
- lib/composite_primary_keys/relation.rb
|
95
95
|
- lib/composite_primary_keys/validations/uniqueness.rb
|
96
96
|
- lib/composite_primary_keys/version.rb
|
97
|
+
- lib/composite_primary_keys/write.rb
|
97
98
|
- lib/composite_primary_keys.rb
|
98
99
|
- scripts/console.rb
|
99
100
|
- scripts/txt2html
|
@@ -179,6 +180,7 @@ files:
|
|
179
180
|
- test/fixtures/tariffs.yml
|
180
181
|
- test/fixtures/user.rb
|
181
182
|
- test/fixtures/users.yml
|
183
|
+
- test/fixtures/way_node.rb
|
182
184
|
- test/hash_tricks.rb
|
183
185
|
- test/plugins/pagination.rb
|
184
186
|
- test/plugins/pagination_helper.rb
|