fog-packet 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- 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,66 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Packet
|
4
|
+
# Real
|
5
|
+
class Real
|
6
|
+
def update_volume(volume_id, options)
|
7
|
+
device = Hash.new {}
|
8
|
+
device["description"] = options[:description] if options[:description]
|
9
|
+
device["billing_cycle"] = options[:billing_cycle] if options[:billing_cycle]
|
10
|
+
device["size"] = options[:size] if options[:size]
|
11
|
+
device["locked"] = options[:locked] if options[:locked]
|
12
|
+
|
13
|
+
request(
|
14
|
+
:expects => [200],
|
15
|
+
:method => "PUT",
|
16
|
+
:path => "/storage/" + volume_id,
|
17
|
+
:body => Fog::JSON.encode(device)
|
18
|
+
)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
# Mock
|
23
|
+
class Mock
|
24
|
+
def update_volume(volume_id, options)
|
25
|
+
response = Excon::Response.new
|
26
|
+
response.status = 200
|
27
|
+
response.body = {
|
28
|
+
"id" => volume_id,
|
29
|
+
"name" => "volume-870f9650",
|
30
|
+
"description" => "test description",
|
31
|
+
"size" => options[:size],
|
32
|
+
"locked" => false,
|
33
|
+
"billing_cycle" => "hourly",
|
34
|
+
"state" => "active",
|
35
|
+
"created_at" => "2018-03-08T12:49:30Z",
|
36
|
+
"updated_at" => "2018-03-08T12:49:30.682Z",
|
37
|
+
"access" => {},
|
38
|
+
"project" => {
|
39
|
+
"href" => "/projects/93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
40
|
+
},
|
41
|
+
"facility" => {
|
42
|
+
"href" => "/facilities/e1e9c52e-a0bc-4117-b996-0fc94843ea09"
|
43
|
+
},
|
44
|
+
"snapshot_policies" => [],
|
45
|
+
"attachments" => [],
|
46
|
+
"snapshots" => [],
|
47
|
+
"plan" => {
|
48
|
+
"id" => "87728148-3155-4992-a730-8d1e6aca8a32",
|
49
|
+
"slug" => "storage_1",
|
50
|
+
"name" => "Standard",
|
51
|
+
"description" => "TBD",
|
52
|
+
"line" => "storage",
|
53
|
+
"specs" => {},
|
54
|
+
"available_in" => [],
|
55
|
+
"pricing" => {
|
56
|
+
"hour" => 0.000104
|
57
|
+
}
|
58
|
+
},
|
59
|
+
"href" => "/storage/870f9650-19ea-48bd-84c5-ddf97471c1c1"
|
60
|
+
}
|
61
|
+
response
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Packet
|
4
|
+
# Real
|
5
|
+
class Real
|
6
|
+
def validate_capacity(options)
|
7
|
+
cap = {
|
8
|
+
"servers" => []
|
9
|
+
}
|
10
|
+
options[:servers].each do |server|
|
11
|
+
srv = {}
|
12
|
+
srv["facility"] = server[:facility] if server[:facility]
|
13
|
+
srv["plan"] = server[:plan] if server[:plan]
|
14
|
+
srv["quantity"] = server[:quantity] if server[:quantity]
|
15
|
+
|
16
|
+
cap["servers"] << srv
|
17
|
+
end
|
18
|
+
|
19
|
+
request(
|
20
|
+
:expects => [204],
|
21
|
+
:method => "POST",
|
22
|
+
:path => "/capacity",
|
23
|
+
:body => Fog::JSON.encode(cap)
|
24
|
+
)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
# Mock
|
29
|
+
class Mock
|
30
|
+
def validate_capacity(_options)
|
31
|
+
response = Excon::Response.new
|
32
|
+
response.status = 204
|
33
|
+
response
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Packet
|
4
|
+
# Real
|
5
|
+
class Real
|
6
|
+
def verify_email(token)
|
7
|
+
request(
|
8
|
+
:expects => [200],
|
9
|
+
:method => "POST",
|
10
|
+
:path => "/verify-email?token=" + token
|
11
|
+
)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
# Mock
|
16
|
+
class Mock
|
17
|
+
def verify_email(_token)
|
18
|
+
response = Excon::Response.new
|
19
|
+
response.status = 200
|
20
|
+
response.body = {
|
21
|
+
"id" => "25a602c3-76b9-4de7-8b06-10d277f2a03b",
|
22
|
+
"token" => "aE5Ye1evHw5ds8CrFB9mYf7qS3JZQ6my",
|
23
|
+
"expires_at" => "2018-04-13T10:50:26Z",
|
24
|
+
"created_at" => "2018-04-12T10:50:26Z",
|
25
|
+
"updated_at" => "2018-04-12T10:50:26Z",
|
26
|
+
"user" => {
|
27
|
+
"href" => "/users/dbb25187-2f7e-4d53-a6de-d7b3e2b6d2ba"
|
28
|
+
},
|
29
|
+
"read_only" => false
|
30
|
+
}
|
31
|
+
response
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestBatches
|
4
|
+
class TestBatches < 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
|
+
|
12
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_create_batch
|
16
|
+
batches = [{
|
17
|
+
:hostname => "test1",
|
18
|
+
:description => "test batch",
|
19
|
+
:plan => "baremetal_0",
|
20
|
+
:operating_system => "coreos_stable",
|
21
|
+
:facility => "ewr1",
|
22
|
+
:billing_cycle => "hourly",
|
23
|
+
:tags => ["abc"],
|
24
|
+
:quantity => 1
|
25
|
+
}]
|
26
|
+
|
27
|
+
response = @compute.batches.create(@project_id, :batches => batches)
|
28
|
+
|
29
|
+
assert !response.empty?
|
30
|
+
|
31
|
+
@@batch_id = response[0].id
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_get_batch
|
35
|
+
response = @compute.batches.get(@@batch_id)
|
36
|
+
|
37
|
+
assert_equal @@batch_id, response.id
|
38
|
+
end
|
39
|
+
|
40
|
+
def test_list_batches
|
41
|
+
response = @compute.batches.all(@project_id)
|
42
|
+
|
43
|
+
assert !response.empty?
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestBGPSessions
|
4
|
+
class TestBGPSessions < 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
|
+
@project_id = "93125c2a-8b78-4d4f-a3c4-7367d6b7cca8"
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_a_create_bgp_session
|
15
|
+
device = @compute.devices.create(:project_id => @project_id, :facility => "ewr1", :plan => "baremetal_0", :hostname => "test01", :operating_system => "coreos_stable")
|
16
|
+
@@device_id = device.id
|
17
|
+
|
18
|
+
device.wait_for { ready? }
|
19
|
+
|
20
|
+
# Perform Request
|
21
|
+
address_family = "ipv4"
|
22
|
+
response = @compute.bgp_sessions.create(:device_id => @@device_id, :address_family => address_family)
|
23
|
+
|
24
|
+
# Assertions
|
25
|
+
assert_equal address_family, response.address_family
|
26
|
+
|
27
|
+
@@session_id = response.id
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_b_get_bgp_session
|
31
|
+
response = @compute.bgp_sessions.get(@@session_id)
|
32
|
+
|
33
|
+
assert_equal @@session_id, response.id
|
34
|
+
end
|
35
|
+
|
36
|
+
def test_d_list_bgp_sessions
|
37
|
+
response = @compute.bgp_sessions.all(@@device_id)
|
38
|
+
|
39
|
+
assert !response.empty?
|
40
|
+
end
|
41
|
+
|
42
|
+
def test_e_delete_bgp_session
|
43
|
+
session = @compute.bgp_sessions.get(@@session_id)
|
44
|
+
|
45
|
+
response = session.destroy
|
46
|
+
assert_equal true, response
|
47
|
+
end
|
48
|
+
|
49
|
+
def test_z_cleanup
|
50
|
+
@compute.delete_device(@@device_id)
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestCapacity
|
4
|
+
class TestCapacity < 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_get_capacity
|
15
|
+
response = @compute.capacities.all
|
16
|
+
|
17
|
+
assert response
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_request_validate_capacity
|
21
|
+
options = {
|
22
|
+
:servers => [
|
23
|
+
{
|
24
|
+
:facility => "ewr1",
|
25
|
+
:plan => "baremetal_2a",
|
26
|
+
:quantity => 1
|
27
|
+
},
|
28
|
+
{
|
29
|
+
:facility => "atl1",
|
30
|
+
:plan => "baremetal_1e",
|
31
|
+
:quantity => 1
|
32
|
+
}
|
33
|
+
]
|
34
|
+
}
|
35
|
+
|
36
|
+
response = @compute.capacities.validate(options)
|
37
|
+
|
38
|
+
assert_equal true, response
|
39
|
+
end
|
40
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestDevices
|
4
|
+
class TestDevices < 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_a_create_device
|
16
|
+
device = @compute.devices.create(:project_id => @project_id, :facility => "ewr1", :plan => "baremetal_0", :hostname => "test01", :operating_system => "coreos_stable")
|
17
|
+
|
18
|
+
assert_equal "test01", device.hostname
|
19
|
+
|
20
|
+
@@device_id = device.id
|
21
|
+
|
22
|
+
Fog.timeout = 1200
|
23
|
+
device.wait_for { ready? }
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_b_list_device
|
27
|
+
devices = @compute.devices.all(@project_id, :per_page => 1, :page => 1, :include => "project")
|
28
|
+
|
29
|
+
assert !devices.empty?
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_c_get_device
|
33
|
+
device = @compute.devices.get(@@device_id)
|
34
|
+
|
35
|
+
assert_equal @@device_id, device.id
|
36
|
+
end
|
37
|
+
|
38
|
+
def test_d_update_device
|
39
|
+
device = @compute.devices.get(@@device_id)
|
40
|
+
device.hostname = "test02"
|
41
|
+
device.update
|
42
|
+
|
43
|
+
assert_equal "test02", device.hostname
|
44
|
+
end
|
45
|
+
|
46
|
+
def test_e_reboot_device
|
47
|
+
device = @compute.devices.get(@@device_id)
|
48
|
+
response = device.reboot
|
49
|
+
|
50
|
+
assert_equal true, response
|
51
|
+
|
52
|
+
device.wait_for { ready? }
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_f_poweroff_device
|
56
|
+
device = @compute.devices.get(@@device_id)
|
57
|
+
|
58
|
+
response = device.stop
|
59
|
+
assert_equal true, response
|
60
|
+
|
61
|
+
device.wait_for { inactive? } unless Fog.mock?
|
62
|
+
end
|
63
|
+
|
64
|
+
def test_g_poweron_device
|
65
|
+
sleep(30) unless Fog.mock?
|
66
|
+
|
67
|
+
device = @compute.devices.get(@@device_id)
|
68
|
+
|
69
|
+
response = device.start
|
70
|
+
|
71
|
+
assert_equal true, response
|
72
|
+
|
73
|
+
device.wait_for { ready? } unless Fog.mock?
|
74
|
+
end
|
75
|
+
|
76
|
+
def test_h_get_events
|
77
|
+
events = @compute.events.all(@@device_id)
|
78
|
+
|
79
|
+
assert !events.empty?
|
80
|
+
end
|
81
|
+
|
82
|
+
def test_i_get_bandwidth
|
83
|
+
response = @compute.bandwidth.get(@@device_id, :to => "12-12-2017", :from => "11-11-2017")
|
84
|
+
|
85
|
+
assert_equal 200, response.status
|
86
|
+
end
|
87
|
+
|
88
|
+
def test_z_delete_device
|
89
|
+
device = @compute.devices.get(@@device_id)
|
90
|
+
result = device.destroy
|
91
|
+
assert_equal true, result
|
92
|
+
end
|
93
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestEmailVerification
|
4
|
+
class TestEmailVerification < 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_email_verification
|
15
|
+
response = @compute.email_verification.request("jdoe@example.net")
|
16
|
+
|
17
|
+
assert_equal true, response
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_verify_email
|
21
|
+
response = @compute.email_verification.verify("token1234!")
|
22
|
+
|
23
|
+
assert_equal true, response
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require_relative "../../test_helper.rb"
|
2
|
+
|
3
|
+
# TestEmails
|
4
|
+
class TestEmails < 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_a_create_email
|
15
|
+
# Perform Request
|
16
|
+
email = @compute.emails.create(:address => "jdoe@example.net", :default => false)
|
17
|
+
|
18
|
+
# Assertions
|
19
|
+
@@email_id = email.id
|
20
|
+
assert_equal "jdoe@example.net", email.address
|
21
|
+
assert_equal false, email.default
|
22
|
+
end
|
23
|
+
|
24
|
+
def test_b_get_email
|
25
|
+
response = @compute.emails.get(@@email_id)
|
26
|
+
|
27
|
+
assert_equal @@email_id, response.id
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_c_update_email
|
31
|
+
email = @compute.emails.get(@@email_id)
|
32
|
+
|
33
|
+
email.default = false
|
34
|
+
email.update
|
35
|
+
|
36
|
+
assert_equal @@email_id, email.id
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_e_delete_email
|
40
|
+
email = @compute.emails.get(@@email_id)
|
41
|
+
|
42
|
+
response = email.destroy
|
43
|
+
assert_equal true, response
|
44
|
+
end
|
45
|
+
end
|