composite_primary_keys 13.0.2 → 13.0.4
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.
- checksums.yaml +4 -4
- data/History.rdoc +8 -0
- data/lib/composite_primary_keys/associations/collection_association.rb +31 -31
- data/lib/composite_primary_keys/associations/join_association.rb +137 -137
- data/lib/composite_primary_keys/associations/through_association.rb +24 -25
- data/lib/composite_primary_keys/autosave_association.rb +60 -60
- data/lib/composite_primary_keys/base.rb +137 -141
- data/lib/composite_primary_keys/composite_arrays.rb +86 -86
- data/lib/composite_primary_keys/persistence.rb +1 -0
- data/lib/composite_primary_keys/validations/uniqueness.rb +31 -31
- data/lib/composite_primary_keys/version.rb +1 -1
- data/test/fixtures/room_assignment.rb +13 -13
- data/test/test_composite_arrays.rb +38 -38
- data/test/test_create.rb +219 -218
- metadata +3 -3
data/test/test_create.rb
CHANGED
@@ -1,218 +1,219 @@
|
|
1
|
-
require File.expand_path('../abstract_unit', __FILE__)
|
2
|
-
|
3
|
-
class TestCreate < ActiveSupport::TestCase
|
4
|
-
fixtures :articles, :students, :dorms, :rooms, :room_assignments, :reference_types, :reference_codes, :streets, :suburbs
|
5
|
-
|
6
|
-
CLASSES = {
|
7
|
-
:single => {
|
8
|
-
:class => ReferenceType,
|
9
|
-
:primary_keys => :reference_type_id,
|
10
|
-
:create => {:reference_type_id => 10, :type_label => 'NEW_TYPE', :abbreviation => 'New Type'}
|
11
|
-
},
|
12
|
-
:dual => {
|
13
|
-
:class => ReferenceCode,
|
14
|
-
:primary_keys => [:reference_type_id, :reference_code],
|
15
|
-
:create => {:reference_type_id => 1, :reference_code => 20, :code_label => 'NEW_CODE', :abbreviation => 'New Code'}
|
16
|
-
}
|
17
|
-
}
|
18
|
-
|
19
|
-
def setup
|
20
|
-
self.class.classes = CLASSES
|
21
|
-
end
|
22
|
-
|
23
|
-
def test_setup
|
24
|
-
testing_with do
|
25
|
-
assert_not_nil @klass_info[:create]
|
26
|
-
end
|
27
|
-
end
|
28
|
-
|
29
|
-
def test_create
|
30
|
-
testing_with do
|
31
|
-
assert new_obj = @klass.create(@klass_info[:create])
|
32
|
-
assert !new_obj.new_record?
|
33
|
-
assert new_obj.id
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
@
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
assert_equal(date, tariff.
|
57
|
-
assert_equal(
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
assert_equal(2, department.
|
80
|
-
assert_equal(
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
assert_equal(2, department.
|
85
|
-
assert_equal(
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
suburb
|
91
|
-
|
92
|
-
|
93
|
-
assert_equal(suburb.
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
rt
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
:
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
:
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
assert_equal(
|
117
|
-
assert_equal(
|
118
|
-
assert_equal(
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
assert_equal(
|
124
|
-
assert_equal(
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
:
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
:
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
assert_equal(
|
139
|
-
assert_equal(
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
assert_equal(
|
147
|
-
assert_equal(
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
room.
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
assignment1.
|
161
|
-
|
162
|
-
|
163
|
-
room.
|
164
|
-
|
165
|
-
|
166
|
-
assert_equal(
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
room.
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
assignment1.
|
181
|
-
|
182
|
-
|
183
|
-
assignment2.
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
assert_equal(
|
191
|
-
assert_equal(
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
refute_nil(suburb
|
215
|
-
refute_nil(suburb.
|
216
|
-
|
217
|
-
|
218
|
-
end
|
1
|
+
require File.expand_path('../abstract_unit', __FILE__)
|
2
|
+
|
3
|
+
class TestCreate < ActiveSupport::TestCase
|
4
|
+
fixtures :articles, :students, :dorms, :rooms, :room_assignments, :reference_types, :reference_codes, :streets, :suburbs
|
5
|
+
|
6
|
+
CLASSES = {
|
7
|
+
:single => {
|
8
|
+
:class => ReferenceType,
|
9
|
+
:primary_keys => :reference_type_id,
|
10
|
+
:create => {:reference_type_id => 10, :type_label => 'NEW_TYPE', :abbreviation => 'New Type'}
|
11
|
+
},
|
12
|
+
:dual => {
|
13
|
+
:class => ReferenceCode,
|
14
|
+
:primary_keys => [:reference_type_id, :reference_code],
|
15
|
+
:create => {:reference_type_id => 1, :reference_code => 20, :code_label => 'NEW_CODE', :abbreviation => 'New Code'}
|
16
|
+
}
|
17
|
+
}
|
18
|
+
|
19
|
+
def setup
|
20
|
+
self.class.classes = CLASSES
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_setup
|
24
|
+
testing_with do
|
25
|
+
assert_not_nil @klass_info[:create]
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def test_create
|
30
|
+
testing_with do
|
31
|
+
assert new_obj = @klass.create(@klass_info[:create])
|
32
|
+
assert !new_obj.new_record?
|
33
|
+
assert new_obj.id
|
34
|
+
assert new_obj.previously_new_record?
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
def test_create_no_id
|
39
|
+
testing_with do
|
40
|
+
begin
|
41
|
+
@obj = @klass.create(@klass_info[:create].except(@klass.primary_key))
|
42
|
+
@successful = !composite?
|
43
|
+
rescue ActiveRecord::CompositeKeyError
|
44
|
+
@successful = false
|
45
|
+
rescue
|
46
|
+
flunk "Incorrect exception raised: #{$!}, #{$!.class}"
|
47
|
+
end
|
48
|
+
assert_equal composite?, !@successful, "Create should have failed for composites; #{@obj.inspect}"
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_create_with_array
|
53
|
+
date = Date.new(2027, 01, 27)
|
54
|
+
tariff = Tariff.create!(id: [10, date], amount: 27)
|
55
|
+
refute_nil(tariff)
|
56
|
+
assert_equal([10, date], tariff.id)
|
57
|
+
assert_equal(date, tariff.start_date)
|
58
|
+
assert_equal(27, tariff.amount)
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_create_with_partial_serial
|
62
|
+
attributes = {:location_id => 100}
|
63
|
+
|
64
|
+
# SQLite does not support an autoincrementing field in a composite key
|
65
|
+
if Department.connection.class.name == "ActiveRecord::ConnectionAdapters::SQLite3Adapter"
|
66
|
+
attributes[:id] = 200
|
67
|
+
end
|
68
|
+
|
69
|
+
department = Department.new(attributes)
|
70
|
+
assert_nil(department.attributes[:id])
|
71
|
+
|
72
|
+
department.save!
|
73
|
+
refute_nil(department.attributes["id"])
|
74
|
+
assert_equal(100, department.location_id)
|
75
|
+
end
|
76
|
+
|
77
|
+
def test_create_with_id
|
78
|
+
department = Department.create!(id: [2, 3])
|
79
|
+
assert_equal([2, 3], department.id)
|
80
|
+
assert_equal(2, department.attributes["id"])
|
81
|
+
assert_equal(3, department.attributes["location_id"])
|
82
|
+
|
83
|
+
department.reload
|
84
|
+
assert_equal([2, 3], department.id)
|
85
|
+
assert_equal(2, department.attributes["id"])
|
86
|
+
assert_equal(3, department.attributes["location_id"])
|
87
|
+
end
|
88
|
+
|
89
|
+
def test_create_on_association
|
90
|
+
suburb = Suburb.first
|
91
|
+
suburb.streets.create(:name => "my street")
|
92
|
+
street = Street.find_by_name('my street')
|
93
|
+
assert_equal(suburb.city_id, street.city_id)
|
94
|
+
assert_equal(suburb.suburb_id, street.suburb_id)
|
95
|
+
end
|
96
|
+
|
97
|
+
def test_create_on_association_when_belongs_to_is_single_key
|
98
|
+
rt = ReferenceType.first
|
99
|
+
rt.reference_codes.create(:reference_code => 4321, :code_label => 'foo', :abbreviation => 'bar')
|
100
|
+
rc = ReferenceCode.find_by_reference_code(4321)
|
101
|
+
assert_equal(rc.reference_type_id, rt.reference_type_id)
|
102
|
+
end
|
103
|
+
|
104
|
+
def test_new_habtm
|
105
|
+
restaurant = Restaurant.new(:franchise_id => 101,
|
106
|
+
:store_id => 201,
|
107
|
+
:name => "My Store")
|
108
|
+
|
109
|
+
restaurant.suburbs << Suburb.new(:city_id => 24,
|
110
|
+
:suburb_id => 25,
|
111
|
+
:name => "My Suburb")
|
112
|
+
|
113
|
+
restaurant.save!
|
114
|
+
|
115
|
+
# Test restaurant
|
116
|
+
assert_equal(101, restaurant.franchise_id)
|
117
|
+
assert_equal(201, restaurant.store_id)
|
118
|
+
assert_equal("My Store", restaurant.name)
|
119
|
+
assert_equal(1, restaurant.suburbs.length)
|
120
|
+
|
121
|
+
# Test suburbs
|
122
|
+
suburb = restaurant.suburbs[0]
|
123
|
+
assert_equal(24, suburb.city_id)
|
124
|
+
assert_equal(25, suburb.suburb_id)
|
125
|
+
assert_equal("My Suburb", suburb.name)
|
126
|
+
end
|
127
|
+
|
128
|
+
def test_create_habtm
|
129
|
+
restaurant = Restaurant.create(:franchise_id => 100,
|
130
|
+
:store_id => 200,
|
131
|
+
:name => "My Store")
|
132
|
+
|
133
|
+
restaurant.suburbs.create(:city_id => 24,
|
134
|
+
:suburb_id => 25,
|
135
|
+
:name => "My Suburb")
|
136
|
+
|
137
|
+
# Test restaurant
|
138
|
+
assert_equal(100, restaurant.franchise_id)
|
139
|
+
assert_equal(200, restaurant.store_id)
|
140
|
+
assert_equal("My Store", restaurant.name)
|
141
|
+
|
142
|
+
assert_equal(1, restaurant.suburbs.reload.length)
|
143
|
+
|
144
|
+
# Test suburbs
|
145
|
+
suburb = restaurant.suburbs[0]
|
146
|
+
assert_equal(24, suburb.city_id)
|
147
|
+
assert_equal(25, suburb.suburb_id)
|
148
|
+
assert_equal("My Suburb", suburb.name)
|
149
|
+
end
|
150
|
+
|
151
|
+
def test_has_many_ids_1
|
152
|
+
dorm = dorms(:toyon)
|
153
|
+
room = Room.new(:dorm_id => dorm.id, :room_id => 5)
|
154
|
+
room.save!
|
155
|
+
|
156
|
+
student1 = students(:kelly)
|
157
|
+
|
158
|
+
RoomAssignment.delete_all
|
159
|
+
|
160
|
+
assignment1 = RoomAssignment.new(:student_id => student1.id, :dorm_id => room.dorm_id, :room_id => room.room_id)
|
161
|
+
assignment1.save!
|
162
|
+
|
163
|
+
room.room_assignment_ids = [[assignment1.student_id, assignment1.dorm_id, assignment1.room_id]]
|
164
|
+
room.save!
|
165
|
+
|
166
|
+
assert_equal(1, room.room_assignments.length)
|
167
|
+
assert_equal(assignment1, room.room_assignments.first)
|
168
|
+
end
|
169
|
+
|
170
|
+
def test_has_many_ids_2
|
171
|
+
dorm = dorms(:toyon)
|
172
|
+
room = Room.new(:dorm_id => dorm.id, :room_id => 5)
|
173
|
+
room.save!
|
174
|
+
|
175
|
+
student1 = students(:kelly)
|
176
|
+
student2 = students(:jordan)
|
177
|
+
|
178
|
+
RoomAssignment.delete_all
|
179
|
+
|
180
|
+
assignment1 = RoomAssignment.new(:student_id => student1.id, :dorm_id => room.dorm_id, :room_id => room.room_id)
|
181
|
+
assignment1.save!
|
182
|
+
|
183
|
+
assignment2 = RoomAssignment.new(:student_id => student2.id, :dorm_id => room.dorm_id, :room_id => room.room_id)
|
184
|
+
assignment2.save!
|
185
|
+
|
186
|
+
room.room_assignment_ids = [[assignment1.student_id, assignment1.dorm_id, assignment1.room_id],
|
187
|
+
[assignment2.student_id, assignment2.dorm_id, assignment2.room_id]]
|
188
|
+
room.save!
|
189
|
+
|
190
|
+
assert_equal(2, room.room_assignments.length)
|
191
|
+
assert_equal(assignment1, room.room_assignments[0])
|
192
|
+
assert_equal(assignment2, room.room_assignments[1])
|
193
|
+
end
|
194
|
+
|
195
|
+
def test_find_or_create_by
|
196
|
+
suburb = Suburb.find_by(:city_id => 3, :suburb_id => 1)
|
197
|
+
assert_nil(suburb)
|
198
|
+
|
199
|
+
suburb = Suburb.find_or_create_by!(:name => 'New Suburb', :city_id => 3, :suburb_id => 1)
|
200
|
+
refute_nil(suburb)
|
201
|
+
end
|
202
|
+
|
203
|
+
def test_cache
|
204
|
+
Suburb.cache do
|
205
|
+
# Suburb does not exist
|
206
|
+
suburb = Suburb.find_by(:city_id => 10, :suburb_id => 10)
|
207
|
+
assert_nil(suburb)
|
208
|
+
|
209
|
+
# Create it
|
210
|
+
suburb = Suburb.create!(:name => 'New Suburb', :city_id => 10, :suburb_id => 10)
|
211
|
+
|
212
|
+
# Should be able to find it
|
213
|
+
suburb = Suburb.find_by(:city_id => 10)
|
214
|
+
refute_nil(suburb)
|
215
|
+
refute_nil(suburb.city_id)
|
216
|
+
refute_nil(suburb.suburb_id)
|
217
|
+
end
|
218
|
+
end
|
219
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: composite_primary_keys
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 13.0.
|
4
|
+
version: 13.0.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Charlie Savage
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
11
|
+
date: 2022-12-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -216,7 +216,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
216
216
|
- !ruby/object:Gem::Version
|
217
217
|
version: '0'
|
218
218
|
requirements: []
|
219
|
-
rubygems_version: 3.3.
|
219
|
+
rubygems_version: 3.3.14
|
220
220
|
signing_key:
|
221
221
|
specification_version: 4
|
222
222
|
summary: Composite key support for ActiveRecord
|