fog-atmos 0.0.1
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 +23 -0
- data/.rubocop.yml +20 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/.travis.yml +17 -0
- data/CONTRIBUTING.md +18 -0
- data/CONTRIBUTORS.md +10 -0
- data/Gemfile +4 -0
- data/LICENSE.md +20 -0
- data/README.md +38 -0
- data/Rakefile +18 -0
- data/fog-atmos.gemspec +35 -0
- data/gemfiles/Gemfile.1.9.2- +8 -0
- data/gemfiles/Gemfile.1.9.3+ +7 -0
- data/lib/fog/atmos.rb +15 -0
- data/lib/fog/atmos/storage.rb +0 -0
- data/lib/fog/atmos/version.rb +5 -0
- data/lib/fog/storage/atmos.rb +187 -0
- data/lib/fog/storage/atmos/models/directories.rb +41 -0
- data/lib/fog/storage/atmos/models/directory.rb +46 -0
- data/lib/fog/storage/atmos/models/file.rb +106 -0
- data/lib/fog/storage/atmos/models/files.rb +71 -0
- data/lib/fog/storage/atmos/requests/delete_namespace.rb +17 -0
- data/lib/fog/storage/atmos/requests/get_namespace.rb +23 -0
- data/lib/fog/storage/atmos/requests/head_namespace.rb +18 -0
- data/lib/fog/storage/atmos/requests/post_namespace.rb +18 -0
- data/lib/fog/storage/atmos/requests/put_namespace.rb +18 -0
- data/tests/helper.rb +36 -0
- data/tests/helpers/collection_helper.rb +97 -0
- data/tests/helpers/compute/flavors_helper.rb +32 -0
- data/tests/helpers/compute/server_helper.rb +25 -0
- data/tests/helpers/compute/servers_helper.rb +10 -0
- data/tests/helpers/formats_helper.rb +98 -0
- data/tests/helpers/formats_helper_tests.rb +110 -0
- data/tests/helpers/mock_helper.rb +117 -0
- data/tests/helpers/model_helper.rb +31 -0
- data/tests/helpers/responds_to_helper.rb +11 -0
- data/tests/helpers/schema_validator_tests.rb +107 -0
- data/tests/helpers/succeeds_helper.rb +9 -0
- data/tests/models/storage/file_update_tests.rb +19 -0
- data/tests/models/storage/nested_directories_tests.rb +23 -0
- metadata +213 -0
@@ -0,0 +1,32 @@
|
|
1
|
+
def flavors_tests(connection, params = {}, mocks_implemented = true)
|
2
|
+
tests('success') do
|
3
|
+
|
4
|
+
tests("#all").succeeds do
|
5
|
+
pending if Fog.mocking? && !mocks_implemented
|
6
|
+
connection.flavors.all
|
7
|
+
end
|
8
|
+
|
9
|
+
if !Fog.mocking? || mocks_implemented
|
10
|
+
@identity = connection.flavors.first.identity
|
11
|
+
end
|
12
|
+
|
13
|
+
tests("#get('#{@identity}')").succeeds do
|
14
|
+
pending if Fog.mocking? && !mocks_implemented
|
15
|
+
connection.flavors.get(@identity)
|
16
|
+
end
|
17
|
+
|
18
|
+
end
|
19
|
+
|
20
|
+
tests('failure') do
|
21
|
+
|
22
|
+
if !Fog.mocking? || mocks_implemented
|
23
|
+
invalid_flavor_identity = connection.flavors.first.identity.to_s.gsub(/\w/, '0')
|
24
|
+
end
|
25
|
+
|
26
|
+
tests("#get('#{invalid_flavor_identity}')").returns(nil) do
|
27
|
+
pending if Fog.mocking? && !mocks_implemented
|
28
|
+
connection.flavors.get(invalid_flavor_identity)
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
def server_tests(connection, params = {}, mocks_implemented = true)
|
2
|
+
model_tests(connection.servers, params, mocks_implemented) do
|
3
|
+
|
4
|
+
tests('#reload').returns(true) do
|
5
|
+
pending if Fog.mocking? && !mocks_implemented
|
6
|
+
@instance.wait_for { ready? }
|
7
|
+
identity = @instance.identity
|
8
|
+
!identity.nil? && identity == @instance.reload.identity
|
9
|
+
end
|
10
|
+
|
11
|
+
responds_to([:ready?, :state])
|
12
|
+
yield if block_given?
|
13
|
+
|
14
|
+
tests('#reboot').succeeds do
|
15
|
+
pending if Fog.mocking? && !mocks_implemented
|
16
|
+
@instance.wait_for { ready? }
|
17
|
+
@instance.reboot
|
18
|
+
end
|
19
|
+
|
20
|
+
if !Fog.mocking? || mocks_implemented
|
21
|
+
@instance.wait_for { ready? }
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,98 @@
|
|
1
|
+
require "fog/schema/data_validator"
|
2
|
+
|
3
|
+
# format related hackery
|
4
|
+
# allows both true.is_a?(Fog::Boolean) and false.is_a?(Fog::Boolean)
|
5
|
+
# allows both nil.is_a?(Fog::Nullable::String) and ''.is_a?(Fog::Nullable::String)
|
6
|
+
module Fog
|
7
|
+
module Boolean; end
|
8
|
+
module Nullable
|
9
|
+
module Boolean; end
|
10
|
+
module Integer; end
|
11
|
+
module String; end
|
12
|
+
module Time; end
|
13
|
+
module Float; end
|
14
|
+
module Hash; end
|
15
|
+
module Array; end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
[FalseClass, TrueClass].each {|klass| klass.send(:include, Fog::Boolean)}
|
19
|
+
[FalseClass, TrueClass, NilClass, Fog::Boolean].each {|klass| klass.send(:include, Fog::Nullable::Boolean)}
|
20
|
+
[NilClass, String].each {|klass| klass.send(:include, Fog::Nullable::String)}
|
21
|
+
[NilClass, Time].each {|klass| klass.send(:include, Fog::Nullable::Time)}
|
22
|
+
[Integer, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Integer)}
|
23
|
+
[Float, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Float)}
|
24
|
+
[Hash, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Hash)}
|
25
|
+
[Array, NilClass].each {|klass| klass.send(:include, Fog::Nullable::Array)}
|
26
|
+
|
27
|
+
module Shindo
|
28
|
+
class Tests
|
29
|
+
# Generates a Shindo test that compares a hash schema to the result
|
30
|
+
# of the passed in block returning true if they match.
|
31
|
+
#
|
32
|
+
# The schema that is passed in is a Hash or Array of hashes that
|
33
|
+
# have Classes in place of values. When checking the schema the
|
34
|
+
# value should match the Class.
|
35
|
+
#
|
36
|
+
# Strict mode will fail if the data has additional keys. Setting
|
37
|
+
# +strict+ to +false+ will allow additional keys to appear.
|
38
|
+
#
|
39
|
+
# @param [Hash] schema A Hash schema
|
40
|
+
# @param [Hash] options Options to change validation rules
|
41
|
+
# @option options [Boolean] :allow_extra_keys
|
42
|
+
# If +true+ does not fail when keys are in the data that are
|
43
|
+
# not specified in the schema. This allows new values to
|
44
|
+
# appear in API output without breaking the check.
|
45
|
+
# @option options [Boolean] :allow_optional_rules
|
46
|
+
# If +true+ does not fail if extra keys are in the schema
|
47
|
+
# that do not match the data. Not recommended!
|
48
|
+
# @yield Data to check with schema
|
49
|
+
#
|
50
|
+
# @example Using in a test
|
51
|
+
# Shindo.tests("comparing welcome data against schema") do
|
52
|
+
# data = {:welcome => "Hello" }
|
53
|
+
# data_matches_schema(:welcome => String) { data }
|
54
|
+
# end
|
55
|
+
#
|
56
|
+
# comparing welcome data against schema
|
57
|
+
# + data matches schema
|
58
|
+
#
|
59
|
+
# @example Example schema
|
60
|
+
# {
|
61
|
+
# "id" => String,
|
62
|
+
# "ram" => Integer,
|
63
|
+
# "disks" => [
|
64
|
+
# {
|
65
|
+
# "size" => Float
|
66
|
+
# }
|
67
|
+
# ],
|
68
|
+
# "dns_name" => Fog::Nullable::String,
|
69
|
+
# "active" => Fog::Boolean,
|
70
|
+
# "created" => DateTime
|
71
|
+
# }
|
72
|
+
#
|
73
|
+
# @return [Boolean]
|
74
|
+
def data_matches_schema(schema, options = {})
|
75
|
+
test('data matches schema') do
|
76
|
+
validator = Fog::Schema::DataValidator.new
|
77
|
+
valid = validator.validate(yield, schema, options)
|
78
|
+
@message = validator.message unless valid
|
79
|
+
valid
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
# @deprecated #formats is deprecated. Use #data_matches_schema instead
|
84
|
+
def formats(format, strict = true)
|
85
|
+
test('has proper format') do
|
86
|
+
if strict
|
87
|
+
options = {:allow_extra_keys => false, :allow_optional_rules => true}
|
88
|
+
else
|
89
|
+
options = {:allow_extra_keys => true, :allow_optional_rules => true}
|
90
|
+
end
|
91
|
+
validator = Fog::Schema::DataValidator.new
|
92
|
+
valid = validator.validate(yield, format, options)
|
93
|
+
@message = validator.message unless valid
|
94
|
+
valid
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
@@ -0,0 +1,110 @@
|
|
1
|
+
Shindo.tests('test_helper', 'meta') do
|
2
|
+
|
3
|
+
tests('comparing welcome data against schema') do
|
4
|
+
data = {:welcome => "Hello" }
|
5
|
+
data_matches_schema(:welcome => String) { data }
|
6
|
+
end
|
7
|
+
|
8
|
+
tests('#data_matches_schema') do
|
9
|
+
tests('when value matches schema expectation') do
|
10
|
+
data_matches_schema({"key" => String}) { {"key" => "Value"} }
|
11
|
+
end
|
12
|
+
|
13
|
+
tests('when values within an array all match schema expectation') do
|
14
|
+
data_matches_schema({"key" => [Integer]}) { {"key" => [1, 2]} }
|
15
|
+
end
|
16
|
+
|
17
|
+
tests('when nested values match schema expectation') do
|
18
|
+
data_matches_schema({"key" => {:nested_key => String}}) { {"key" => {:nested_key => "Value"}} }
|
19
|
+
end
|
20
|
+
|
21
|
+
tests('when collection of values all match schema expectation') do
|
22
|
+
data_matches_schema([{"key" => String}]) { [{"key" => "Value"}, {"key" => "Value"}] }
|
23
|
+
end
|
24
|
+
|
25
|
+
tests('when collection is empty although schema covers optional members') do
|
26
|
+
data_matches_schema([{"key" => String}], {:allow_optional_rules => true}) { [] }
|
27
|
+
end
|
28
|
+
|
29
|
+
tests('when additional keys are passed and not strict') do
|
30
|
+
data_matches_schema({"key" => String}, {:allow_extra_keys => true}) { {"key" => "Value", :extra => "Bonus"} }
|
31
|
+
end
|
32
|
+
|
33
|
+
tests('when value is nil and schema expects NilClass') do
|
34
|
+
data_matches_schema({"key" => NilClass}) { {"key" => nil} }
|
35
|
+
end
|
36
|
+
|
37
|
+
tests('when value and schema match as hashes') do
|
38
|
+
data_matches_schema({}) { {} }
|
39
|
+
end
|
40
|
+
|
41
|
+
tests('when value and schema match as arrays') do
|
42
|
+
data_matches_schema([]) { [] }
|
43
|
+
end
|
44
|
+
|
45
|
+
tests('when value is a Time') do
|
46
|
+
data_matches_schema({"time" => Time}) { {"time" => Time.now} }
|
47
|
+
end
|
48
|
+
|
49
|
+
tests('when key is missing but value should be NilClass (#1477)') do
|
50
|
+
data_matches_schema({"key" => NilClass}, {:allow_optional_rules => true}) { {} }
|
51
|
+
end
|
52
|
+
|
53
|
+
tests('when key is missing but value is nullable (#1477)') do
|
54
|
+
data_matches_schema({"key" => Fog::Nullable::String}, {:allow_optional_rules => true}) { {} }
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
tests('#formats backwards compatible changes') do
|
59
|
+
|
60
|
+
tests('when value matches schema expectation') do
|
61
|
+
formats({"key" => String}) { {"key" => "Value"} }
|
62
|
+
end
|
63
|
+
|
64
|
+
tests('when values within an array all match schema expectation') do
|
65
|
+
formats({"key" => [Integer]}) { {"key" => [1, 2]} }
|
66
|
+
end
|
67
|
+
|
68
|
+
tests('when nested values match schema expectation') do
|
69
|
+
formats({"key" => {:nested_key => String}}) { {"key" => {:nested_key => "Value"}} }
|
70
|
+
end
|
71
|
+
|
72
|
+
tests('when collection of values all match schema expectation') do
|
73
|
+
formats([{"key" => String}]) { [{"key" => "Value"}, {"key" => "Value"}] }
|
74
|
+
end
|
75
|
+
|
76
|
+
tests('when collection is empty although schema covers optional members') do
|
77
|
+
formats([{"key" => String}]) { [] }
|
78
|
+
end
|
79
|
+
|
80
|
+
tests('when additional keys are passed and not strict') do
|
81
|
+
formats({"key" => String}, false) { {"key" => "Value", :extra => "Bonus"} }
|
82
|
+
end
|
83
|
+
|
84
|
+
tests('when value is nil and schema expects NilClass') do
|
85
|
+
formats({"key" => NilClass}) { {"key" => nil} }
|
86
|
+
end
|
87
|
+
|
88
|
+
tests('when value and schema match as hashes') do
|
89
|
+
formats({}) { {} }
|
90
|
+
end
|
91
|
+
|
92
|
+
tests('when value and schema match as arrays') do
|
93
|
+
formats([]) { [] }
|
94
|
+
end
|
95
|
+
|
96
|
+
tests('when value is a Time') do
|
97
|
+
formats({"time" => Time}) { {"time" => Time.now} }
|
98
|
+
end
|
99
|
+
|
100
|
+
tests('when key is missing but value should be NilClass (#1477)') do
|
101
|
+
formats({"key" => NilClass}) { {} }
|
102
|
+
end
|
103
|
+
|
104
|
+
tests('when key is missing but value is nullable (#1477)') do
|
105
|
+
formats({"key" => Fog::Nullable::String}) { {} }
|
106
|
+
end
|
107
|
+
|
108
|
+
end
|
109
|
+
|
110
|
+
end
|
@@ -0,0 +1,117 @@
|
|
1
|
+
# Use so you can run in mock mode from the command line
|
2
|
+
#
|
3
|
+
# FOG_MOCK=true fog
|
4
|
+
|
5
|
+
if ENV["FOG_MOCK"] == "true"
|
6
|
+
Fog.mock!
|
7
|
+
end
|
8
|
+
|
9
|
+
# if in mocked mode, fill in some fake credentials for us
|
10
|
+
if Fog.mock?
|
11
|
+
Fog.credentials = {
|
12
|
+
:aws_access_key_id => 'aws_access_key_id',
|
13
|
+
:aws_secret_access_key => 'aws_secret_access_key',
|
14
|
+
:ia_access_key_id => 'aws_access_key_id',
|
15
|
+
:ia_secret_access_key => 'aws_secret_access_key',
|
16
|
+
:atmos_storage_token => 'atmos_token',
|
17
|
+
:atmos_storage_secret => 'atmos_secret',
|
18
|
+
:atmos_storage_endpoint => 'http://atmos.is.cool:1000/test1.0',
|
19
|
+
:bluebox_api_key => 'bluebox_api_key',
|
20
|
+
:bluebox_customer_id => 'bluebox_customer_id',
|
21
|
+
:brightbox_client_id => 'brightbox_client_id',
|
22
|
+
:brightbox_secret => 'brightbox_secret',
|
23
|
+
:cloudstack_disk_offering_id => '',
|
24
|
+
:cloudstack_host => 'http://cloudstack.example.org',
|
25
|
+
:cloudstack_network_ids => '',
|
26
|
+
:cloudstack_service_offering_id => '4437ac6c-9fe3-477a-57ec-60a5a45896a4',
|
27
|
+
:cloudstack_template_id => '8a31cf9c-f248-0588-256e-9dbf58785216',
|
28
|
+
:cloudstack_zone_id => 'c554c592-e09c-9df5-7688-4a32754a4305',
|
29
|
+
:clodo_api_key => 'clodo_api_key',
|
30
|
+
:clodo_username => 'clodo_username',
|
31
|
+
:digitalocean_api_key => 'digitalocean_api_key',
|
32
|
+
:digitalocean_client_id => 'digitalocean_client_id',
|
33
|
+
:dnsimple_email => 'dnsimple_email',
|
34
|
+
:dnsimple_password => 'dnsimple_password',
|
35
|
+
:dnsmadeeasy_api_key => 'dnsmadeeasy_api_key',
|
36
|
+
:dnsmadeeasy_secret_key => 'dnsmadeeasy_secret_key',
|
37
|
+
:ecloud_username => 'ecloud_username',
|
38
|
+
:ecloud_password => 'ecloud_password',
|
39
|
+
:ecloud_versions_uri => 'http://ecloud.versions.uri',
|
40
|
+
:glesys_username => 'glesys_username',
|
41
|
+
:glesys_api_key => 'glesys_api_key',
|
42
|
+
:go_grid_api_key => 'go_grid_api_key',
|
43
|
+
:go_grid_shared_secret => 'go_grid_shared_secret',
|
44
|
+
:google_storage_access_key_id => 'google_storage_access_key_id',
|
45
|
+
:google_storage_secret_access_key => 'google_storage_secret_access_key',
|
46
|
+
:google_project => 'google_project_name',
|
47
|
+
:google_client_email => 'fake@developer.gserviceaccount.com',
|
48
|
+
:google_key_location => '~/fake.p12',
|
49
|
+
:hp_access_key => 'hp_access_key',
|
50
|
+
:hp_secret_key => 'hp_secret_key',
|
51
|
+
:hp_tenant_id => 'hp_tenant_id',
|
52
|
+
:hp_avl_zone => 'hp_avl_zone',
|
53
|
+
:os_account_meta_temp_url_key => 'os_account_meta_temp_url_key',
|
54
|
+
:ibm_username => 'ibm_username',
|
55
|
+
:ibm_password => 'ibm_password',
|
56
|
+
:joyent_username => "joyentuser",
|
57
|
+
:joyent_password => "joyentpass",
|
58
|
+
:linode_api_key => 'linode_api_key',
|
59
|
+
:local_root => '~/.fog',
|
60
|
+
:bare_metal_cloud_password => 'bare_metal_cloud_password',
|
61
|
+
:bare_metal_cloud_username => 'bare_metal_cloud_username',
|
62
|
+
:ninefold_compute_key => 'ninefold_compute_key',
|
63
|
+
:ninefold_compute_secret => 'ninefold_compute_secret',
|
64
|
+
:ninefold_storage_secret => 'ninefold_storage_secret',
|
65
|
+
:ninefold_storage_token => 'ninefold_storage_token',
|
66
|
+
# :public_key_path => '~/.ssh/id_rsa.pub',
|
67
|
+
# :private_key_path => '~/.ssh/id_rsa',
|
68
|
+
:opennebula_endpoint => 'http://opennebula:2633/RPC2',
|
69
|
+
:opennebula_username => 'oneadmin',
|
70
|
+
:opennebula_password => 'oneadmin',
|
71
|
+
:openstack_api_key => 'openstack_api_key',
|
72
|
+
:openstack_username => 'openstack_username',
|
73
|
+
:openstack_tenant => 'openstack_tenant',
|
74
|
+
:openstack_auth_url => 'http://openstack:35357/v2.0/tokens',
|
75
|
+
:ovirt_url => 'http://ovirt:8080/api',
|
76
|
+
:ovirt_username => 'admin@internal',
|
77
|
+
:ovirt_password => '123123',
|
78
|
+
:profitbricks_username => 'profitbricks_username',
|
79
|
+
:profitbricks_password => 'profitbricks_password',
|
80
|
+
:libvirt_uri => 'qemu://libvirt/system',
|
81
|
+
:rackspace_api_key => 'rackspace_api_key',
|
82
|
+
:rackspace_region => 'dfw',
|
83
|
+
:rackspace_username => 'rackspace_username',
|
84
|
+
:riakcs_access_key_id => 'riakcs_access_key_id',
|
85
|
+
:riakcs_secret_access_key => 'riakcs_secret_access_key',
|
86
|
+
:sakuracloud_api_token => 'sakuracloud_api_token',
|
87
|
+
:sakuracloud_api_token_secret => 'sakuracloud_api_token_secret',
|
88
|
+
:storm_on_demand_username => 'storm_on_demand_username',
|
89
|
+
:storm_on_demand_password => 'storm_on_demand_password',
|
90
|
+
:vcloud_host => 'vcloud_host',
|
91
|
+
:vcloud_password => 'vcloud_password',
|
92
|
+
:vcloud_username => 'vcloud_username',
|
93
|
+
:vcloud_director_host => 'vcloud-director-host',
|
94
|
+
:vcloud_director_password => 'vcloud_director_password',
|
95
|
+
:vcloud_director_username => 'vcd_user@vcd_org_name',
|
96
|
+
:voxel_api_key => 'voxel_api_key',
|
97
|
+
:voxel_api_secret => 'voxel_api_secret',
|
98
|
+
:zerigo_email => 'zerigo_email',
|
99
|
+
:zerigo_token => 'zerigo_token',
|
100
|
+
:dynect_customer => 'dynect_customer',
|
101
|
+
:dynect_username => 'dynect_username',
|
102
|
+
:dynect_password => 'dynect_password',
|
103
|
+
:vsphere_server => 'virtualcenter.lan',
|
104
|
+
:vsphere_username => 'apiuser',
|
105
|
+
:vsphere_password => 'apipassword',
|
106
|
+
:vsphere_expected_pubkey_hash => 'abcdef1234567890',
|
107
|
+
:libvirt_uri => 'qemu:///system',
|
108
|
+
:libvirt_username => 'root',
|
109
|
+
:libvirt_password => 'password',
|
110
|
+
:cloudsigma_username => 'csuname',
|
111
|
+
:cloudsigma_password => 'cspass',
|
112
|
+
:docker_username => 'docker-fan',
|
113
|
+
:docker_password => 'i<3docker',
|
114
|
+
:docker_email => 'dockerfan@gmail.com',
|
115
|
+
:docker_url => 'unix://var/run/docker.sock'
|
116
|
+
}.merge(Fog.credentials)
|
117
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
def model_tests(collection, params = {}, mocks_implemented = true)
|
2
|
+
tests('success') do
|
3
|
+
|
4
|
+
@instance = collection.new(params)
|
5
|
+
|
6
|
+
tests("#save").succeeds do
|
7
|
+
pending if Fog.mocking? && !mocks_implemented
|
8
|
+
@instance.save
|
9
|
+
end
|
10
|
+
|
11
|
+
if block_given?
|
12
|
+
yield(@instance)
|
13
|
+
end
|
14
|
+
|
15
|
+
tests("#destroy").succeeds do
|
16
|
+
pending if Fog.mocking? && !mocks_implemented
|
17
|
+
@instance.destroy
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
# Generates a unique identifier with a random differentiator.
|
24
|
+
# Useful when rapidly re-running tests, so we don't have to wait
|
25
|
+
# serveral minutes for deleted objects to disappear from the API
|
26
|
+
# E.g. 'fog-test-1234'
|
27
|
+
def uniq_id(base_name = 'fog-test')
|
28
|
+
# random_differentiator
|
29
|
+
suffix = rand(65536).to_s(16).rjust(4, '0')
|
30
|
+
[base_name, suffix] * '-'
|
31
|
+
end
|
@@ -0,0 +1,107 @@
|
|
1
|
+
Shindo.tests('Fog::Schema::DataValidator', 'meta') do
|
2
|
+
|
3
|
+
validator = Fog::Schema::DataValidator.new
|
4
|
+
|
5
|
+
tests('#validate') do
|
6
|
+
|
7
|
+
tests('returns true') do
|
8
|
+
|
9
|
+
returns(true, 'when value matches schema expectation') do
|
10
|
+
validator.validate({"key" => "Value"}, {"key" => String})
|
11
|
+
end
|
12
|
+
|
13
|
+
returns(true, 'when values within an array all match schema expectation') do
|
14
|
+
validator.validate({"key" => [1, 2]}, {"key" => [Integer]})
|
15
|
+
end
|
16
|
+
|
17
|
+
returns(true, 'when nested values match schema expectation') do
|
18
|
+
validator.validate({"key" => {:nested_key => "Value"}}, {"key" => {:nested_key => String}})
|
19
|
+
end
|
20
|
+
|
21
|
+
returns(true, 'when collection of values all match schema expectation') do
|
22
|
+
validator.validate([{"key" => "Value"}, {"key" => "Value"}], [{"key" => String}])
|
23
|
+
end
|
24
|
+
|
25
|
+
returns(true, 'when collection is empty although schema covers optional members') do
|
26
|
+
validator.validate([], [{"key" => String}])
|
27
|
+
end
|
28
|
+
|
29
|
+
returns(true, 'when additional keys are passed and not strict') do
|
30
|
+
validator.validate({"key" => "Value", :extra => "Bonus"}, {"key" => String}, {:allow_extra_keys => true})
|
31
|
+
end
|
32
|
+
|
33
|
+
returns(true, 'when value is nil and schema expects NilClass') do
|
34
|
+
validator.validate({"key" => nil}, {"key" => NilClass})
|
35
|
+
end
|
36
|
+
|
37
|
+
returns(true, 'when value and schema match as hashes') do
|
38
|
+
validator.validate({}, {})
|
39
|
+
end
|
40
|
+
|
41
|
+
returns(true, 'when value and schema match as arrays') do
|
42
|
+
validator.validate([], [])
|
43
|
+
end
|
44
|
+
|
45
|
+
returns(true, 'when value is a Time') do
|
46
|
+
validator.validate({"time" => Time.now}, {"time" => Time})
|
47
|
+
end
|
48
|
+
|
49
|
+
returns(true, 'when key is missing but value should be NilClass (#1477)') do
|
50
|
+
validator.validate({}, {"key" => NilClass}, {:allow_optional_rules => true})
|
51
|
+
end
|
52
|
+
|
53
|
+
returns(true, 'when key is missing but value is nullable (#1477)') do
|
54
|
+
validator.validate({}, {"key" => Fog::Nullable::String}, {:allow_optional_rules => true})
|
55
|
+
end
|
56
|
+
|
57
|
+
end
|
58
|
+
|
59
|
+
tests('returns false') do
|
60
|
+
|
61
|
+
returns(false, 'when value does not match schema expectation') do
|
62
|
+
validator.validate({"key" => nil}, {"key" => String})
|
63
|
+
end
|
64
|
+
|
65
|
+
returns(false, 'when key formats do not match') do
|
66
|
+
validator.validate({"key" => "Value"}, {:key => String})
|
67
|
+
end
|
68
|
+
|
69
|
+
returns(false, 'when additional keys are passed and strict') do
|
70
|
+
validator.validate({"key" => "Missing"}, {})
|
71
|
+
end
|
72
|
+
|
73
|
+
returns(false, 'when some keys do not appear') do
|
74
|
+
validator.validate({}, {"key" => String})
|
75
|
+
end
|
76
|
+
|
77
|
+
returns(false, 'when collection contains a member that does not match schema') do
|
78
|
+
validator.validate([{"key" => "Value"}, {"key" => 5}], [{"key" => String}])
|
79
|
+
end
|
80
|
+
|
81
|
+
returns(false, 'when collection has multiple schema patterns') do
|
82
|
+
validator.validate([{"key" => "Value"}], [{"key" => Integer}, {"key" => String}])
|
83
|
+
end
|
84
|
+
|
85
|
+
returns(false, 'when hash and array are compared') do
|
86
|
+
validator.validate({}, [])
|
87
|
+
end
|
88
|
+
|
89
|
+
returns(false, 'when array and hash are compared') do
|
90
|
+
validator.validate([], {})
|
91
|
+
end
|
92
|
+
|
93
|
+
returns(false, 'when a hash is expected but another data type is found') do
|
94
|
+
validator.validate({"key" => {:nested_key => []}}, {"key" => {:nested_key => {}}})
|
95
|
+
end
|
96
|
+
|
97
|
+
returns(false, 'when key is missing but value should be NilClass (#1477)') do
|
98
|
+
validator.validate({}, {"key" => NilClass}, {:allow_optional_rules => false})
|
99
|
+
end
|
100
|
+
|
101
|
+
returns(false, 'when key is missing but value is nullable (#1477)') do
|
102
|
+
validator.validate({}, {"key" => Fog::Nullable::String}, {:allow_optional_rules => false})
|
103
|
+
end
|
104
|
+
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|