fog-packet 1.0.0
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 +7 -0
- data/.gitignore +51 -0
- data/.rubocop.yml +38 -0
- data/Gemfile +4 -0
- data/LICENSE +21 -0
- data/README.md +1176 -0
- data/Rakefile +24 -0
- data/fog-packet.gemspec +24 -0
- data/lib/fog-packet.rb +26 -0
- data/lib/fog/compute/packet/compute.rb +313 -0
- data/lib/fog/compute/packet/models/bandwidth.rb +14 -0
- data/lib/fog/compute/packet/models/batch.rb +18 -0
- data/lib/fog/compute/packet/models/batches.rb +27 -0
- data/lib/fog/compute/packet/models/bgp_session.rb +35 -0
- data/lib/fog/compute/packet/models/bgp_sessions.rb +22 -0
- data/lib/fog/compute/packet/models/capacities.rb +27 -0
- data/lib/fog/compute/packet/models/capacity.rb +29 -0
- data/lib/fog/compute/packet/models/device.rb +136 -0
- data/lib/fog/compute/packet/models/devices.rb +22 -0
- data/lib/fog/compute/packet/models/email.rb +50 -0
- data/lib/fog/compute/packet/models/email_verification.rb +18 -0
- data/lib/fog/compute/packet/models/emails.rb +17 -0
- data/lib/fog/compute/packet/models/event.rb +23 -0
- data/lib/fog/compute/packet/models/events.rb +17 -0
- data/lib/fog/compute/packet/models/facilities.rb +17 -0
- data/lib/fog/compute/packet/models/facility.rb +22 -0
- data/lib/fog/compute/packet/models/hardware_reservation.rb +66 -0
- data/lib/fog/compute/packet/models/hardware_reservations.rb +22 -0
- data/lib/fog/compute/packet/models/invitation.rb +36 -0
- data/lib/fog/compute/packet/models/invitations.rb +22 -0
- data/lib/fog/compute/packet/models/ip.rb +60 -0
- data/lib/fog/compute/packet/models/ips.rb +22 -0
- data/lib/fog/compute/packet/models/license.rb +55 -0
- data/lib/fog/compute/packet/models/licenses.rb +22 -0
- data/lib/fog/compute/packet/models/membership.rb +38 -0
- data/lib/fog/compute/packet/models/memberships.rb +22 -0
- data/lib/fog/compute/packet/models/notification.rb +31 -0
- data/lib/fog/compute/packet/models/notifications.rb +22 -0
- data/lib/fog/compute/packet/models/operating_system.rb +23 -0
- data/lib/fog/compute/packet/models/operating_systems.rb +17 -0
- data/lib/fog/compute/packet/models/organization.rb +71 -0
- data/lib/fog/compute/packet/models/organizations.rb +22 -0
- data/lib/fog/compute/packet/models/payment_method.rb +63 -0
- data/lib/fog/compute/packet/models/payment_methods.rb +22 -0
- data/lib/fog/compute/packet/models/plan.rb +23 -0
- data/lib/fog/compute/packet/models/plans.rb +17 -0
- data/lib/fog/compute/packet/models/project.rb +47 -0
- data/lib/fog/compute/packet/models/projects.rb +22 -0
- data/lib/fog/compute/packet/models/session.rb +22 -0
- data/lib/fog/compute/packet/models/sessions.rb +26 -0
- data/lib/fog/compute/packet/models/snapshot.rb +33 -0
- data/lib/fog/compute/packet/models/snapshots.rb +22 -0
- data/lib/fog/compute/packet/models/spot_market_price.rb +15 -0
- data/lib/fog/compute/packet/models/spot_market_prices.rb +22 -0
- data/lib/fog/compute/packet/models/ssh_key.rb +51 -0
- data/lib/fog/compute/packet/models/ssh_keys.rb +22 -0
- data/lib/fog/compute/packet/models/transfer_request.rb +34 -0
- data/lib/fog/compute/packet/models/transfer_requests.rb +27 -0
- data/lib/fog/compute/packet/models/two_factor_auth.rb +18 -0
- data/lib/fog/compute/packet/models/user.rb +56 -0
- data/lib/fog/compute/packet/models/users.rb +22 -0
- data/lib/fog/compute/packet/models/virtual_network.rb +76 -0
- data/lib/fog/compute/packet/models/virtual_networks.rb +17 -0
- data/lib/fog/compute/packet/models/volume.rb +96 -0
- data/lib/fog/compute/packet/models/volumes.rb +23 -0
- data/lib/fog/compute/packet/models/vpn.rb +16 -0
- data/lib/fog/compute/packet/models/vpns.rb +27 -0
- data/lib/fog/compute/packet/requests/accept_invitation.rb +43 -0
- data/lib/fog/compute/packet/requests/accept_transfer_request.rb +26 -0
- data/lib/fog/compute/packet/requests/assign_ip.rb +32 -0
- data/lib/fog/compute/packet/requests/assign_port.rb +25 -0
- data/lib/fog/compute/packet/requests/attach_volume.rb +41 -0
- data/lib/fog/compute/packet/requests/bond_ports.rb +25 -0
- data/lib/fog/compute/packet/requests/create_batch.rb +43 -0
- data/lib/fog/compute/packet/requests/create_bgp_session.rb +37 -0
- data/lib/fog/compute/packet/requests/create_device.rb +212 -0
- data/lib/fog/compute/packet/requests/create_email.rb +38 -0
- data/lib/fog/compute/packet/requests/create_license.rb +46 -0
- data/lib/fog/compute/packet/requests/create_organization.rb +87 -0
- data/lib/fog/compute/packet/requests/create_payment_method.rb +63 -0
- data/lib/fog/compute/packet/requests/create_project.rb +72 -0
- data/lib/fog/compute/packet/requests/create_snapshot.rb +25 -0
- data/lib/fog/compute/packet/requests/create_ssh_key.rb +44 -0
- data/lib/fog/compute/packet/requests/create_virtual_network.rb +49 -0
- data/lib/fog/compute/packet/requests/create_volume.rb +70 -0
- data/lib/fog/compute/packet/requests/decline_invitation.rb +43 -0
- data/lib/fog/compute/packet/requests/decline_transfer_request.rb +26 -0
- data/lib/fog/compute/packet/requests/delete_bgp_session.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_device.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_email.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_license.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_membership.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_organization.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_payment_method.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_project.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_session.rb +27 -0
- data/lib/fog/compute/packet/requests/delete_snapshot.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_ssh_key.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_virtual_network.rb +25 -0
- data/lib/fog/compute/packet/requests/delete_volume.rb +25 -0
- data/lib/fog/compute/packet/requests/detach_volume.rb +36 -0
- data/lib/fog/compute/packet/requests/disable_two_factor_auth.rb +27 -0
- data/lib/fog/compute/packet/requests/disable_vpn.rb +25 -0
- data/lib/fog/compute/packet/requests/disbond_ports.rb +25 -0
- data/lib/fog/compute/packet/requests/enable_two_factor_auth.rb +26 -0
- data/lib/fog/compute/packet/requests/enable_vpn.rb +25 -0
- data/lib/fog/compute/packet/requests/get_bandwidth.rb +31 -0
- data/lib/fog/compute/packet/requests/get_batch.rb +38 -0
- data/lib/fog/compute/packet/requests/get_bgp_session.rb +37 -0
- data/lib/fog/compute/packet/requests/get_capacity.rb +165 -0
- data/lib/fog/compute/packet/requests/get_device.rb +189 -0
- data/lib/fog/compute/packet/requests/get_email.rb +32 -0
- data/lib/fog/compute/packet/requests/get_hardware_reservation.rb +193 -0
- data/lib/fog/compute/packet/requests/get_invitation.rb +43 -0
- data/lib/fog/compute/packet/requests/get_ip.rb +60 -0
- data/lib/fog/compute/packet/requests/get_license.rb +37 -0
- data/lib/fog/compute/packet/requests/get_membership.rb +40 -0
- data/lib/fog/compute/packet/requests/get_notification.rb +40 -0
- data/lib/fog/compute/packet/requests/get_organization.rb +61 -0
- data/lib/fog/compute/packet/requests/get_payment_method.rb +56 -0
- data/lib/fog/compute/packet/requests/get_project.rb +67 -0
- data/lib/fog/compute/packet/requests/get_ssh_key.rb +38 -0
- data/lib/fog/compute/packet/requests/get_transfer_request.rb +38 -0
- data/lib/fog/compute/packet/requests/get_user.rb +56 -0
- data/lib/fog/compute/packet/requests/get_volume.rb +60 -0
- data/lib/fog/compute/packet/requests/get_vpn.rb +29 -0
- data/lib/fog/compute/packet/requests/list_batches.rb +33 -0
- data/lib/fog/compute/packet/requests/list_bgp_sessions.rb +32 -0
- data/lib/fog/compute/packet/requests/list_devices.rb +33 -0
- data/lib/fog/compute/packet/requests/list_events.rb +33 -0
- data/lib/fog/compute/packet/requests/list_facilities.rb +57 -0
- data/lib/fog/compute/packet/requests/list_hardware_reservations.rb +216 -0
- data/lib/fog/compute/packet/requests/list_invitations.rb +48 -0
- data/lib/fog/compute/packet/requests/list_ips.rb +65 -0
- data/lib/fog/compute/packet/requests/list_licenses.rb +42 -0
- data/lib/fog/compute/packet/requests/list_memberships.rb +45 -0
- data/lib/fog/compute/packet/requests/list_notifications.rb +45 -0
- data/lib/fog/compute/packet/requests/list_operating_systems.rb +66 -0
- data/lib/fog/compute/packet/requests/list_organizations.rb +81 -0
- data/lib/fog/compute/packet/requests/list_payment_methods.rb +76 -0
- data/lib/fog/compute/packet/requests/list_plans.rb +92 -0
- data/lib/fog/compute/packet/requests/list_projects.rb +87 -0
- data/lib/fog/compute/packet/requests/list_sessions.rb +40 -0
- data/lib/fog/compute/packet/requests/list_snapshots.rb +40 -0
- data/lib/fog/compute/packet/requests/list_spotmarketprices.rb +173 -0
- data/lib/fog/compute/packet/requests/list_spotmarketprices_history.rb +42 -0
- data/lib/fog/compute/packet/requests/list_ssh_keys.rb +50 -0
- data/lib/fog/compute/packet/requests/list_transfer_requests.rb +43 -0
- data/lib/fog/compute/packet/requests/list_users.rb +61 -0
- data/lib/fog/compute/packet/requests/list_virtual_networks.rb +62 -0
- data/lib/fog/compute/packet/requests/list_volumes.rb +65 -0
- data/lib/fog/compute/packet/requests/move_hardware_reservation.rb +43 -0
- data/lib/fog/compute/packet/requests/poweroff_device.rb +194 -0
- data/lib/fog/compute/packet/requests/poweron_device.rb +194 -0
- data/lib/fog/compute/packet/requests/reboot_device.rb +194 -0
- data/lib/fog/compute/packet/requests/request_email_verification.rb +25 -0
- data/lib/fog/compute/packet/requests/reserve_ip.rb +37 -0
- data/lib/fog/compute/packet/requests/session_login.rb +25 -0
- data/lib/fog/compute/packet/requests/transfer_project.rb +43 -0
- data/lib/fog/compute/packet/requests/unassign_ip.rb +24 -0
- data/lib/fog/compute/packet/requests/unassign_port.rb +25 -0
- data/lib/fog/compute/packet/requests/update_device.rb +201 -0
- data/lib/fog/compute/packet/requests/update_email.rb +37 -0
- data/lib/fog/compute/packet/requests/update_license.rb +42 -0
- data/lib/fog/compute/packet/requests/update_membership.rb +43 -0
- data/lib/fog/compute/packet/requests/update_notification.rb +40 -0
- data/lib/fog/compute/packet/requests/update_organization.rb +85 -0
- data/lib/fog/compute/packet/requests/update_payment_method.rb +63 -0
- data/lib/fog/compute/packet/requests/update_project.rb +71 -0
- data/lib/fog/compute/packet/requests/update_ssh_key.rb +43 -0
- data/lib/fog/compute/packet/requests/update_user.rb +65 -0
- data/lib/fog/compute/packet/requests/update_volume.rb +66 -0
- data/lib/fog/compute/packet/requests/validate_capacity.rb +38 -0
- data/lib/fog/compute/packet/requests/verify_email.rb +36 -0
- data/tests/packet/models/test_batches.rb +45 -0
- data/tests/packet/models/test_bgp_sessions.rb +52 -0
- data/tests/packet/models/test_capacity.rb +40 -0
- data/tests/packet/models/test_devices.rb +93 -0
- data/tests/packet/models/test_email_verification.rb +25 -0
- data/tests/packet/models/test_emails.rb +45 -0
- data/tests/packet/models/test_facilities.rb +18 -0
- data/tests/packet/models/test_hardware_reservations.rb +38 -0
- data/tests/packet/models/test_invitations.rb +41 -0
- data/tests/packet/models/test_ips.rb +52 -0
- data/tests/packet/models/test_licenses.rb +56 -0
- data/tests/packet/models/test_memberships.rb +41 -0
- data/tests/packet/models/test_notifications.rb +35 -0
- data/tests/packet/models/test_operating_systems.rb +19 -0
- data/tests/packet/models/test_organizations.rb +67 -0
- data/tests/packet/models/test_payment_methods.rb +61 -0
- data/tests/packet/models/test_plans.rb +19 -0
- data/tests/packet/models/test_projects.rb +41 -0
- data/tests/packet/models/test_sessions.rb +34 -0
- data/tests/packet/models/test_snapshots.rb +43 -0
- data/tests/packet/models/test_spotmarketprices.rb +28 -0
- data/tests/packet/models/test_ssh_keys.rb +58 -0
- data/tests/packet/models/test_transfer_requests.rb +49 -0
- data/tests/packet/models/test_two_factor_auth.rb +29 -0
- data/tests/packet/models/test_users.rb +47 -0
- data/tests/packet/models/test_virtual_networks.rb +81 -0
- data/tests/packet/models/test_volumes.rb +70 -0
- data/tests/packet/models/test_vpns.rb +37 -0
- data/tests/packet/requests/test_batches.rb +45 -0
- data/tests/packet/requests/test_bgp_sessions.rb +64 -0
- data/tests/packet/requests/test_capacity.rb +40 -0
- data/tests/packet/requests/test_devices.rb +104 -0
- data/tests/packet/requests/test_email_verification.rb +25 -0
- data/tests/packet/requests/test_emails.rb +51 -0
- data/tests/packet/requests/test_facilities.rb +19 -0
- data/tests/packet/requests/test_hardware_reservations.rb +38 -0
- data/tests/packet/requests/test_invitations.rb +40 -0
- data/tests/packet/requests/test_ips.rb +66 -0
- data/tests/packet/requests/test_licenses.rb +56 -0
- data/tests/packet/requests/test_memberships.rb +43 -0
- data/tests/packet/requests/test_notifications.rb +40 -0
- data/tests/packet/requests/test_operating_systems.rb +19 -0
- data/tests/packet/requests/test_organizations.rb +64 -0
- data/tests/packet/requests/test_payment_methods.rb +60 -0
- data/tests/packet/requests/test_plans.rb +21 -0
- data/tests/packet/requests/test_projects.rb +40 -0
- data/tests/packet/requests/test_sessions.rb +34 -0
- data/tests/packet/requests/test_snapshots.rb +57 -0
- data/tests/packet/requests/test_sportmarketprices.rb +29 -0
- data/tests/packet/requests/test_ssh_keys.rb +60 -0
- data/tests/packet/requests/test_transfer_requests.rb +46 -0
- data/tests/packet/requests/test_two_factor_auth.rb +29 -0
- data/tests/packet/requests/test_users.rb +48 -0
- data/tests/packet/requests/test_virtual_networks.rb +100 -0
- data/tests/packet/requests/test_volumes.rb +95 -0
- data/tests/packet/requests/test_vpns.rb +38 -0
- data/tests/test_helper.rb +4 -0
- metadata +345 -0
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestSnapshots
|
|
4
|
+
class TestSnapshots < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
|
13
|
+
options = {
|
|
14
|
+
:facility => "ewr1",
|
|
15
|
+
:plan => "storage_1",
|
|
16
|
+
:size => 20,
|
|
17
|
+
:description => "test description",
|
|
18
|
+
:billing_cycle => "hourly"
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
response = @compute.create_volume(@project_id, options)
|
|
22
|
+
|
|
23
|
+
@@volume_id = response.body["id"]
|
|
24
|
+
|
|
25
|
+
unless Fog.mock?
|
|
26
|
+
loop do
|
|
27
|
+
sleep(3)
|
|
28
|
+
response = @compute.get_volume(@@volume_id)
|
|
29
|
+
break if response.body["state"] == "active"
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
def test_request_a_create_snapshot
|
|
35
|
+
response = @compute.create_snapshot(@@volume_id)
|
|
36
|
+
|
|
37
|
+
assert_equal 202, response.status
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def test_request_b_list_snapshots
|
|
41
|
+
response = @compute.list_snapshots(@@volume_id)
|
|
42
|
+
|
|
43
|
+
assert_equal 200, response.status
|
|
44
|
+
assert !response.body["snapshots"].empty?
|
|
45
|
+
@@snapshot_id = response.body["snapshots"][0]["id"]
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
def test_request_c_delete_snapshot
|
|
49
|
+
response = @compute.delete_snapshot(@@volume_id, @@snapshot_id)
|
|
50
|
+
|
|
51
|
+
assert_equal 204, response.status
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
def test_request_e_cleanup
|
|
55
|
+
@compute.delete_volume(@@volume_id)
|
|
56
|
+
end
|
|
57
|
+
end
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestSpotMarketPrices
|
|
4
|
+
class TestSpotMarketPrices < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def test_request_list_spotmarketprices
|
|
15
|
+
# Perform Request
|
|
16
|
+
response = @compute.list_spotmarketprices
|
|
17
|
+
|
|
18
|
+
# Assertions
|
|
19
|
+
assert !response.body["spot_market_prices"].empty?
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def test_request_list_spotmarketprices_history
|
|
23
|
+
# Perform Request
|
|
24
|
+
response = @compute.list_spotmarketprices_history("ewr1", "baremetal_0")
|
|
25
|
+
|
|
26
|
+
# Assertions
|
|
27
|
+
assert !response.body["prices_history"].empty?
|
|
28
|
+
end
|
|
29
|
+
end
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestSSHKeys
|
|
4
|
+
class TestSSHKeys < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def test_request_a_create_ssh_key
|
|
15
|
+
options = {
|
|
16
|
+
:label => "test",
|
|
17
|
+
:key => "ssh-rsa AAAAB3Nz"
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
# Perform Request
|
|
21
|
+
response = @compute.create_ssh_key(options)
|
|
22
|
+
|
|
23
|
+
assert response.body
|
|
24
|
+
assert_equal options[:label], response.body["label"]
|
|
25
|
+
assert_equal options[:key], response.body["key"]
|
|
26
|
+
@@key_id = response.body["id"]
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def test_request_b_list_ssh_keys
|
|
30
|
+
response = @compute.list_ssh_keys
|
|
31
|
+
|
|
32
|
+
assert !response.body["ssh_keys"].empty?
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def test_request_c_get_ssh_key
|
|
36
|
+
response = @compute.get_ssh_key(@@key_id)
|
|
37
|
+
|
|
38
|
+
assert_equal @@key_id, response.body["id"]
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def test_request_d_update_ssh_key
|
|
42
|
+
options = {
|
|
43
|
+
:label => "test",
|
|
44
|
+
:key => "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDgnV5MOhBqpQLt66KGlMKi"
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
response = @compute.update_ssh_key(@@key_id, options)
|
|
48
|
+
|
|
49
|
+
assert response.body
|
|
50
|
+
assert_equal 200, response.status
|
|
51
|
+
assert_equal options[:label], response.body["label"]
|
|
52
|
+
assert_equal options[:key], response.body["key"]
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
def test_request_h_delete_ssh_key
|
|
56
|
+
response = @compute.delete_ssh_key(@@key_id)
|
|
57
|
+
|
|
58
|
+
assert_equal 204, response.status
|
|
59
|
+
end
|
|
60
|
+
end
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestInvitations
|
|
4
|
+
class TestInvitations < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
11
|
+
@org_id = "602c17ec-f996-4d94-a6a8-20d6356e6c2a"
|
|
12
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def test_request_a_transfer_project
|
|
16
|
+
response = @compute.transfer_project(@project_id, @org_id)
|
|
17
|
+
|
|
18
|
+
assert_equal 201, response.status
|
|
19
|
+
@@transfer_request_id = response.body["id"]
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def test_request_b_list_transfer_requests
|
|
23
|
+
response = @compute.list_transfer_requests(@org_id)
|
|
24
|
+
|
|
25
|
+
assert_equal 200, response.status
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def test_request_c_get_transfer_request
|
|
29
|
+
response = @compute.get_transfer_request(@@transfer_request_id)
|
|
30
|
+
|
|
31
|
+
assert_equal 200, response.status
|
|
32
|
+
assert_equal @@transfer_request_id, response.body["id"]
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def test_request_d_accept_transfer_request
|
|
36
|
+
response = @compute.accept_transfer_request(@@transfer_request_id)
|
|
37
|
+
|
|
38
|
+
assert_equal 204, response.status
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def test_request_e_decline_transfer_request
|
|
42
|
+
response = @compute.decline_transfer_request(@@transfer_request_id)
|
|
43
|
+
|
|
44
|
+
assert_equal 204, response.status
|
|
45
|
+
end
|
|
46
|
+
end
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestTwoFactorAuth
|
|
4
|
+
class TestTwoFactorAuth < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def test_request_a_enable_two_factor_auth
|
|
15
|
+
# Perform Request
|
|
16
|
+
response = @compute.enable_two_factor_auth("app")
|
|
17
|
+
|
|
18
|
+
# Assertions
|
|
19
|
+
assert_equal 200, response.status
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def test_request_c_disable_two_factor_auth
|
|
23
|
+
# Perform Request
|
|
24
|
+
response = @compute.disable_two_factor_auth("app")
|
|
25
|
+
|
|
26
|
+
# Assertions
|
|
27
|
+
assert_equal 204, response.status
|
|
28
|
+
end
|
|
29
|
+
end
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestUsers
|
|
4
|
+
class TestUsers < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def test_request_a_list_users
|
|
15
|
+
# Perform Request
|
|
16
|
+
response = @compute.list_users
|
|
17
|
+
|
|
18
|
+
# Assertions
|
|
19
|
+
assert !response.body["users"].empty?
|
|
20
|
+
|
|
21
|
+
@@user_id = response.body["users"][0]["id"]
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def test_request_b_get_current_user
|
|
25
|
+
response = @compute.get_user
|
|
26
|
+
assert_equal response.status, 200
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def test_request_c_get_user
|
|
30
|
+
response = @compute.get_user(@@user_id)
|
|
31
|
+
|
|
32
|
+
assert_equal response.status, 200
|
|
33
|
+
assert_equal @@user_id, response.body["id"]
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def test_request_d_update_user
|
|
37
|
+
options = {
|
|
38
|
+
:first_name => "Jane",
|
|
39
|
+
:last_name => "Doe"
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
response = @compute.update_user("2dce124f-3220-495c-907e-5bbbd4dda77c", options)
|
|
43
|
+
|
|
44
|
+
assert_equal response.status, 200
|
|
45
|
+
assert_equal options[:first_name], response.body["first_name"]
|
|
46
|
+
assert_equal options[:last_name], response.body["last_name"]
|
|
47
|
+
end
|
|
48
|
+
end
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
require_relative "../../test_helper.rb"
|
|
2
|
+
|
|
3
|
+
# TestVirtualNetworks
|
|
4
|
+
class TestVirtualNetworks < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def test_request_a_create_virtual_network
|
|
16
|
+
dev = {
|
|
17
|
+
:hostname => "test01",
|
|
18
|
+
:facility => "ewr1",
|
|
19
|
+
:plan => "baremetal_0",
|
|
20
|
+
:operating_system => "coreos_stable"
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
response = @compute.create_device(@project_id, dev)
|
|
24
|
+
|
|
25
|
+
@@device = response.body
|
|
26
|
+
loop do
|
|
27
|
+
response = @compute.get_device(@@device["id"])
|
|
28
|
+
break if response.body["state"] == "active"
|
|
29
|
+
sleep(3)
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
options = {
|
|
33
|
+
:project_id => @project_id,
|
|
34
|
+
:description => "test",
|
|
35
|
+
:facility => "ewr1",
|
|
36
|
+
:vlan => 1,
|
|
37
|
+
:vxlan => 1
|
|
38
|
+
}
|
|
39
|
+
response = @compute.create_virtual_network(options)
|
|
40
|
+
|
|
41
|
+
assert_equal 201, response.status
|
|
42
|
+
assert_equal options[:description], response.body["description"]
|
|
43
|
+
|
|
44
|
+
@@virtual_network_id = response.body["id"]
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
def test_request_b_list_virtual_networks
|
|
48
|
+
response = @compute.list_virtual_networks(@project_id)
|
|
49
|
+
|
|
50
|
+
assert_equal 200, response.status
|
|
51
|
+
assert !response.body["virtual_networks"].empty?
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
def test_request_d_bond_ports
|
|
55
|
+
response = @compute.bond_ports(@@virtual_network_id, true)
|
|
56
|
+
assert_equal 200, response.status
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def test_request_e_disbond_ports
|
|
60
|
+
response = @compute.disbond_ports(@@virtual_network_id, true)
|
|
61
|
+
assert_equal 200, response.status
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def test_request_f_assign_port
|
|
65
|
+
eth1 = ""
|
|
66
|
+
@@device["provisioning_events"].each do |port|
|
|
67
|
+
next unless port["network_ports"]
|
|
68
|
+
port["network_ports"].each do |np|
|
|
69
|
+
eth1 = np["id"] if np["name"] == "eth1"
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
response = @compute.assign_port(eth1, @@virtual_network_id)
|
|
73
|
+
|
|
74
|
+
assert_equal 200, response.status
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
def test_request_g_unassign_port
|
|
78
|
+
eth1 = ""
|
|
79
|
+
|
|
80
|
+
@@device["provisioning_events"].each do |port|
|
|
81
|
+
next unless port["network_ports"]
|
|
82
|
+
port["network_ports"].each do |np|
|
|
83
|
+
eth1 = np["id"] if np["name"] == "eth1"
|
|
84
|
+
end
|
|
85
|
+
end
|
|
86
|
+
response = @compute.unassign_port(eth1, @@virtual_network_id)
|
|
87
|
+
|
|
88
|
+
assert_equal 200, response.status
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
def test_request_h_delete_virtual_network
|
|
92
|
+
response = @compute.delete_virtual_network(@@virtual_network_id)
|
|
93
|
+
|
|
94
|
+
assert_equal 204, response.status
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
def test_request_i_cleanup
|
|
98
|
+
@compute.delete_device(@@device["id"])
|
|
99
|
+
end
|
|
100
|
+
end
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
require_relative "../../../lib/fog-packet"
|
|
2
|
+
|
|
3
|
+
# TestVolumes
|
|
4
|
+
class TestVolumes < Minitest::Test
|
|
5
|
+
def self.test_order
|
|
6
|
+
:alpha
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def setup
|
|
10
|
+
# Establish Connection
|
|
11
|
+
@compute = Fog::Compute::Packet.new(:packet_token => ENV["PACKET_TOKEN"])
|
|
12
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def test_request_a_create_volume
|
|
16
|
+
dev = {
|
|
17
|
+
:hostname => "test01",
|
|
18
|
+
:facility => "ewr1",
|
|
19
|
+
:plan => "baremetal_0",
|
|
20
|
+
:operating_system => "coreos_stable"
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
response = @compute.create_device(@project_id, dev)
|
|
24
|
+
|
|
25
|
+
@@device_id = response.body["id"]
|
|
26
|
+
|
|
27
|
+
loop do
|
|
28
|
+
response = @compute.get_device(@@device_id)
|
|
29
|
+
break if response.body["state"] == "active"
|
|
30
|
+
sleep(3)
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
options = {
|
|
34
|
+
:facility => "ewr1",
|
|
35
|
+
:plan => "storage_1",
|
|
36
|
+
:size => 20,
|
|
37
|
+
:description => "test description",
|
|
38
|
+
:billing_cycle => "hourly"
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
response = @compute.create_volume(@project_id, options)
|
|
42
|
+
|
|
43
|
+
assert_equal response.status, 201
|
|
44
|
+
@@volume_id = response.body["id"]
|
|
45
|
+
|
|
46
|
+
loop do
|
|
47
|
+
response = @compute.get_volume(@@volume_id)
|
|
48
|
+
break if response.body["state"] == "active"
|
|
49
|
+
sleep(3)
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def test_request_b_get_volume
|
|
54
|
+
response = @compute.get_volume(@@volume_id)
|
|
55
|
+
|
|
56
|
+
assert_equal response.status, 200
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def test_request_c_update_volume
|
|
60
|
+
options = {
|
|
61
|
+
:size => 30
|
|
62
|
+
}
|
|
63
|
+
response = @compute.update_volume(@@volume_id, options)
|
|
64
|
+
|
|
65
|
+
assert_equal response.status, 200
|
|
66
|
+
assert_equal response.body["size"], options[:size]
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
def test_request_d_list_volumes
|
|
70
|
+
response = @compute.list_volumes(@project_id)
|
|
71
|
+
|
|
72
|
+
assert !response.body["volumes"].empty?
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
def test_request_e_attach_volume
|
|
76
|
+
response = @compute.attach_volume(@@volume_id, @@device_id)
|
|
77
|
+
@@attachment_id = response.body["id"]
|
|
78
|
+
|
|
79
|
+
assert_equal 201, response.status
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
def test_request_f_detach_volume
|
|
83
|
+
response = @compute.detach_volume(@@attachment_id)
|
|
84
|
+
assert_equal 204, response.status
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
def test_request_g_delete_volume
|
|
88
|
+
response = @compute.delete_volume(@@volume_id)
|
|
89
|
+
assert_equal response.status, 204
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
def test_request_h_cleanup
|
|
93
|
+
@compute.delete_device(@@device_id)
|
|
94
|
+
end
|
|
95
|
+
end
|