deltacloud-core 1.0.2 → 1.0.3
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +2 -1
- data/bin/deltacloudd +11 -5
- data/config.ru +3 -3
- data/deltacloud-core.gemspec +24 -18
- data/lib/cimi/collections/address_templates.rb +3 -3
- data/lib/cimi/collections/addresses.rb +6 -5
- data/lib/cimi/collections/entity_metadata.rb +0 -2
- data/lib/cimi/collections/machine_admins.rb +5 -5
- data/lib/cimi/collections/machine_configurations.rb +2 -2
- data/lib/cimi/collections/machine_images.rb +3 -3
- data/lib/cimi/collections/machines.rb +32 -10
- data/lib/cimi/collections/network_configurations.rb +4 -3
- data/lib/cimi/collections/network_templates.rb +4 -3
- data/lib/cimi/collections/networks.rb +8 -8
- data/lib/cimi/collections/routing_group_templates.rb +4 -3
- data/lib/cimi/collections/routing_groups.rb +4 -3
- data/lib/cimi/collections/volume_configurations.rb +3 -3
- data/lib/cimi/collections/volume_images.rb +3 -3
- data/lib/cimi/collections/volumes.rb +4 -3
- data/lib/cimi/collections/vsp_configurations.rb +4 -3
- data/lib/cimi/collections/vsp_templates.rb +4 -3
- data/lib/cimi/collections/vsps.rb +8 -7
- data/lib/cimi/helpers.rb +1 -1
- data/lib/cimi/helpers/cimi_helper.rb +11 -1
- data/lib/cimi/models.rb +4 -0
- data/lib/cimi/models/base.rb +11 -1
- data/lib/cimi/models/cloud_entry_point.rb +7 -14
- data/lib/cimi/models/disk.rb +40 -0
- data/lib/cimi/models/disk_collection.rb +38 -0
- data/lib/cimi/models/machine.rb +9 -43
- data/lib/cimi/models/machine_collection.rb +7 -4
- data/lib/cimi/models/machine_configuration.rb +8 -15
- data/lib/cimi/models/machine_configuration_collection.rb +6 -4
- data/lib/cimi/models/machine_image_collection.rb +6 -4
- data/lib/cimi/models/machine_template_collection.rb +6 -4
- data/lib/cimi/models/machine_volume.rb +42 -0
- data/lib/cimi/models/machine_volume_collection.rb +34 -0
- data/lib/cimi/models/network.rb +5 -9
- data/lib/cimi/models/network_collection.rb +6 -5
- data/lib/cimi/models/schema.rb +20 -0
- data/lib/cimi/models/volume_collection.rb +6 -4
- data/lib/cimi/models/volume_configuration_collection.rb +6 -4
- data/lib/cimi/models/volume_image_collection.rb +6 -4
- data/lib/cimi/models/volume_template_collection.rb +6 -4
- data/lib/deltacloud/api.rb +3 -3
- data/lib/deltacloud/collections/addresses.rb +1 -1
- data/lib/deltacloud/collections/firewalls.rb +4 -2
- data/lib/deltacloud/collections/keys.rb +1 -1
- data/lib/deltacloud/collections/load_balancers.rb +1 -1
- data/lib/deltacloud/collections/storage_volumes.rb +4 -4
- data/lib/deltacloud/drivers/base_driver.rb +12 -20
- data/lib/deltacloud/drivers/ec2/aws_vpc_monkey_patch.rb +294 -0
- data/lib/deltacloud/drivers/ec2/ec2_driver.rb +38 -6
- data/lib/deltacloud/drivers/fgcp/fgcp_client.rb +4 -0
- data/lib/deltacloud/drivers/fgcp/fgcp_driver.rb +40 -4
- data/lib/deltacloud/drivers/gogrid/gogrid_client.rb +8 -7
- data/lib/deltacloud/drivers/gogrid/gogrid_driver.rb +422 -416
- data/lib/deltacloud/drivers/google/google_driver.rb +2 -1
- data/lib/deltacloud/drivers/openstack/openstack_driver.rb +30 -16
- data/lib/deltacloud/drivers/rhevm/rhevm_driver.rb +1 -0
- data/lib/deltacloud/drivers/vsphere/vsphere_driver.rb +3 -9
- data/lib/deltacloud/helpers/deltacloud_helper.rb +0 -2
- data/lib/deltacloud/models/firewall_rule.rb +2 -0
- data/lib/deltacloud/models/hardware_profile.rb +61 -59
- data/{tests/deprecated/core_ext/string.rb → lib/deltacloud/version.rb} +3 -15
- data/lib/deltacloud_rack.rb +1 -0
- data/lib/ec2/server.rb +5 -3
- data/lib/sinatra/rack_accept.rb +53 -53
- data/lib/sinatra/rack_etag.rb +1 -1
- data/tests/cimi/collections/cloud_entry_point_test.rb +11 -2
- data/tests/deltacloud/common.rb +1 -1
- data/tests/deltacloud/rack_test.rb +3 -3
- data/tests/drivers/base/base_driver_test.rb +6 -2
- data/tests/drivers/base/common.rb +1 -0
- data/tests/drivers/base/library_test.rb +6 -2
- data/tests/drivers/ec2/common.rb +34 -15
- data/tests/drivers/ec2/images_test.rb +2 -3
- data/tests/drivers/ec2/instance_test.rb +12 -2
- data/tests/drivers/ec2/keys_test.rb +2 -2
- data/tests/drivers/ec2/realms_test.rb +7 -3
- data/tests/drivers/ec2/storage_snapshots_test.rb +2 -3
- data/tests/drivers/gogrid/common.rb +24 -0
- data/tests/drivers/gogrid/hardware_profiles_test.rb +51 -0
- data/tests/drivers/gogrid/images_test.rb +57 -0
- data/tests/drivers/gogrid/instances_test.rb +92 -0
- data/tests/drivers/gogrid/realms_test.rb +45 -0
- data/tests/drivers/google/buckets_test.rb +105 -0
- data/tests/drivers/google/common.rb +20 -0
- data/tests/drivers/mock/common.rb +1 -0
- data/tests/drivers/mock/images_test.rb +3 -2
- data/tests/drivers/mock/instances_test.rb +3 -2
- data/tests/drivers/mock/keys_test.rb +3 -2
- data/tests/drivers/mock/realms_test.rb +3 -2
- data/tests/drivers/mock/storage_snapshots_test.rb +3 -2
- data/tests/drivers/mock/storage_volumes_test.rb +3 -2
- data/tests/drivers/models/address_test.rb +3 -3
- data/tests/drivers/models/base_test.rb +4 -2
- data/tests/drivers/models/blob_test.rb +3 -3
- data/tests/drivers/models/common.rb +3 -0
- data/tests/drivers/models/hardware_profile_test.rb +5 -4
- data/tests/drivers/models/instance_address_test.rb +3 -3
- data/tests/drivers/models/instance_profile_test.rb +3 -3
- data/tests/drivers/models/instance_test.rb +3 -3
- data/tests/drivers/models/keys_test.rb +3 -3
- data/tests/drivers/models/metrics_test.rb +3 -3
- data/tests/drivers/openstack/common.rb +26 -0
- data/tests/drivers/openstack/hardware_profiles_test.rb +46 -0
- data/tests/drivers/openstack/images_test.rb +50 -0
- data/tests/drivers/openstack/instances_test.rb +66 -0
- data/tests/drivers/openstack/keys_test.rb +61 -0
- data/tests/drivers/openstack/realms_test.rb +46 -0
- data/tests/drivers/rhevm/common.rb +2 -0
- data/tests/drivers/rhevm/images_test.rb +3 -4
- data/tests/drivers/rhevm/instance_test.rb +2 -2
- data/tests/drivers/rhevm/provider_test.rb +2 -2
- data/tests/drivers/rhevm/realms_test.rb +2 -3
- data/tests/ec2/common.rb +5 -4
- data/tests/ec2/server_test.rb +3 -2
- data/tests/helpers/rack/common.rb +3 -0
- data/tests/helpers/rack/rack_accept_test.rb +65 -0
- data/tests/helpers/rack/rack_date_test.rb +27 -0
- data/tests/helpers/rack/rack_driver_select_test.rb +53 -0
- data/tests/helpers/rack/rack_etag_test.rb +29 -0
- data/tests/helpers/rack/rack_matrix_params_test.rb +72 -0
- data/tests/test_helper.rb +44 -36
- data/views/hardware_profiles/index.html.haml +1 -1
- data/views/hardware_profiles/show.html.haml +2 -2
- data/views/hardware_profiles/show.xml.haml +2 -1
- data/views/images/show.html.haml +6 -5
- metadata +74 -117
- data/tests/deprecated/api/common.rb +0 -1
- data/tests/deprecated/api/driver_test.rb +0 -79
- data/tests/deprecated/api/library_test.rb +0 -6
- data/tests/deprecated/cimi/features/step_definitions/common_steps.rb +0 -59
- data/tests/deprecated/cimi/features/step_definitions/machine_images_steps.rb +0 -0
- data/tests/deprecated/cimi/features/step_definitions/machines_steps.rb +0 -100
- data/tests/deprecated/cimi/features/step_definitions/volumes_steps.rb +0 -115
- data/tests/deprecated/cimi/features/support/env.rb +0 -75
- data/tests/deprecated/common.rb +0 -279
- data/tests/deprecated/drivers/ec2/api_test.rb +0 -19
- data/tests/deprecated/drivers/ec2/common.rb +0 -23
- data/tests/deprecated/drivers/ec2/drivers_test.rb +0 -120
- data/tests/deprecated/drivers/ec2/hardware_profiles_test.rb +0 -224
- data/tests/deprecated/drivers/ec2/images_test.rb +0 -230
- data/tests/deprecated/drivers/ec2/instances_test.rb +0 -356
- data/tests/deprecated/drivers/ec2/keys_test.rb +0 -181
- data/tests/deprecated/drivers/ec2/realms_test.rb +0 -146
- data/tests/deprecated/drivers/fgcp/api_test.rb +0 -47
- data/tests/deprecated/drivers/fgcp/hardware_profiles_test.rb +0 -54
- data/tests/deprecated/drivers/fgcp/realms_test.rb +0 -42
- data/tests/deprecated/drivers/fgcp/setup.rb +0 -13
- data/tests/deprecated/drivers/google/api_test.rb +0 -19
- data/tests/deprecated/drivers/google/buckets_test.rb +0 -100
- data/tests/deprecated/drivers/google/common.rb +0 -54
- data/tests/deprecated/drivers/mock/api_test.rb +0 -10
- data/tests/deprecated/drivers/mock/buckets_test.rb +0 -195
- data/tests/deprecated/drivers/mock/common.rb +0 -7
- data/tests/deprecated/drivers/mock/drivers_test.rb +0 -123
- data/tests/deprecated/drivers/mock/hardware_profiles_test.rb +0 -224
- data/tests/deprecated/drivers/mock/images_test.rb +0 -197
- data/tests/deprecated/drivers/mock/instances_test.rb +0 -343
- data/tests/deprecated/drivers/mock/keys_test.rb +0 -161
- data/tests/deprecated/drivers/mock/realms_test.rb +0 -132
- data/tests/deprecated/drivers/mock/storage_snapshots_test.rb +0 -114
- data/tests/deprecated/drivers/mock/storage_volumes_test.rb +0 -122
- data/tests/deprecated/drivers/openstack/api_test.rb +0 -46
- data/tests/deprecated/drivers/openstack/common.rb +0 -21
- data/tests/deprecated/drivers/openstack/hardware_profiles_test.rb +0 -64
- data/tests/deprecated/drivers/openstack/images_test.rb +0 -46
- data/tests/deprecated/drivers/openstack/instances_test.rb +0 -208
- data/tests/deprecated/drivers/openstack/realms_test.rb +0 -40
- data/tests/deprecated/drivers/rackspace/api_test.rb +0 -46
- data/tests/deprecated/drivers/rackspace/buckets_test.rb +0 -150
- data/tests/deprecated/drivers/rackspace/common.rb +0 -16
- data/tests/deprecated/drivers/rackspace/hardware_profiles_test.rb +0 -58
- data/tests/deprecated/drivers/rackspace/images_test.rb +0 -45
- data/tests/deprecated/drivers/rackspace/instances_test.rb +0 -166
- data/tests/deprecated/drivers/rackspace/realms_test.rb +0 -41
- data/tests/deprecated/drivers/rhevm/api_test.rb +0 -45
- data/tests/deprecated/drivers/rhevm/common.rb +0 -21
- data/tests/deprecated/drivers/rhevm/hardware_profiles_test.rb +0 -58
- data/tests/deprecated/drivers/rhevm/images_test.rb +0 -48
- data/tests/deprecated/drivers/rhevm/instances_test.rb +0 -182
- data/tests/deprecated/drivers/rhevm/realms_test.rb +0 -40
- data/tests/deprecated/minitest_common.rb +0 -58
- data/tests/deprecated/minitest_common_api_test.rb +0 -115
- data/tests/deprecated/rabbit_test.rb +0 -52
@@ -1,195 +0,0 @@
|
|
1
|
-
$:.unshift File.join(File.dirname(__FILE__), '..', '..', '..')
|
2
|
-
require 'tests/drivers/mock/common'
|
3
|
-
|
4
|
-
describe 'Deltacloud API buckets' do
|
5
|
-
include Deltacloud::Test
|
6
|
-
|
7
|
-
it 'must advertise have the buckets collection in API entrypoint' do
|
8
|
-
get root_url
|
9
|
-
(xml_response/'api/link[@rel=buckets]').wont_be_empty
|
10
|
-
end
|
11
|
-
|
12
|
-
it 'must require authentication to access the "bucket" collection' do
|
13
|
-
get collection_url(:buckets)
|
14
|
-
last_response.status.must_equal 401
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'should respond with HTTP_OK when accessing the :buckets collection with authentication' do
|
18
|
-
authenticate
|
19
|
-
get collection_url(:buckets)
|
20
|
-
last_response.status.must_equal 200
|
21
|
-
end
|
22
|
-
|
23
|
-
it 'should support the JSON media type' do
|
24
|
-
authenticate
|
25
|
-
header 'Accept', 'application/json'
|
26
|
-
get collection_url(:buckets)
|
27
|
-
last_response.status.must_equal 200
|
28
|
-
last_response.headers['Content-Type'].must_equal 'application/json'
|
29
|
-
end
|
30
|
-
|
31
|
-
it 'must include the ETag in HTTP headers' do
|
32
|
-
authenticate
|
33
|
-
get collection_url(:buckets)
|
34
|
-
last_response.headers['ETag'].wont_be_nil
|
35
|
-
end
|
36
|
-
|
37
|
-
it 'must have the "buckets" element on top level' do
|
38
|
-
authenticate
|
39
|
-
get collection_url(:buckets)
|
40
|
-
xml_response.root.name.must_equal 'buckets'
|
41
|
-
end
|
42
|
-
|
43
|
-
it 'must have some "bucket" elements inside "buckets"' do
|
44
|
-
authenticate
|
45
|
-
get collection_url(:buckets)
|
46
|
-
(xml_response/'buckets/bucket').wont_be_empty
|
47
|
-
end
|
48
|
-
|
49
|
-
it 'must provide the :id attribute for each bucket in collection' do
|
50
|
-
authenticate
|
51
|
-
get collection_url(:buckets)
|
52
|
-
(xml_response/'buckets/bucket').each do |r|
|
53
|
-
r[:id].wont_be_nil
|
54
|
-
end
|
55
|
-
end
|
56
|
-
|
57
|
-
it 'must include the :href attribute for each "bucket" element in collection' do
|
58
|
-
authenticate
|
59
|
-
get collection_url(:buckets)
|
60
|
-
(xml_response/'buckets/bucket').each do |r|
|
61
|
-
r[:href].wont_be_nil
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
it 'must use the absolute URL in each :href attribute' do
|
66
|
-
authenticate
|
67
|
-
get collection_url(:buckets)
|
68
|
-
(xml_response/'buckets/bucket').each do |r|
|
69
|
-
r[:href].must_match /^http/
|
70
|
-
end
|
71
|
-
end
|
72
|
-
|
73
|
-
it 'must have the URL ending with the :id of the bucket' do
|
74
|
-
authenticate
|
75
|
-
get collection_url(:buckets)
|
76
|
-
(xml_response/'buckets/bucket').each do |r|
|
77
|
-
r[:href].must_match /#{r[:id]}$/
|
78
|
-
end
|
79
|
-
end
|
80
|
-
|
81
|
-
it 'must return the list of valid parameters for the :index action' do
|
82
|
-
authenticate
|
83
|
-
options collection_url(:buckets) + '/index'
|
84
|
-
last_response.headers['Allow'].wont_be_nil
|
85
|
-
end
|
86
|
-
|
87
|
-
it 'must have the "name" element defined for each bucket in collection' do
|
88
|
-
authenticate
|
89
|
-
get collection_url(:buckets)
|
90
|
-
(xml_response/'buckets/bucket').each do |r|
|
91
|
-
(r/'name').wont_be_nil
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
it 'must have the "state" element defined for each bucket in collection' do
|
96
|
-
authenticate
|
97
|
-
get collection_url(:buckets)
|
98
|
-
(xml_response/'buckets/bucket').each do |r|
|
99
|
-
(r/'state').wont_be_nil
|
100
|
-
end
|
101
|
-
end
|
102
|
-
|
103
|
-
it 'must return the full "bucket" when following the URL in bucket element' do
|
104
|
-
authenticate
|
105
|
-
get collection_url(:buckets)
|
106
|
-
(xml_response/'buckets/bucket').each do |r|
|
107
|
-
get collection_url(:buckets) + '/' + r[:id]
|
108
|
-
last_response.status.must_equal 200
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
it 'must have the "name" element for the bucket and it should match with the one in collection' do
|
113
|
-
authenticate
|
114
|
-
get collection_url(:buckets)
|
115
|
-
(xml_response/'buckets/bucket').each do |r|
|
116
|
-
get collection_url(:buckets) + '/' + r[:id]
|
117
|
-
(xml_response/'name').wont_be_empty
|
118
|
-
(xml_response/'name').first.text.must_equal((r/'name').first.text)
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
it 'must have the "size" element for the bucket and it should match with the one in collection' do
|
123
|
-
authenticate
|
124
|
-
get collection_url(:buckets)
|
125
|
-
(xml_response/'buckets/bucket').each do |r|
|
126
|
-
get collection_url(:buckets) + '/' + r[:id]
|
127
|
-
(xml_response/'size').wont_be_empty
|
128
|
-
(xml_response/'size').first.text.must_equal((r/'size').first.text)
|
129
|
-
end
|
130
|
-
end
|
131
|
-
|
132
|
-
it 'must have the "blob" elements for the bucket and it should match with the ones in collection' do
|
133
|
-
authenticate
|
134
|
-
get collection_url(:buckets)
|
135
|
-
(xml_response/'buckets/bucket').each do |r|
|
136
|
-
get collection_url(:buckets) + '/' + r[:id]
|
137
|
-
(xml_response/'bucket/blob').wont_be_empty
|
138
|
-
(xml_response/'bucket/blob').each do |b|
|
139
|
-
b[:id].wont_be_nil
|
140
|
-
b[:href].wont_be_nil
|
141
|
-
b[:href].must_match /^http/
|
142
|
-
b[:href].must_match /#{r[:id]}\/#{b[:id]}$/
|
143
|
-
end
|
144
|
-
end
|
145
|
-
end
|
146
|
-
|
147
|
-
it 'must have the "blob" elements for the bucket and it should match with the ones in collection' do
|
148
|
-
authenticate
|
149
|
-
get collection_url(:buckets)
|
150
|
-
(xml_response/'buckets/bucket').each do |r|
|
151
|
-
get collection_url(:buckets) + '/' + r[:id]
|
152
|
-
(xml_response/'bucket/blob').wont_be_empty
|
153
|
-
(xml_response/'bucket/blob').each do |b|
|
154
|
-
b[:id].wont_be_nil
|
155
|
-
b[:href].wont_be_nil
|
156
|
-
b[:href].must_match /^http/
|
157
|
-
b[:href].must_match /#{r[:id]}\/#{b[:id]}$/
|
158
|
-
end
|
159
|
-
end
|
160
|
-
end
|
161
|
-
|
162
|
-
it 'must allow to get all blobs details and the details should be set correctly' do
|
163
|
-
authenticate
|
164
|
-
get collection_url(:buckets)
|
165
|
-
(xml_response/'buckets/bucket').each do |r|
|
166
|
-
get collection_url(:buckets) + '/' + r[:id]
|
167
|
-
(xml_response/'bucket/blob').each do |b|
|
168
|
-
get collection_url(:buckets) + '/' + r[:id] + '/' + b[:id]
|
169
|
-
xml_response.root.name.must_equal 'blob'
|
170
|
-
xml_response.root[:id].must_equal b[:id]
|
171
|
-
(xml_response/'bucket').wont_be_empty
|
172
|
-
(xml_response/'bucket').size.must_equal 1
|
173
|
-
(xml_response/'bucket').first.text.wont_be_nil
|
174
|
-
(xml_response/'bucket').first.text.must_equal r[:id]
|
175
|
-
(xml_response/'content_length').wont_be_empty
|
176
|
-
(xml_response/'content_length').size.must_equal 1
|
177
|
-
(xml_response/'content_length').first.text.must_match /^(\d+)$/
|
178
|
-
(xml_response/'content_type').wont_be_empty
|
179
|
-
(xml_response/'content_type').size.must_equal 1
|
180
|
-
(xml_response/'content_type').first.text.wont_be_empty
|
181
|
-
(xml_response/'last_modified').wont_be_empty
|
182
|
-
(xml_response/'last_modified').size.must_equal 1
|
183
|
-
(xml_response/'last_modified').first.text.wont_be_empty
|
184
|
-
(xml_response/'content').wont_be_empty
|
185
|
-
(xml_response/'content').size.must_equal 1
|
186
|
-
(xml_response/'content').first[:rel].wont_be_nil
|
187
|
-
(xml_response/'content').first[:rel].must_equal 'blob_content'
|
188
|
-
(xml_response/'content').first[:href].wont_be_nil
|
189
|
-
(xml_response/'content').first[:href].must_match /^http/
|
190
|
-
(xml_response/'content').first[:href].must_match /\/content$/
|
191
|
-
end
|
192
|
-
end
|
193
|
-
end
|
194
|
-
|
195
|
-
end
|
@@ -1,123 +0,0 @@
|
|
1
|
-
$:.unshift File.join(File.dirname(__FILE__), '..', '..', '..')
|
2
|
-
require 'tests/drivers/mock/common'
|
3
|
-
|
4
|
-
describe 'Deltacloud API drivers' do
|
5
|
-
include Deltacloud::Test
|
6
|
-
|
7
|
-
it 'must advertise have the drivers collection in API entrypoint' do
|
8
|
-
get root_url
|
9
|
-
(xml_response/'api/link[@rel=drivers]').wont_be_empty
|
10
|
-
end
|
11
|
-
|
12
|
-
it 'must not require authentication to access the "driver" collection' do
|
13
|
-
get collection_url(:drivers)
|
14
|
-
last_response.status.must_equal 200
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'should respond with HTTP_OK when accessing the :drivers collection with authentication' do
|
18
|
-
get collection_url(:drivers)
|
19
|
-
last_response.status.must_equal 200
|
20
|
-
end
|
21
|
-
|
22
|
-
it 'should support the JSON media type' do
|
23
|
-
header 'Accept', 'application/json'
|
24
|
-
get collection_url(:drivers)
|
25
|
-
last_response.status.must_equal 200
|
26
|
-
last_response.headers['Content-Type'].must_equal 'application/json'
|
27
|
-
end
|
28
|
-
|
29
|
-
it 'must include the ETag in HTTP headers' do
|
30
|
-
get collection_url(:drivers)
|
31
|
-
last_response.headers['ETag'].wont_be_nil
|
32
|
-
end
|
33
|
-
|
34
|
-
it 'must have the "drivers" element on top level' do
|
35
|
-
get collection_url(:drivers)
|
36
|
-
xml_response.root.name.must_equal 'drivers'
|
37
|
-
end
|
38
|
-
|
39
|
-
it 'must have some "driver" elements inside "drivers"' do
|
40
|
-
get collection_url(:drivers)
|
41
|
-
(xml_response/'drivers/driver').wont_be_empty
|
42
|
-
end
|
43
|
-
|
44
|
-
it 'must provide the :id attribute for each driver in collection' do
|
45
|
-
get collection_url(:drivers)
|
46
|
-
(xml_response/'drivers/driver').each do |r|
|
47
|
-
r[:id].wont_be_nil
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
it 'must include the :href attribute for each "driver" element in collection' do
|
52
|
-
get collection_url(:drivers)
|
53
|
-
(xml_response/'drivers/driver').each do |r|
|
54
|
-
r[:href].wont_be_nil
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
it 'must use the absolute URL in each :href attribute' do
|
59
|
-
get collection_url(:drivers)
|
60
|
-
(xml_response/'drivers/driver').each do |r|
|
61
|
-
r[:href].must_match /^http/
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
it 'must have the URL ending with the :id of the driver' do
|
66
|
-
get collection_url(:drivers)
|
67
|
-
(xml_response/'drivers/driver').each do |r|
|
68
|
-
r[:href].must_match /#{r[:id]}$/
|
69
|
-
end
|
70
|
-
end
|
71
|
-
|
72
|
-
it 'must return the list of valid parameters for the :index action' do
|
73
|
-
options collection_url(:drivers) + '/index'
|
74
|
-
last_response.headers['Allow'].wont_be_nil
|
75
|
-
end
|
76
|
-
|
77
|
-
it 'must have the "name" element defined for each driver in collection' do
|
78
|
-
get collection_url(:drivers)
|
79
|
-
(xml_response/'drivers/driver').each do |r|
|
80
|
-
(r/'name').wont_be_nil
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
|
85
|
-
it 'must return the full "driver" when following the URL in driver element' do
|
86
|
-
get collection_url(:drivers)
|
87
|
-
(xml_response/'drivers/driver').each do |r|
|
88
|
-
get collection_url(:drivers) + '/' + r[:id]
|
89
|
-
last_response.status.must_equal 200
|
90
|
-
end
|
91
|
-
end
|
92
|
-
|
93
|
-
it 'must have the "name" element for the driver and it should match with the one in collection' do
|
94
|
-
get collection_url(:drivers)
|
95
|
-
(xml_response/'drivers/driver').each do |r|
|
96
|
-
get collection_url(:drivers) + '/' + r[:id]
|
97
|
-
(xml_response/'name').wont_be_empty
|
98
|
-
(xml_response/'name').first.text.must_equal((r/'name').first.text)
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
|
-
it 'should advertise available providers for some drivers' do
|
103
|
-
get collection_url(:drivers)
|
104
|
-
(xml_response/'drivers/driver/provider').each do |p|
|
105
|
-
p[:id].wont_be_nil
|
106
|
-
end
|
107
|
-
end
|
108
|
-
|
109
|
-
it 'should expose entrypoints for each provider if driver has providers defined' do
|
110
|
-
get collection_url(:drivers)
|
111
|
-
(xml_response/'drivers/driver/provider').each do |p|
|
112
|
-
get collection_url(:drivers) + '/' + p.parent[:id]
|
113
|
-
(xml_response/"driver/provider[@id=#{p[:id]}]").wont_be_empty
|
114
|
-
(xml_response/"driver/provider[@id=#{p[:id]}]").size.must_equal 1
|
115
|
-
(xml_response/"driver/provider[@id=#{p[:id]}]/entrypoint").wont_be_empty
|
116
|
-
(xml_response/"driver/provider[@id=#{p[:id]}]/entrypoint").each do |e|
|
117
|
-
e[:kind].wont_be_nil
|
118
|
-
e.text.wont_be_empty
|
119
|
-
end
|
120
|
-
end
|
121
|
-
end
|
122
|
-
|
123
|
-
end
|
@@ -1,224 +0,0 @@
|
|
1
|
-
$:.unshift File.join(File.dirname(__FILE__), '..', '..', '..')
|
2
|
-
require 'tests/drivers/mock/common'
|
3
|
-
|
4
|
-
describe 'Deltacloud API Hardware Profiles' do
|
5
|
-
include Deltacloud::Test
|
6
|
-
|
7
|
-
it 'must advertise have the hardware_profiles collection in API entrypoint' do
|
8
|
-
get root_url
|
9
|
-
(xml_response/'api/link[@rel=hardware_profiles]').wont_be_empty
|
10
|
-
end
|
11
|
-
|
12
|
-
it 'should respond with HTTP_OK when accessing the :hardware_profiles collection with authentication' do
|
13
|
-
authenticate
|
14
|
-
get collection_url(:hardware_profiles)
|
15
|
-
last_response.status.must_equal 200
|
16
|
-
end
|
17
|
-
|
18
|
-
it 'should support the JSON media type' do
|
19
|
-
authenticate
|
20
|
-
header 'Accept', 'application/json'
|
21
|
-
get collection_url(:hardware_profiles)
|
22
|
-
last_response.status.must_equal 200
|
23
|
-
last_response.headers['Content-Type'].must_equal 'application/json'
|
24
|
-
end
|
25
|
-
|
26
|
-
it 'must include the ETag in HTTP headers' do
|
27
|
-
authenticate
|
28
|
-
get collection_url(:hardware_profiles)
|
29
|
-
last_response.headers['ETag'].wont_be_nil
|
30
|
-
end
|
31
|
-
|
32
|
-
it 'must have the "hardware_profiles" element on top level' do
|
33
|
-
authenticate
|
34
|
-
get collection_url(:hardware_profiles)
|
35
|
-
xml_response.root.name.must_equal 'hardware_profiles'
|
36
|
-
end
|
37
|
-
|
38
|
-
it 'must have some "hardware_profile" elements inside "hardware_profiles"' do
|
39
|
-
authenticate
|
40
|
-
get collection_url(:hardware_profiles)
|
41
|
-
(xml_response/'hardware_profiles/hardware_profile').wont_be_empty
|
42
|
-
end
|
43
|
-
|
44
|
-
it 'must provide the :id attribute for each hardware_profile in collection' do
|
45
|
-
authenticate
|
46
|
-
get collection_url(:hardware_profiles)
|
47
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
48
|
-
r[:id].wont_be_nil
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
|
-
it 'must include the :href attribute for each "hardware_profile" element in collection' do
|
53
|
-
authenticate
|
54
|
-
get collection_url(:hardware_profiles)
|
55
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
56
|
-
r[:href].wont_be_nil
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
it 'must use the absolute URL in each :href attribute' do
|
61
|
-
authenticate
|
62
|
-
get collection_url(:hardware_profiles)
|
63
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
64
|
-
r[:href].must_match /^http/
|
65
|
-
end
|
66
|
-
end
|
67
|
-
|
68
|
-
it 'must have the URL ending with the :id of the hardware_profile' do
|
69
|
-
authenticate
|
70
|
-
get collection_url(:hardware_profiles)
|
71
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
72
|
-
r[:href].must_match /#{r[:id]}$/
|
73
|
-
end
|
74
|
-
end
|
75
|
-
|
76
|
-
it 'must return the list of valid parameters for the :index action' do
|
77
|
-
authenticate
|
78
|
-
options collection_url(:hardware_profiles) + '/index'
|
79
|
-
last_response.headers['Allow'].wont_be_nil
|
80
|
-
end
|
81
|
-
|
82
|
-
it 'must have the "name" element defined for each hardware_profile in collection' do
|
83
|
-
authenticate
|
84
|
-
get collection_url(:hardware_profiles)
|
85
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
86
|
-
(r/'name').wont_be_empty
|
87
|
-
end
|
88
|
-
end
|
89
|
-
|
90
|
-
it 'should have the "property" element defined if not the opaque hardware_profile' do
|
91
|
-
authenticate
|
92
|
-
get collection_url(:hardware_profiles)
|
93
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
94
|
-
next if r[:id] == 'opaque'
|
95
|
-
(r/'property').wont_be_empty
|
96
|
-
end
|
97
|
-
end
|
98
|
-
|
99
|
-
it 'must define the :kind attribute for each "property" ' do
|
100
|
-
authenticate
|
101
|
-
get collection_url(:hardware_profiles)
|
102
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
103
|
-
next if r[:id] == 'opaque'
|
104
|
-
(r/'property').each { |p| p[:kind].wont_be_nil }
|
105
|
-
end
|
106
|
-
end
|
107
|
-
|
108
|
-
it 'must define the :name attribute for each "property" ' do
|
109
|
-
authenticate
|
110
|
-
get collection_url(:hardware_profiles)
|
111
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
112
|
-
next if r[:id] == 'opaque'
|
113
|
-
(r/'property').each { |p| p[:name].wont_be_nil }
|
114
|
-
end
|
115
|
-
end
|
116
|
-
|
117
|
-
it 'must define the :unit attribute for each "property" ' do
|
118
|
-
authenticate
|
119
|
-
get collection_url(:hardware_profiles)
|
120
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
121
|
-
next if r[:id] == 'opaque'
|
122
|
-
(r/'property').each { |p| p[:unit].wont_be_nil }
|
123
|
-
end
|
124
|
-
end
|
125
|
-
|
126
|
-
it 'must define the :value attribute for each "property" ' do
|
127
|
-
authenticate
|
128
|
-
get collection_url(:hardware_profiles)
|
129
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
130
|
-
next if r[:id] == 'opaque'
|
131
|
-
(r/'property').each { |p| p[:value].wont_be_nil }
|
132
|
-
end
|
133
|
-
end
|
134
|
-
|
135
|
-
it 'must define the "param" element if property kind is not "fixed"' do
|
136
|
-
authenticate
|
137
|
-
get collection_url(:hardware_profiles)
|
138
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
139
|
-
next if r[:id] == 'opaque'
|
140
|
-
(r/'property').each do |p|
|
141
|
-
next if p[:kind] == 'fixed'
|
142
|
-
(p/'param').wont_be_empty
|
143
|
-
(p/'param').size.must_equal 1
|
144
|
-
(p/'param').first[:href].wont_be_nil
|
145
|
-
(p/'param').first[:href].must_match /^http/
|
146
|
-
(p/'param').first[:method].wont_be_nil
|
147
|
-
(p/'param').first[:name].wont_be_nil
|
148
|
-
(p/'param').first[:operation].wont_be_nil
|
149
|
-
end
|
150
|
-
end
|
151
|
-
end
|
152
|
-
|
153
|
-
it 'must provide the list of valid values when the property is defined as "enum"' do
|
154
|
-
authenticate
|
155
|
-
get collection_url(:hardware_profiles)
|
156
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
157
|
-
next if r[:id] == 'opaque'
|
158
|
-
(r/'property').each do |p|
|
159
|
-
next if p[:kind] != 'enum'
|
160
|
-
(p/'enum/entry').wont_be_empty
|
161
|
-
(p/'enum/entry').each { |e| e[:value].wont_be_nil }
|
162
|
-
end
|
163
|
-
end
|
164
|
-
end
|
165
|
-
|
166
|
-
it 'must provide the range of valid values when the property is defined as "range"' do
|
167
|
-
authenticate
|
168
|
-
get collection_url(:hardware_profiles)
|
169
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
170
|
-
next if r[:id] == 'opaque'
|
171
|
-
(r/'property').each do |p|
|
172
|
-
next if p[:kind] != 'range'
|
173
|
-
(p/'range').wont_be_empty
|
174
|
-
(p/'range').size.must_equal 1
|
175
|
-
(p/'range').first[:first].wont_be_nil
|
176
|
-
(p/'range').first[:last].wont_be_nil
|
177
|
-
end
|
178
|
-
end
|
179
|
-
end
|
180
|
-
|
181
|
-
it 'must provide the default value within the range if property defined as "range"' do
|
182
|
-
authenticate
|
183
|
-
get collection_url(:hardware_profiles)
|
184
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
185
|
-
next if r[:id] == 'opaque'
|
186
|
-
(r/'property').each do |p|
|
187
|
-
next if p[:kind] != 'range'
|
188
|
-
((p/'range').first[:first].to_i..(p/'range').first[:last].to_i).include?(p[:value].to_i).must_equal true
|
189
|
-
end
|
190
|
-
end
|
191
|
-
end
|
192
|
-
|
193
|
-
it 'must provide the default value that is included in enum list if property defined as "enum"' do
|
194
|
-
authenticate
|
195
|
-
get collection_url(:hardware_profiles)
|
196
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
197
|
-
next if r[:id] == 'opaque'
|
198
|
-
(r/'property').each do |p|
|
199
|
-
next if p[:kind] != 'enum'
|
200
|
-
(p/'enum/entry').map { |e| e[:value] }.include?(p[:value]).must_equal true
|
201
|
-
end
|
202
|
-
end
|
203
|
-
end
|
204
|
-
|
205
|
-
it 'must return the full "hardware_profile" when following the URL in hardware_profile element' do
|
206
|
-
authenticate
|
207
|
-
get collection_url(:hardware_profiles)
|
208
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
209
|
-
get collection_url(:hardware_profiles) + '/' + r[:id]
|
210
|
-
last_response.status.must_equal 200
|
211
|
-
end
|
212
|
-
end
|
213
|
-
|
214
|
-
it 'must have the "name" element for the hardware_profile and it should match with the one in collection' do
|
215
|
-
authenticate
|
216
|
-
get collection_url(:hardware_profiles)
|
217
|
-
(xml_response/'hardware_profiles/hardware_profile').each do |r|
|
218
|
-
get collection_url(:hardware_profiles) + '/' + r[:id]
|
219
|
-
(xml_response/'name').wont_be_empty
|
220
|
-
(xml_response/'name').first.text.must_equal((r/'name').first.text)
|
221
|
-
end
|
222
|
-
end
|
223
|
-
|
224
|
-
end
|