fog-atmos 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (43) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +23 -0
  3. data/.rubocop.yml +20 -0
  4. data/.ruby-gemset +1 -0
  5. data/.ruby-version +1 -0
  6. data/.travis.yml +17 -0
  7. data/CONTRIBUTING.md +18 -0
  8. data/CONTRIBUTORS.md +10 -0
  9. data/Gemfile +4 -0
  10. data/LICENSE.md +20 -0
  11. data/README.md +38 -0
  12. data/Rakefile +18 -0
  13. data/fog-atmos.gemspec +35 -0
  14. data/gemfiles/Gemfile.1.9.2- +8 -0
  15. data/gemfiles/Gemfile.1.9.3+ +7 -0
  16. data/lib/fog/atmos.rb +15 -0
  17. data/lib/fog/atmos/storage.rb +0 -0
  18. data/lib/fog/atmos/version.rb +5 -0
  19. data/lib/fog/storage/atmos.rb +187 -0
  20. data/lib/fog/storage/atmos/models/directories.rb +41 -0
  21. data/lib/fog/storage/atmos/models/directory.rb +46 -0
  22. data/lib/fog/storage/atmos/models/file.rb +106 -0
  23. data/lib/fog/storage/atmos/models/files.rb +71 -0
  24. data/lib/fog/storage/atmos/requests/delete_namespace.rb +17 -0
  25. data/lib/fog/storage/atmos/requests/get_namespace.rb +23 -0
  26. data/lib/fog/storage/atmos/requests/head_namespace.rb +18 -0
  27. data/lib/fog/storage/atmos/requests/post_namespace.rb +18 -0
  28. data/lib/fog/storage/atmos/requests/put_namespace.rb +18 -0
  29. data/tests/helper.rb +36 -0
  30. data/tests/helpers/collection_helper.rb +97 -0
  31. data/tests/helpers/compute/flavors_helper.rb +32 -0
  32. data/tests/helpers/compute/server_helper.rb +25 -0
  33. data/tests/helpers/compute/servers_helper.rb +10 -0
  34. data/tests/helpers/formats_helper.rb +98 -0
  35. data/tests/helpers/formats_helper_tests.rb +110 -0
  36. data/tests/helpers/mock_helper.rb +117 -0
  37. data/tests/helpers/model_helper.rb +31 -0
  38. data/tests/helpers/responds_to_helper.rb +11 -0
  39. data/tests/helpers/schema_validator_tests.rb +107 -0
  40. data/tests/helpers/succeeds_helper.rb +9 -0
  41. data/tests/models/storage/file_update_tests.rb +19 -0
  42. data/tests/models/storage/nested_directories_tests.rb +23 -0
  43. 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,10 @@
1
+ def servers_tests(connection, params = {}, mocks_implemented = true)
2
+ collection_tests(connection.servers, params, mocks_implemented) do
3
+
4
+ if !Fog.mocking? || mocks_implemented
5
+ @instance.wait_for { ready? }
6
+ yield if block_given?
7
+ end
8
+
9
+ end
10
+ 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,11 @@
1
+ module Shindo
2
+ class Tests
3
+ def responds_to(method_names)
4
+ for method_name in [*method_names]
5
+ tests("#respond_to?(:#{method_name})").returns(true) do
6
+ @instance.respond_to?(method_name)
7
+ end
8
+ end
9
+ end
10
+ end
11
+ 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