occi-core 4.3.6 → 5.0.0.alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.fasterer.yml +3 -0
- data/.gitignore +9 -16
- data/.rspec +1 -1
- data/.rubocop.yml +69 -0
- data/.travis.yml +27 -0
- data/AUTHORS +8 -6
- data/CHANGELOG.md +0 -0
- data/Gemfile +1 -1
- data/LICENSE +1 -1
- data/README.md +25 -170
- data/Rakefile +25 -17
- data/examples/initialize_model.rb +10 -0
- data/examples/parse_action_instance_json.rb +15 -0
- data/examples/parse_action_instance_text.rb +15 -0
- data/examples/parse_categories_json.rb +15 -0
- data/examples/parse_categories_text.rb +15 -0
- data/examples/parse_instance_json.rb +15 -0
- data/examples/parse_instance_text.rb +15 -0
- data/examples/parse_model_json.rb +9 -0
- data/examples/parse_model_text.rb +9 -0
- data/examples/render_action_instance_json.rb +17 -0
- data/examples/render_action_instance_text.rb +17 -0
- data/examples/render_instance_json.rb +20 -0
- data/examples/render_instance_text.rb +20 -0
- data/examples/render_model_json.rb +12 -0
- data/examples/render_model_text.rb +12 -0
- data/examples/rendering/action_instance.json +6 -0
- data/examples/rendering/action_instance.txt +2 -0
- data/examples/rendering/categories.json +78 -0
- data/examples/rendering/categories.txt +4 -0
- data/examples/rendering/instance.json +70 -0
- data/examples/rendering/instance.txt +12 -0
- data/examples/rendering/model.alt.json +1716 -0
- data/examples/rendering/model.json +785 -0
- data/examples/rendering/model.txt +68 -0
- data/lib/occi/core/action.rb +12 -26
- data/lib/occi/core/action_instance.rb +109 -65
- data/lib/occi/core/attribute.rb +136 -0
- data/lib/occi/core/attribute_definition.rb +269 -0
- data/lib/occi/core/category.rb +110 -83
- data/lib/occi/core/collection.rb +255 -0
- data/lib/occi/core/constants.rb +14 -0
- data/lib/occi/core/entity.rb +301 -195
- data/lib/occi/core/errors/.gitkeep +0 -0
- data/lib/occi/core/errors/attribute_definition_error.rb +11 -0
- data/lib/occi/core/errors/attribute_validation_error.rb +13 -0
- data/lib/occi/core/errors/category_validation_error.rb +13 -0
- data/lib/occi/core/errors/collection_lookup_error.rb +11 -0
- data/lib/occi/core/errors/instance_validation_error.rb +13 -0
- data/lib/occi/core/errors/mandatory_argument_error.rb +11 -0
- data/lib/occi/core/errors/model_lookup_error.rb +11 -0
- data/lib/occi/core/errors/parser_error.rb +11 -0
- data/lib/occi/core/errors/parsing_error.rb +11 -0
- data/lib/occi/core/errors/renderer_error.rb +11 -0
- data/lib/occi/core/errors/rendering_error.rb +11 -0
- data/lib/occi/core/errors/validation_error.rb +11 -0
- data/lib/occi/core/errors.rb +9 -0
- data/lib/occi/core/helpers/.gitkeep +0 -0
- data/lib/occi/core/helpers/argument_validator.rb +27 -0
- data/lib/occi/core/helpers/attributes_accessor.rb +22 -0
- data/lib/occi/core/helpers/error_handler.rb +29 -0
- data/lib/occi/core/helpers/hash_dereferencer.rb +149 -0
- data/lib/occi/core/helpers/identifier_validator.rb +135 -0
- data/lib/occi/core/helpers/instance_attribute_resetter.rb +131 -0
- data/lib/occi/core/helpers/instance_attributes_accessor.rb +30 -0
- data/lib/occi/core/helpers/locatable.rb +40 -0
- data/lib/occi/core/helpers/parser_dereferencer.rb +96 -0
- data/lib/occi/core/helpers/raw_json_parser.rb +18 -0
- data/lib/occi/core/helpers/renderable.rb +93 -0
- data/lib/occi/core/helpers/yaml_summoner.rb +44 -0
- data/lib/occi/core/helpers.rb +13 -0
- data/lib/occi/core/instance_builder.rb +162 -0
- data/lib/occi/core/kind.rb +100 -132
- data/lib/occi/core/link.rb +47 -72
- data/lib/occi/core/mixin.rb +76 -61
- data/lib/occi/core/model.rb +341 -0
- data/lib/occi/core/parsers/.gitkeep +0 -0
- data/lib/occi/core/parsers/base_parser.rb +168 -0
- data/lib/occi/core/parsers/json/.gitkeep +0 -0
- data/lib/occi/core/parsers/json/action_instance.rb +36 -0
- data/lib/occi/core/parsers/json/category.rb +113 -0
- data/lib/occi/core/parsers/json/entity.rb +156 -0
- data/lib/occi/core/parsers/json/validator/.gitkeep +0 -0
- data/lib/occi/core/parsers/json/validator/action-instance.json +3 -0
- data/lib/occi/core/parsers/json/validator/entity-collection.json +3 -0
- data/lib/occi/core/parsers/json/validator/link-collection.json +3 -0
- data/lib/occi/core/parsers/json/validator/link.json +3 -0
- data/lib/occi/core/parsers/json/validator/locations.json +3 -0
- data/lib/occi/core/parsers/json/validator/mixin-collection.json +3 -0
- data/lib/occi/core/parsers/json/validator/model.json +3 -0
- data/lib/occi/core/parsers/json/validator/occi-schema.json +277 -0
- data/lib/occi/core/parsers/json/validator/resource-collection.json +3 -0
- data/lib/occi/core/parsers/json/validator/resource.json +3 -0
- data/lib/occi/core/parsers/json/validator.rb +87 -0
- data/lib/occi/core/parsers/json_parser.rb +128 -0
- data/lib/occi/core/parsers/text/.gitkeep +0 -0
- data/lib/occi/core/parsers/text/category.rb +183 -0
- data/lib/occi/core/parsers/text/constants.rb +89 -0
- data/lib/occi/core/parsers/text/entity.rb +257 -0
- data/lib/occi/core/parsers/text/location.rb +48 -0
- data/lib/occi/core/parsers/text_parser.rb +257 -0
- data/lib/occi/core/parsers.rb +18 -0
- data/lib/occi/core/renderer_factory.rb +213 -0
- data/lib/occi/core/renderers/.gitkeep +0 -0
- data/lib/occi/core/renderers/base_renderer.rb +81 -0
- data/lib/occi/core/renderers/json/.gitkeep +0 -0
- data/lib/occi/core/renderers/json/action_instance.rb +24 -0
- data/lib/occi/core/renderers/json/attributes.rb +50 -0
- data/lib/occi/core/renderers/json/base.rb +46 -0
- data/lib/occi/core/renderers/json/category.rb +85 -0
- data/lib/occi/core/renderers/json/collection.rb +52 -0
- data/lib/occi/core/renderers/json/instance.rb +39 -0
- data/lib/occi/core/renderers/json/link.rb +48 -0
- data/lib/occi/core/renderers/json/model.rb +26 -0
- data/lib/occi/core/renderers/json/resource.rb +27 -0
- data/lib/occi/core/renderers/json_renderer.rb +72 -0
- data/lib/occi/core/renderers/text/.gitkeep +0 -0
- data/lib/occi/core/renderers/text/action_instance.rb +36 -0
- data/lib/occi/core/renderers/text/attributes.rb +87 -0
- data/lib/occi/core/renderers/text/base.rb +82 -0
- data/lib/occi/core/renderers/text/category.rb +183 -0
- data/lib/occi/core/renderers/text/collection.rb +65 -0
- data/lib/occi/core/renderers/text/instance.rb +44 -0
- data/lib/occi/core/renderers/text/link.rb +40 -0
- data/lib/occi/core/renderers/text/model.rb +41 -0
- data/lib/occi/core/renderers/text/resource.rb +109 -0
- data/lib/occi/core/renderers/text_renderer.rb +72 -0
- data/lib/occi/core/renderers.rb +20 -0
- data/lib/occi/core/resource.rb +93 -57
- data/lib/occi/core/utils/.gitkeep +0 -0
- data/lib/occi/core/version.rb +17 -0
- data/lib/occi/core/warehouse/actions/.gitkeep +0 -0
- data/lib/occi/core/warehouse/actions/attributes/.gitkeep +0 -0
- data/lib/occi/core/warehouse/kinds/.gitkeep +0 -0
- data/lib/occi/core/warehouse/kinds/attributes/.gitkeep +0 -0
- data/lib/occi/core/warehouse/kinds/attributes/occi.core.id.yml +7 -0
- data/lib/occi/core/warehouse/kinds/attributes/occi.core.source.yml +7 -0
- data/lib/occi/core/warehouse/kinds/attributes/occi.core.summary.yml +7 -0
- data/lib/occi/core/warehouse/kinds/attributes/occi.core.target.yml +7 -0
- data/lib/occi/core/warehouse/kinds/attributes/occi.core.title.yml +7 -0
- data/lib/occi/core/warehouse/kinds/entity.yml +10 -0
- data/lib/occi/core/warehouse/kinds/link.yml +10 -0
- data/lib/occi/core/warehouse/kinds/resource.yml +9 -0
- data/lib/occi/core/warehouse/mixins/.gitkeep +0 -0
- data/lib/occi/core/warehouse/mixins/attributes/.gitkeep +0 -0
- data/lib/occi/core/warehouse.rb +115 -0
- data/lib/occi/core.rb +59 -23
- data/lib/occi/infrastructure/compute.rb +5 -122
- data/lib/occi/infrastructure/constants.rb +25 -0
- data/lib/occi/infrastructure/instance_builder.rb +24 -0
- data/lib/occi/infrastructure/mixins/.gitkeep +0 -0
- data/lib/occi/infrastructure/mixins/os_tpl.rb +19 -0
- data/lib/occi/infrastructure/mixins/resource_tpl.rb +19 -0
- data/lib/occi/infrastructure/mixins.rb +12 -0
- data/lib/occi/infrastructure/model.rb +27 -0
- data/lib/occi/infrastructure/network.rb +5 -104
- data/lib/occi/infrastructure/networkinterface.rb +5 -100
- data/lib/occi/infrastructure/storage.rb +5 -59
- data/lib/occi/infrastructure/storagelink.rb +5 -54
- data/lib/occi/infrastructure/version.rb +5 -0
- data/lib/occi/infrastructure/warehouse/actions/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/actions/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/actions/compute_restart.yml +12 -0
- data/lib/occi/infrastructure/warehouse/actions/compute_save.yml +19 -0
- data/lib/occi/infrastructure/warehouse/actions/compute_start.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/compute_stop.yml +12 -0
- data/lib/occi/infrastructure/warehouse/actions/compute_suspend.yml +12 -0
- data/lib/occi/infrastructure/warehouse/actions/network_down.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/network_up.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/networkinterface_down.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/networkinterface_up.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storage_backup.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storage_offline.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storage_online.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storage_resize.yml +12 -0
- data/lib/occi/infrastructure/warehouse/actions/storage_snapshot.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storagelink_offline.yml +4 -0
- data/lib/occi/infrastructure/warehouse/actions/storagelink_online.yml +4 -0
- data/lib/occi/infrastructure/warehouse/kinds/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.architecture.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.cores.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.hostname.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.memory.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.speed.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.compute.state.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.network.label.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.network.state.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.network.vlan.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.networkinterface.interface.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.networkinterface.mac.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.networkinterface.state.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.storage.size.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.storage.state.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.storagelink.deviceid.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.storagelink.mountpoint.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/attributes/occi.storagelink.state.yml +7 -0
- data/lib/occi/infrastructure/warehouse/kinds/compute.yml +19 -0
- data/lib/occi/infrastructure/warehouse/kinds/network.yml +13 -0
- data/lib/occi/infrastructure/warehouse/kinds/networkinterface.yml +13 -0
- data/lib/occi/infrastructure/warehouse/kinds/storage.yml +15 -0
- data/lib/occi/infrastructure/warehouse/kinds/storagelink.yml +13 -0
- data/lib/occi/infrastructure/warehouse/mixins/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.network.address.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.network.allocation.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.network.gateway.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.networkinterface.address.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.networkinterface.allocation.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/attributes/occi.networkinterface.gateway.yml +7 -0
- data/lib/occi/infrastructure/warehouse/mixins/ipnetwork.yml +11 -0
- data/lib/occi/infrastructure/warehouse/mixins/ipnetworkinterface.yml +11 -0
- data/lib/occi/infrastructure/warehouse.rb +20 -0
- data/lib/occi/infrastructure-ext.rb +35 -0
- data/lib/occi/infrastructure.rb +34 -19
- data/lib/occi/infrastructure_ext/constants.rb +20 -0
- data/lib/occi/infrastructure_ext/instance_builder.rb +22 -0
- data/lib/occi/infrastructure_ext/ipreservation.rb +9 -0
- data/lib/occi/infrastructure_ext/mixins/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/mixins/availability_zone.rb +19 -0
- data/lib/occi/infrastructure_ext/mixins.rb +12 -0
- data/lib/occi/infrastructure_ext/model.rb +26 -0
- data/lib/occi/infrastructure_ext/securitygroup.rb +9 -0
- data/lib/occi/infrastructure_ext/securitygrouplink.rb +9 -0
- data/lib/occi/infrastructure_ext/version.rb +5 -0
- data/lib/occi/infrastructure_ext/warehouse/actions/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse/actions/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse/actions/ipreservation_down.yml +4 -0
- data/lib/occi/infrastructure_ext/warehouse/actions/ipreservation_up.yml +4 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.ipreservation.address.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.ipreservation.state.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.ipreservation.used.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.securitygroup.rules.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.securitygroup.state.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/attributes/occi.securitygrouplink.state.yml +7 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/ipreservation.yml +13 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/securitygroup.yml +9 -0
- data/lib/occi/infrastructure_ext/warehouse/kinds/securitygrouplink.yml +8 -0
- data/lib/occi/infrastructure_ext/warehouse/mixins/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse/mixins/attributes/.gitkeep +0 -0
- data/lib/occi/infrastructure_ext/warehouse.rb +20 -0
- data/lib/occi/monkey_island/boolean.rb +6 -0
- data/lib/occi/monkey_island/hash.rb +4 -0
- data/occi-core.gemspec +26 -26
- metadata +312 -243
- data/.yardopts +0 -1
- data/config/occi.yml +0 -4
- data/lib/occi/collection.rb +0 -265
- data/lib/occi/core/actions.rb +0 -21
- data/lib/occi/core/attributes.rb +0 -411
- data/lib/occi/core/categories.rb +0 -64
- data/lib/occi/core/dependencies.rb +0 -7
- data/lib/occi/core/entities.rb +0 -48
- data/lib/occi/core/kinds.rb +0 -22
- data/lib/occi/core/links.rb +0 -37
- data/lib/occi/core/mixins.rb +0 -37
- data/lib/occi/core/properties.rb +0 -108
- data/lib/occi/core/resources.rb +0 -14
- data/lib/occi/errors/attribute_definitions_converted_error.rb +0 -5
- data/lib/occi/errors/attribute_missing_error.rb +0 -5
- data/lib/occi/errors/attribute_name_invalid_error.rb +0 -5
- data/lib/occi/errors/attribute_not_defined_error.rb +0 -5
- data/lib/occi/errors/attribute_property_type_error.rb +0 -5
- data/lib/occi/errors/attribute_type_error.rb +0 -5
- data/lib/occi/errors/category_not_defined_error.rb +0 -5
- data/lib/occi/errors/kind_not_defined_error.rb +0 -5
- data/lib/occi/errors/parser_input_error.rb +0 -5
- data/lib/occi/errors/parser_type_error.rb +0 -5
- data/lib/occi/errors.rb +0 -1
- data/lib/occi/extensions/hashie.rb +0 -25
- data/lib/occi/helpers/comparators/action_instance.rb +0 -22
- data/lib/occi/helpers/comparators/attributes.rb +0 -22
- data/lib/occi/helpers/comparators/categories.rb +0 -22
- data/lib/occi/helpers/comparators/category.rb +0 -22
- data/lib/occi/helpers/comparators/collection.rb +0 -40
- data/lib/occi/helpers/comparators/entities.rb +0 -22
- data/lib/occi/helpers/comparators/entity.rb +0 -22
- data/lib/occi/helpers/comparators/properties.rb +0 -26
- data/lib/occi/helpers/comparators.rb +0 -1
- data/lib/occi/helpers/inspect.rb +0 -12
- data/lib/occi/infrastructure/network/ipnetwork.rb +0 -28
- data/lib/occi/infrastructure/networkinterface/ipnetworkinterface.rb +0 -28
- data/lib/occi/infrastructure/os_tpl.rb +0 -20
- data/lib/occi/infrastructure/resource_tpl.rb +0 -20
- data/lib/occi/log.rb +0 -71
- data/lib/occi/model.rb +0 -87
- data/lib/occi/parser/json.rb +0 -38
- data/lib/occi/parser/text/constants.rb +0 -89
- data/lib/occi/parser/text.rb +0 -280
- data/lib/occi/parser.rb +0 -144
- data/lib/occi/settings.rb +0 -10
- data/lib/occi/version.rb +0 -3
- data/lib/occi-core.rb +0 -53
- data/spec/helpers/to_plain.rb +0 -39
- data/spec/helpers/yaml_hash.rb +0 -32
- data/spec/occi/collection_samples/collection1.json +0 -1
- data/spec/occi/collection_samples/directory2/collection2.json +0 -1
- data/spec/occi/collection_spec.rb +0 -1003
- data/spec/occi/core/action_instance_spec.rb +0 -317
- data/spec/occi/core/action_spec.rb +0 -71
- data/spec/occi/core/attributes_spec.rb +0 -665
- data/spec/occi/core/categories_spec.rb +0 -28
- data/spec/occi/core/category_spec.rb +0 -216
- data/spec/occi/core/entities_spec.rb +0 -160
- data/spec/occi/core/entity_spec.rb +0 -374
- data/spec/occi/core/kind_spec.rb +0 -182
- data/spec/occi/core/link_spec.rb +0 -52
- data/spec/occi/core/links_spec.rb +0 -132
- data/spec/occi/core/mixin_spec.rb +0 -38
- data/spec/occi/core/mixins_spec.rb +0 -107
- data/spec/occi/core/properties_spec.rb +0 -171
- data/spec/occi/core/resource_spec.rb +0 -42
- data/spec/occi/core_spec.rb +0 -12
- data/spec/occi/infrastructure/compute_spec.rb +0 -229
- data/spec/occi/infrastructure/network_spec.rb +0 -96
- data/spec/occi/infrastructure/networkinterface_spec.rb +0 -96
- data/spec/occi/infrastructure/storage_spec.rb +0 -33
- data/spec/occi/infrastructure/storagelink_spec.rb +0 -45
- data/spec/occi/log_spec.rb +0 -117
- data/spec/occi/model_spec.rb +0 -256
- data/spec/occi/parser/json_samples/test.json +0 -49
- data/spec/occi/parser/text_samples/occi_categories.body_plain.expected +0 -2
- data/spec/occi/parser/text_samples/occi_categories.expected +0 -2
- data/spec/occi/parser/text_samples/occi_categories.parse_headers.expected +0 -2
- data/spec/occi/parser/text_samples/occi_categories.text +0 -2
- data/spec/occi/parser/text_samples/occi_compute_rocci_server.expected +0 -11
- data/spec/occi/parser/text_samples/occi_compute_rocci_server.text +0 -10
- data/spec/occi/parser/text_samples/occi_link_resource_instance.body_plain.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_resource_instance.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_resource_instance.parse.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_resource_instance.text +0 -7
- data/spec/occi/parser/text_samples/occi_link_simple.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_simple.text +0 -1
- data/spec/occi/parser/text_samples/occi_link_w_attributes.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_w_attributes.text +0 -7
- data/spec/occi/parser/text_samples/occi_link_w_category.expected +0 -7
- data/spec/occi/parser/text_samples/occi_link_w_category.text +0 -3
- data/spec/occi/parser/text_samples/occi_model_categories.expected +0 -3
- data/spec/occi/parser/text_samples/occi_model_rocci_server.text +0 -51
- data/spec/occi/parser/text_samples/occi_network_rocci_server.body_plain.expected +0 -11
- data/spec/occi/parser/text_samples/occi_network_rocci_server.expected +0 -11
- data/spec/occi/parser/text_samples/occi_network_rocci_server.resource.header.expected +0 -9
- data/spec/occi/parser/text_samples/occi_network_rocci_server.resource.rack.expected +0 -9
- data/spec/occi/parser/text_samples/occi_network_rocci_server.text +0 -11
- data/spec/occi/parser/text_samples/occi_resource_custom_class_w_attributes.parse.expected +0 -15
- data/spec/occi/parser/text_samples/occi_resource_custom_class_w_attributes.text +0 -15
- data/spec/occi/parser/text_samples/occi_resource_w_attributes.text +0 -11
- data/spec/occi/parser/text_samples/occi_resource_w_inline_links.expected +0 -1
- data/spec/occi/parser/text_samples/occi_resource_w_inline_links.text +0 -16
- data/spec/occi/parser/text_samples/occi_resource_w_inline_links_only.text +0 -13
- data/spec/occi/parser/text_samples/occi_storage_rocci_server.expected +0 -9
- data/spec/occi/parser/text_samples/occi_storage_rocci_server.text +0 -9
- data/spec/occi/parser/text_spec.rb +0 -320
- data/spec/occi/parser_spec.rb +0 -259
- data/spec/occi-core_spec.rb +0 -31
- data/spec/spec_helper.rb +0 -18
@@ -1,132 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
module Core
|
3
|
-
describe Links do
|
4
|
-
|
5
|
-
context '.initialize' do
|
6
|
-
it 'initializes an empty Links set' do
|
7
|
-
links = Occi::Core::Links.new
|
8
|
-
expect(links).to eql []
|
9
|
-
end
|
10
|
-
|
11
|
-
context 'with multiple members' do
|
12
|
-
let(:link1){ Occi::Core::Link.new }
|
13
|
-
let(:link2){ Occi::Core::Link.new }
|
14
|
-
let(:links){ Occi::Core::Links.new [link1,link2] }
|
15
|
-
let(:expected){ expected = []
|
16
|
-
links.each { |ln| expected << ln.id }
|
17
|
-
expected }
|
18
|
-
|
19
|
-
it 'produces the right number of members' do
|
20
|
-
expect(links.count).to eql 2
|
21
|
-
end
|
22
|
-
|
23
|
-
it 'has the first link' do
|
24
|
-
expect(link1.id).to satisfy { |id| expected.include?(id) }
|
25
|
-
end
|
26
|
-
|
27
|
-
it 'has the second link' do
|
28
|
-
expect(link2.id).to satisfy { |id| expected.include?(id) }
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
context 'with strings' do
|
33
|
-
it 'produces the right number of members, strings only' do
|
34
|
-
links = Occi::Core::Links.new ["target1","target2"]
|
35
|
-
expect(links.count).to eql 2
|
36
|
-
end
|
37
|
-
|
38
|
-
it 'populates Links with correctly initialized links' do
|
39
|
-
links = Occi::Core::Links.new ["/link/9c3b83bd-2456-45e9-8ce5-91a7d5c7bb85"]
|
40
|
-
|
41
|
-
expect(links.first.id).to eql "9c3b83bd-2456-45e9-8ce5-91a7d5c7bb85"
|
42
|
-
expect(links.first.location).to eql "/link/9c3b83bd-2456-45e9-8ce5-91a7d5c7bb85"
|
43
|
-
end
|
44
|
-
|
45
|
-
it 'produces the right number of members, string/link combination' do
|
46
|
-
link2 = Occi::Core::Link.new
|
47
|
-
links = Occi::Core::Links.new ["target1",link2]
|
48
|
-
expect(links.count).to eql 2
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
|
-
|
53
|
-
end
|
54
|
-
|
55
|
-
context '<<' do
|
56
|
-
context 'into an empty set' do
|
57
|
-
let(:link1){ Occi::Core::Link.new }
|
58
|
-
let(:links){ links = Occi::Core::Links.new
|
59
|
-
links << link1
|
60
|
-
links }
|
61
|
-
|
62
|
-
it 'produces the right number of members' do
|
63
|
-
expect(links.count).to eql 1
|
64
|
-
end
|
65
|
-
|
66
|
-
it 'has the link' do
|
67
|
-
expect(links.first.id).to eql link1.id
|
68
|
-
end
|
69
|
-
end
|
70
|
-
|
71
|
-
context 'into a populated set' do
|
72
|
-
let(:link1){ Occi::Core::Link.new }
|
73
|
-
let(:link2){ Occi::Core::Link.new }
|
74
|
-
let(:links){ links = Occi::Core::Links.new [link2]
|
75
|
-
links << link1
|
76
|
-
links }
|
77
|
-
let(:expected){ expected = []
|
78
|
-
links.each { |ln| expected << ln.id }
|
79
|
-
expected }
|
80
|
-
|
81
|
-
it 'produces the right number of members' do
|
82
|
-
expect(links.count).to eql 2
|
83
|
-
end
|
84
|
-
|
85
|
-
it 'has the first link' do
|
86
|
-
expect(link1.id).to satisfy { |id| expected.include?(id) }
|
87
|
-
end
|
88
|
-
|
89
|
-
it 'has the second link' do
|
90
|
-
expect(link2.id).to satisfy { |id| expected.include?(id) }
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
context '.create' do
|
96
|
-
context 'in an empty set' do
|
97
|
-
let!(:links){ Occi::Core::Links.new }
|
98
|
-
let!(:link1){ links.create }
|
99
|
-
|
100
|
-
it 'produces the right number of members' do
|
101
|
-
expect(links.count).to eql 1
|
102
|
-
end
|
103
|
-
|
104
|
-
it 'has the link' do
|
105
|
-
expect(links.first.id).to eql link1.id
|
106
|
-
end
|
107
|
-
end
|
108
|
-
|
109
|
-
context 'in a populated set' do
|
110
|
-
let(:link2){ Occi::Core::Link.new }
|
111
|
-
let!(:links){ Occi::Core::Links.new [link2] }
|
112
|
-
let!(:link1){ links.create }
|
113
|
-
let!(:expected){ expected = []
|
114
|
-
links.each { |ln| expected << ln.id }
|
115
|
-
expected }
|
116
|
-
|
117
|
-
it 'produces the right number of members' do
|
118
|
-
expect(links.count).to eql 2
|
119
|
-
end
|
120
|
-
|
121
|
-
it 'has the first link' do
|
122
|
-
expect(link1.id).to satisfy { |id| expected.include?(id) }
|
123
|
-
end
|
124
|
-
|
125
|
-
it 'has the second link' do
|
126
|
-
expect(link2.id).to satisfy { |id| expected.include?(id) }
|
127
|
-
end
|
128
|
-
end
|
129
|
-
end
|
130
|
-
end
|
131
|
-
end
|
132
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
module Core
|
3
|
-
describe Mixin do
|
4
|
-
|
5
|
-
describe '#location' do
|
6
|
-
let(:mixin) { Occi::Core::Mixin.new }
|
7
|
-
|
8
|
-
it 'defaults to /mixin/term/' do
|
9
|
-
expect(mixin.location).to eq '/mixin/mixin/'
|
10
|
-
end
|
11
|
-
|
12
|
-
it 'gets normalized to a relative path' do
|
13
|
-
mixin.location = 'http://example.org/mixin/'
|
14
|
-
expect(mixin.location).to eq '/mixin/'
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'can be set to nil' do
|
18
|
-
mixin.location = nil
|
19
|
-
expect(mixin.location).to be_nil
|
20
|
-
end
|
21
|
-
|
22
|
-
it 'raises an error when location does not start and end with a slash' do
|
23
|
-
expect { mixin.location = '/no_slash' }.to raise_error
|
24
|
-
expect { mixin.location = 'no_slash/' }.to raise_error
|
25
|
-
end
|
26
|
-
|
27
|
-
it 'raises an error when location contains spaces' do
|
28
|
-
expect { mixin.location = '/sla shes/' }.to raise_error
|
29
|
-
end
|
30
|
-
|
31
|
-
it 'can be set to an empty string' do
|
32
|
-
expect { mixin.location = '' }.not_to raise_error
|
33
|
-
end
|
34
|
-
end
|
35
|
-
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
@@ -1,107 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
module Core
|
3
|
-
describe Mixins do
|
4
|
-
|
5
|
-
context '#entity=' do
|
6
|
-
let(:ent){ Occi::Core::Entity.new }
|
7
|
-
let(:mixins){ Occi::Core::Mixins.new }
|
8
|
-
|
9
|
-
context 'assignment with mixins set empty' do
|
10
|
-
let(:mixin){ Occi::Core::Mixin.new }
|
11
|
-
it 'assigns entity to an empty mixin' do
|
12
|
-
mixins.entity = ent
|
13
|
-
expect(mixins.entity).to eql ent
|
14
|
-
end
|
15
|
-
end
|
16
|
-
|
17
|
-
context 'converting attributes form members into the assigned entity' do
|
18
|
-
let(:mixin){ mixin = Occi::Core::Mixin.new
|
19
|
-
mixin.attributes['stringtype'] = { :type => 'string',
|
20
|
-
:pattern => '[adefltuv]+',
|
21
|
-
:default => 'defaultvalue',
|
22
|
-
:mutable => true }
|
23
|
-
mixin.attributes['stringtype'] = 'flute'
|
24
|
-
mixin }
|
25
|
-
|
26
|
-
before(:each) {
|
27
|
-
mixins << mixin
|
28
|
-
mixins.entity = ent }
|
29
|
-
|
30
|
-
it 'removes assigned values' do
|
31
|
-
expect(mixins.entity.attributes['stringtype']).to eql nil
|
32
|
-
end
|
33
|
-
|
34
|
-
it 'preserves attribute properties' do
|
35
|
-
expect(mixins.entity.attributes['_stringtype']).to_not eql nil
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
context '<<' do
|
41
|
-
let!(:mixins){ Occi::Core::Mixins.new }
|
42
|
-
|
43
|
-
it 'adds a mixin to an empty set' do
|
44
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
45
|
-
expect(mixins.include?(Occi::Infrastructure::OsTpl.mixin)).to eql true
|
46
|
-
end
|
47
|
-
|
48
|
-
it 'adds a mixin to an empty set' do
|
49
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
50
|
-
mixins << Occi::Infrastructure::ResourceTpl.mixin
|
51
|
-
expect(mixins.include?(Occi::Infrastructure::ResourceTpl.mixin)).to eql true
|
52
|
-
end
|
53
|
-
|
54
|
-
it 'only adds the supplied mixin' do
|
55
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
56
|
-
expect(mixins.include?(Occi::Infrastructure::ResourceTpl.mixin)).to eql false
|
57
|
-
end
|
58
|
-
|
59
|
-
it 'adds mixin from string' do
|
60
|
-
mixins << "http://schemas.ogf.org/occi/core#testmixin"
|
61
|
-
expect(mixins.first.term).to eql "testmixin"
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
context '#remove' do
|
66
|
-
let!(:mixins){ Occi::Core::Mixins.new }
|
67
|
-
|
68
|
-
it 'removes last mixin from the set' do
|
69
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
70
|
-
mixins.remove(Occi::Infrastructure::OsTpl.mixin)
|
71
|
-
expect(mixins.include?(Occi::Infrastructure::OsTpl.mixin)).to eql false
|
72
|
-
end
|
73
|
-
|
74
|
-
it 'removes mixin from among multiple members' do
|
75
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
76
|
-
mixins << Occi::Infrastructure::ResourceTpl.mixin
|
77
|
-
mixins.remove(Occi::Infrastructure::OsTpl.mixin)
|
78
|
-
expect(mixins.include?(Occi::Infrastructure::OsTpl.mixin)).to eql false
|
79
|
-
end
|
80
|
-
|
81
|
-
it 'leaves other unaffected' do
|
82
|
-
mixins << Occi::Infrastructure::OsTpl.mixin
|
83
|
-
mixins << Occi::Infrastructure::ResourceTpl.mixin
|
84
|
-
mixins.remove(Occi::Infrastructure::OsTpl.mixin)
|
85
|
-
expect(mixins.include?(Occi::Infrastructure::ResourceTpl.mixin)).to eql true
|
86
|
-
end
|
87
|
-
|
88
|
-
it 'removes attributes from the entity attribute' do
|
89
|
-
ent = Occi::Core::Entity.new
|
90
|
-
mixin = Occi::Core::Mixin.new
|
91
|
-
mixin.attributes['stringtype'] = { :type => 'string', :pattern => '[adefltuv]+', :default => 'defaultvalue', :mutable => true }
|
92
|
-
mixin.attributes['stringtype'] = 'flute'
|
93
|
-
|
94
|
-
mixins << mixin
|
95
|
-
mixins.entity = ent
|
96
|
-
|
97
|
-
mixins.remove(mixin)
|
98
|
-
|
99
|
-
expect(mixins.entity.attributes['_stringtype']).to eql nil
|
100
|
-
end
|
101
|
-
end
|
102
|
-
|
103
|
-
context '#convert' do
|
104
|
-
end
|
105
|
-
end
|
106
|
-
end
|
107
|
-
end
|
@@ -1,171 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
module Core
|
3
|
-
describe Properties do
|
4
|
-
|
5
|
-
context '#type=' do
|
6
|
-
let(:properties){ Occi::Core::Properties.new }
|
7
|
-
it 'accepts string' do
|
8
|
-
expect{ properties.type = 'string' }.to_not raise_exception
|
9
|
-
end
|
10
|
-
|
11
|
-
it 'accepts number' do
|
12
|
-
expect{ properties.type = 'number' }.to_not raise_exception
|
13
|
-
end
|
14
|
-
|
15
|
-
it 'accepts boolean' do
|
16
|
-
expect{ properties.type = 'boolean' }.to_not raise_exception
|
17
|
-
end
|
18
|
-
|
19
|
-
it 'rejects another string' do
|
20
|
-
expect{ properties.type = 'other' }.to raise_exception Occi::Errors::AttributePropertyTypeError
|
21
|
-
end
|
22
|
-
|
23
|
-
end
|
24
|
-
|
25
|
-
context '#check_value_for_type' do
|
26
|
-
context 'string' do
|
27
|
-
let(:properties){ properties = Occi::Core::Properties.new
|
28
|
-
properties.type = 'string'
|
29
|
-
properties }
|
30
|
-
|
31
|
-
it 'permits string' do
|
32
|
-
expect{ properties.check_value_for_type("string") }.to_not raise_exception
|
33
|
-
end
|
34
|
-
|
35
|
-
it 'rejects nil' do
|
36
|
-
expect{ properties.check_value_for_type(nil) }.to raise_exception(Occi::Errors::AttributeTypeError)
|
37
|
-
end
|
38
|
-
|
39
|
-
it 'rejects another class' do
|
40
|
-
expect{ properties.check_value_for_type(true) }.to raise_exception(Occi::Errors::AttributeTypeError)
|
41
|
-
end
|
42
|
-
end
|
43
|
-
|
44
|
-
context 'number' do
|
45
|
-
let(:properties){ properties = Occi::Core::Properties.new
|
46
|
-
properties.type = 'number'
|
47
|
-
properties }
|
48
|
-
|
49
|
-
it 'permits number' do
|
50
|
-
expect{ properties.check_value_for_type(42) }.to_not raise_exception
|
51
|
-
end
|
52
|
-
|
53
|
-
it 'rejects nil' do
|
54
|
-
expect{ properties.check_value_for_type(nil) }.to raise_exception(Occi::Errors::AttributeTypeError)
|
55
|
-
end
|
56
|
-
|
57
|
-
it 'rejects another class' do
|
58
|
-
expect{ properties.check_value_for_type("string") }.to raise_exception(Occi::Errors::AttributeTypeError)
|
59
|
-
end
|
60
|
-
end
|
61
|
-
|
62
|
-
context 'boolean' do
|
63
|
-
let(:properties){ properties = Occi::Core::Properties.new
|
64
|
-
properties.type = 'boolean'
|
65
|
-
properties }
|
66
|
-
|
67
|
-
it 'permits true' do
|
68
|
-
expect{ properties.check_value_for_type(true) }.to_not raise_exception
|
69
|
-
end
|
70
|
-
|
71
|
-
it 'permits false' do
|
72
|
-
expect{ properties.check_value_for_type(false) }.to_not raise_exception
|
73
|
-
end
|
74
|
-
|
75
|
-
it 'rejects nil' do
|
76
|
-
expect{ properties.check_value_for_type(nil) }.to raise_exception(Occi::Errors::AttributeTypeError)
|
77
|
-
end
|
78
|
-
|
79
|
-
it 'rejects another class' do
|
80
|
-
expect{ properties.check_value_for_type(0) }.to raise_exception(Occi::Errors::AttributeTypeError)
|
81
|
-
end
|
82
|
-
end
|
83
|
-
end
|
84
|
-
|
85
|
-
context 'rendering' do
|
86
|
-
let(:properties) { properties = Occi::Core::Properties.new
|
87
|
-
properties.type = "string"
|
88
|
-
properties.required = true
|
89
|
-
properties.mutable = true
|
90
|
-
properties.default = "defaultvalue"
|
91
|
-
properties.description = "Required string value"
|
92
|
-
properties.pattern = "[adefltuv]+"
|
93
|
-
properties }
|
94
|
-
|
95
|
-
context '#to_hash' do
|
96
|
-
it 'makes a correct rendering' do
|
97
|
-
expected = Hash.new
|
98
|
-
|
99
|
-
expected["default"] = "defaultvalue"
|
100
|
-
expected["description"] = "Required string value"
|
101
|
-
expected["mutable"] = true
|
102
|
-
expected["pattern"] = "[adefltuv]+"
|
103
|
-
expected["required"] = true
|
104
|
-
expected["type"] = "string"
|
105
|
-
|
106
|
-
expect(properties.to_hash).to eql expected
|
107
|
-
end
|
108
|
-
end
|
109
|
-
|
110
|
-
context '#as_json' do
|
111
|
-
it 'makes a correct rendering' do
|
112
|
-
expected = Hash.new
|
113
|
-
|
114
|
-
expected["default"] = "defaultvalue"
|
115
|
-
expected["description"] = "Required string value"
|
116
|
-
expected["mutable"] = true
|
117
|
-
expected["pattern"] = "[adefltuv]+"
|
118
|
-
expected["required"] = true
|
119
|
-
expected["type"] = "string"
|
120
|
-
|
121
|
-
expect(properties.to_hash).to eql expected
|
122
|
-
end
|
123
|
-
|
124
|
-
it 'makes a correct rendering of empty props' do
|
125
|
-
empty = Occi::Core::Properties.new
|
126
|
-
expected = Hash.new
|
127
|
-
expected["mutable"] = true
|
128
|
-
expected["pattern"] = ".*"
|
129
|
-
expected["required"] = false
|
130
|
-
expected["type"] = "string"
|
131
|
-
|
132
|
-
expect(empty.to_hash).to eql expected
|
133
|
-
end
|
134
|
-
|
135
|
-
end
|
136
|
-
|
137
|
-
context '#to_json' do
|
138
|
-
it 'makes a correct rendering' do
|
139
|
-
expected = '{"default":"defaultvalue","type":"string","required":true,"mutable":true,"pattern":"[adefltuv]+","description":"Required string value"}'
|
140
|
-
expect(properties.to_json).to eql expected
|
141
|
-
end
|
142
|
-
end
|
143
|
-
end
|
144
|
-
|
145
|
-
context '#empty?' do
|
146
|
-
let(:properties) { properties = Occi::Core::Properties.new
|
147
|
-
properties.type = "string"
|
148
|
-
properties.required = true
|
149
|
-
properties.mutable = true
|
150
|
-
properties.default = "defaultvalue"
|
151
|
-
properties.description = "Required string value"
|
152
|
-
properties.pattern = "[adefltuv]+"
|
153
|
-
properties }
|
154
|
-
|
155
|
-
it 'Returns false for non-empty props' do
|
156
|
-
expect(properties.empty?).to be false
|
157
|
-
end
|
158
|
-
|
159
|
-
it 'Returns true for empty props' do
|
160
|
-
empty = Occi::Core::Properties.new
|
161
|
-
empty.mutable = nil
|
162
|
-
empty.pattern = nil
|
163
|
-
empty.required = nil
|
164
|
-
empty.instance_eval { @type=nil }
|
165
|
-
|
166
|
-
expect(empty.empty?).to be true
|
167
|
-
end
|
168
|
-
end
|
169
|
-
end
|
170
|
-
end
|
171
|
-
end
|
@@ -1,42 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
module Core
|
3
|
-
describe Resource do
|
4
|
-
let(:resource){ resource = Occi::Core::Resource.new
|
5
|
-
resource.link target
|
6
|
-
resource.attributes.occi!.core!.summary = "Resource Summary"
|
7
|
-
resource }
|
8
|
-
let(:target){ target = Occi::Core::Resource.new }
|
9
|
-
|
10
|
-
context '#link' do
|
11
|
-
it "creates the appropriate No. of links" do
|
12
|
-
expect(resource.links.count).to eq 1
|
13
|
-
end
|
14
|
-
|
15
|
-
it "has the correct kind" do
|
16
|
-
expect(resource.links.first).to be_kind_of Occi::Core::Link
|
17
|
-
end
|
18
|
-
|
19
|
-
it 'sets the right target' do
|
20
|
-
expect(resource.links.first.target).to eq target.to_s
|
21
|
-
end
|
22
|
-
|
23
|
-
it 'sets the right source' do
|
24
|
-
expect(resource.links.first.source).to eq resource.to_s
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
context '#as_json' do
|
29
|
-
it 'renders to JSON with full links' do
|
30
|
-
expect(resource.as_json.links.first).to be_kind_of Hashie::Mash
|
31
|
-
end
|
32
|
-
end
|
33
|
-
|
34
|
-
context '#summary' do
|
35
|
-
it 'gets the summary attribute corectly' do
|
36
|
-
expected = "Resource Summary"
|
37
|
-
expect(resource.summary).to eql expected
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|
data/spec/occi/core_spec.rb
DELETED
@@ -1,12 +0,0 @@
|
|
1
|
-
module Occi
|
2
|
-
describe Core do
|
3
|
-
|
4
|
-
context ".kinds" do
|
5
|
-
it 'initializes kinds' do
|
6
|
-
kinds = Occi::Core.kinds
|
7
|
-
expected = Occi::Core::Kinds.new << Occi::Core::Entity.kind << Occi::Core::Link.kind << Occi::Core::Resource.kind
|
8
|
-
expect(kinds).to eql expected
|
9
|
-
end
|
10
|
-
end
|
11
|
-
end
|
12
|
-
end
|