metasploit-model 0.24.1.pre.semantic.pre.versioning.pre.2.pre.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/.coveralls.yml +1 -0
- data/.gitignore +27 -0
- data/.rspec +4 -0
- data/.simplecov +38 -0
- data/.travis.yml +6 -0
- data/.yardopts +5 -0
- data/Gemfile +43 -0
- data/LICENSE +27 -0
- data/README.md +33 -0
- data/Rakefile +52 -0
- data/app/models/metasploit/model/association/reflection.rb +46 -0
- data/app/models/metasploit/model/module/ancestor/spec/template.rb +125 -0
- data/app/models/metasploit/model/module/class/spec/template.rb +92 -0
- data/app/models/metasploit/model/module/instance/spec/template.rb +97 -0
- data/app/models/metasploit/model/search/group/base.rb +21 -0
- data/app/models/metasploit/model/search/group/intersection.rb +4 -0
- data/app/models/metasploit/model/search/group/union.rb +4 -0
- data/app/models/metasploit/model/search/operation/base.rb +39 -0
- data/app/models/metasploit/model/search/operation/boolean.rb +36 -0
- data/app/models/metasploit/model/search/operation/date.rb +37 -0
- data/app/models/metasploit/model/search/operation/integer.rb +14 -0
- data/app/models/metasploit/model/search/operation/null.rb +26 -0
- data/app/models/metasploit/model/search/operation/set.rb +34 -0
- data/app/models/metasploit/model/search/operation/set/integer.rb +5 -0
- data/app/models/metasploit/model/search/operation/set/string.rb +5 -0
- data/app/models/metasploit/model/search/operation/string.rb +11 -0
- data/app/models/metasploit/model/search/operation/union.rb +59 -0
- data/app/models/metasploit/model/search/operator/association.rb +43 -0
- data/app/models/metasploit/model/search/operator/attribute.rb +60 -0
- data/app/models/metasploit/model/search/operator/base.rb +34 -0
- data/app/models/metasploit/model/search/operator/delegation.rb +40 -0
- data/app/models/metasploit/model/search/operator/deprecated/app.rb +27 -0
- data/app/models/metasploit/model/search/operator/deprecated/author.rb +33 -0
- data/app/models/metasploit/model/search/operator/deprecated/authority.rb +43 -0
- data/app/models/metasploit/model/search/operator/deprecated/platform.rb +45 -0
- data/app/models/metasploit/model/search/operator/deprecated/ref.rb +50 -0
- data/app/models/metasploit/model/search/operator/deprecated/text.rb +32 -0
- data/app/models/metasploit/model/search/operator/null.rb +44 -0
- data/app/models/metasploit/model/search/operator/single.rb +98 -0
- data/app/models/metasploit/model/search/operator/union.rb +33 -0
- data/app/models/metasploit/model/search/query.rb +171 -0
- data/app/models/metasploit/model/spec/template.rb +273 -0
- data/app/models/metasploit/model/visitation/visitor.rb +69 -0
- data/app/validators/derivation_validator.rb +17 -0
- data/app/validators/dynamic_length_validator.rb +45 -0
- data/app/validators/ip_format_validator.rb +31 -0
- data/app/validators/nil_validator.rb +16 -0
- data/app/validators/parameters_validator.rb +147 -0
- data/app/validators/password_is_strong_validator.rb +115 -0
- data/config/locales/en.yml +209 -0
- data/lib/metasploit/model.rb +38 -0
- data/lib/metasploit/model/architecture.rb +346 -0
- data/lib/metasploit/model/association.rb +49 -0
- data/lib/metasploit/model/association/error.rb +40 -0
- data/lib/metasploit/model/author.rb +58 -0
- data/lib/metasploit/model/authority.rb +134 -0
- data/lib/metasploit/model/authority/bid.rb +10 -0
- data/lib/metasploit/model/authority/cve.rb +10 -0
- data/lib/metasploit/model/authority/msb.rb +10 -0
- data/lib/metasploit/model/authority/osvdb.rb +10 -0
- data/lib/metasploit/model/authority/pmasa.rb +10 -0
- data/lib/metasploit/model/authority/secunia.rb +10 -0
- data/lib/metasploit/model/authority/us_cert_vu.rb +10 -0
- data/lib/metasploit/model/authority/waraxe.rb +31 -0
- data/lib/metasploit/model/authority/zdi.rb +10 -0
- data/lib/metasploit/model/base.rb +25 -0
- data/lib/metasploit/model/configuration.rb +72 -0
- data/lib/metasploit/model/configuration/autoload.rb +109 -0
- data/lib/metasploit/model/configuration/child.rb +12 -0
- data/lib/metasploit/model/configuration/error.rb +4 -0
- data/lib/metasploit/model/configuration/i18n.rb +54 -0
- data/lib/metasploit/model/configuration/parent.rb +50 -0
- data/lib/metasploit/model/configured.rb +46 -0
- data/lib/metasploit/model/derivation.rb +110 -0
- data/lib/metasploit/model/derivation/full_name.rb +25 -0
- data/lib/metasploit/model/email_address.rb +128 -0
- data/lib/metasploit/model/engine.rb +34 -0
- data/lib/metasploit/model/error.rb +7 -0
- data/lib/metasploit/model/file.rb +49 -0
- data/lib/metasploit/model/invalid.rb +17 -0
- data/lib/metasploit/model/module.rb +8 -0
- data/lib/metasploit/model/module/action.rb +58 -0
- data/lib/metasploit/model/module/ancestor.rb +494 -0
- data/lib/metasploit/model/module/architecture.rb +40 -0
- data/lib/metasploit/model/module/author.rb +47 -0
- data/lib/metasploit/model/module/class.rb +406 -0
- data/lib/metasploit/model/module/handler.rb +35 -0
- data/lib/metasploit/model/module/instance.rb +626 -0
- data/lib/metasploit/model/module/path.rb +165 -0
- data/lib/metasploit/model/module/platform.rb +38 -0
- data/lib/metasploit/model/module/rank.rb +91 -0
- data/lib/metasploit/model/module/reference.rb +38 -0
- data/lib/metasploit/model/module/stance.rb +22 -0
- data/lib/metasploit/model/module/target.rb +80 -0
- data/lib/metasploit/model/module/target/architecture.rb +42 -0
- data/lib/metasploit/model/module/target/platform.rb +42 -0
- data/lib/metasploit/model/module/type.rb +44 -0
- data/lib/metasploit/model/nilify_blanks.rb +53 -0
- data/lib/metasploit/model/platform.rb +250 -0
- data/lib/metasploit/model/real_pathname.rb +18 -0
- data/lib/metasploit/model/reference.rb +108 -0
- data/lib/metasploit/model/search.rb +63 -0
- data/lib/metasploit/model/search/association.rb +32 -0
- data/lib/metasploit/model/search/attribute.rb +51 -0
- data/lib/metasploit/model/search/operation.rb +31 -0
- data/lib/metasploit/model/search/operation/integer/value.rb +33 -0
- data/lib/metasploit/model/search/operation/string/value.rb +14 -0
- data/lib/metasploit/model/search/operator.rb +10 -0
- data/lib/metasploit/model/search/operator/help.rb +47 -0
- data/lib/metasploit/model/search/with.rb +40 -0
- data/lib/metasploit/model/spec.rb +140 -0
- data/lib/metasploit/model/spec/error.rb +9 -0
- data/lib/metasploit/model/spec/i18n_exception_handler.rb +19 -0
- data/lib/metasploit/model/spec/pathname_collision.rb +28 -0
- data/lib/metasploit/model/spec/template/write.rb +42 -0
- data/lib/metasploit/model/spec/temporary_pathname.rb +59 -0
- data/lib/metasploit/model/translation.rb +31 -0
- data/lib/metasploit/model/version.rb +33 -0
- data/lib/metasploit/model/visitation.rb +9 -0
- data/lib/metasploit/model/visitation/visit.rb +103 -0
- data/lib/tasks/yard.rake +30 -0
- data/metasploit-model.gemspec +39 -0
- data/script/rails +9 -0
- data/spec/app/models/metasploit/model/association/reflection_spec.rb +48 -0
- data/spec/app/models/metasploit/model/module/ancestor/spec/template_spec.rb +174 -0
- data/spec/app/models/metasploit/model/module/class/spec/template_spec.rb +222 -0
- data/spec/app/models/metasploit/model/module/instance/spec/template_spec.rb +201 -0
- data/spec/app/models/metasploit/model/search/group/base_spec.rb +5 -0
- data/spec/app/models/metasploit/model/search/group/intersection_spec.rb +5 -0
- data/spec/app/models/metasploit/model/search/group/union_spec.rb +5 -0
- data/spec/app/models/metasploit/model/search/operation/base_spec.rb +70 -0
- data/spec/app/models/metasploit/model/search/operation/boolean_spec.rb +56 -0
- data/spec/app/models/metasploit/model/search/operation/date_spec.rb +89 -0
- data/spec/app/models/metasploit/model/search/operation/integer_spec.rb +9 -0
- data/spec/app/models/metasploit/model/search/operation/null_spec.rb +64 -0
- data/spec/app/models/metasploit/model/search/operation/set/integer_spec.rb +7 -0
- data/spec/app/models/metasploit/model/search/operation/set/string_spec.rb +7 -0
- data/spec/app/models/metasploit/model/search/operation/set_spec.rb +126 -0
- data/spec/app/models/metasploit/model/search/operation/string_spec.rb +9 -0
- data/spec/app/models/metasploit/model/search/operation/union_spec.rb +124 -0
- data/spec/app/models/metasploit/model/search/operator/association_spec.rb +108 -0
- data/spec/app/models/metasploit/model/search/operator/attribute_spec.rb +104 -0
- data/spec/app/models/metasploit/model/search/operator/base_spec.rb +34 -0
- data/spec/app/models/metasploit/model/search/operator/delegation_spec.rb +108 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/app_spec.rb +62 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/author_spec.rb +161 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/authority_spec.rb +123 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/platform_spec.rb +112 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/ref_spec.rb +327 -0
- data/spec/app/models/metasploit/model/search/operator/deprecated/text_spec.rb +357 -0
- data/spec/app/models/metasploit/model/search/operator/null_spec.rb +41 -0
- data/spec/app/models/metasploit/model/search/operator/single_spec.rb +327 -0
- data/spec/app/models/metasploit/model/search/operator/union_spec.rb +92 -0
- data/spec/app/models/metasploit/model/search/query_spec.rb +742 -0
- data/spec/app/models/metasploit/model/spec/template_spec.rb +23 -0
- data/spec/app/models/metasploit/model/visitation/visitor_spec.rb +45 -0
- data/spec/app/validators/derivation_validator_spec.rb +92 -0
- data/spec/app/validators/dynamic_length_validator_spec.rb +293 -0
- data/spec/app/validators/ip_format_validator_spec.rb +124 -0
- data/spec/app/validators/nil_validator_spec.rb +69 -0
- data/spec/app/validators/parameters_validator_spec.rb +342 -0
- data/spec/app/validators/password_is_strong_validator_spec.rb +250 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/.gitkeep +0 -0
- data/spec/dummy/app/models/dummy/architecture.rb +92 -0
- data/spec/dummy/app/models/dummy/author.rb +15 -0
- data/spec/dummy/app/models/dummy/authority.rb +130 -0
- data/spec/dummy/app/models/dummy/email_address.rb +27 -0
- data/spec/dummy/app/models/dummy/module/action.rb +25 -0
- data/spec/dummy/app/models/dummy/module/ancestor.rb +67 -0
- data/spec/dummy/app/models/dummy/module/architecture.rb +19 -0
- data/spec/dummy/app/models/dummy/module/author.rb +28 -0
- data/spec/dummy/app/models/dummy/module/class.rb +69 -0
- data/spec/dummy/app/models/dummy/module/instance.rb +209 -0
- data/spec/dummy/app/models/dummy/module/path.rb +64 -0
- data/spec/dummy/app/models/dummy/module/platform.rb +19 -0
- data/spec/dummy/app/models/dummy/module/rank.rb +44 -0
- data/spec/dummy/app/models/dummy/module/reference.rb +19 -0
- data/spec/dummy/app/models/dummy/module/target.rb +62 -0
- data/spec/dummy/app/models/dummy/module/target/architecture.rb +19 -0
- data/spec/dummy/app/models/dummy/module/target/platform.rb +19 -0
- data/spec/dummy/app/models/dummy/platform.rb +58 -0
- data/spec/dummy/app/models/dummy/reference.rb +31 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +43 -0
- data/spec/dummy/config/boot.rb +10 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +27 -0
- data/spec/dummy/config/environments/production.rb +63 -0
- data/spec/dummy/config/environments/test.rb +29 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/inflections.rb +15 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +3 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +9 -0
- data/spec/dummy/config/locales/en.yml +1 -0
- data/spec/dummy/config/routes.rb +2 -0
- data/spec/dummy/db/schema.rb +707 -0
- data/spec/dummy/lib/assets/.gitkeep +0 -0
- data/spec/dummy/log/.gitkeep +0 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +25 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/dummy/spec/factories/dummy/architectures.rb +13 -0
- data/spec/dummy/spec/factories/dummy/authorities.rb +32 -0
- data/spec/dummy/spec/factories/dummy/authors.rb +8 -0
- data/spec/dummy/spec/factories/dummy/email_addresses.rb +8 -0
- data/spec/dummy/spec/factories/dummy/module/actions.rb +13 -0
- data/spec/dummy/spec/factories/dummy/module/ancestors.rb +45 -0
- data/spec/dummy/spec/factories/dummy/module/architectures.rb +35 -0
- data/spec/dummy/spec/factories/dummy/module/authors.rb +10 -0
- data/spec/dummy/spec/factories/dummy/module/classes.rb +40 -0
- data/spec/dummy/spec/factories/dummy/module/instances.rb +86 -0
- data/spec/dummy/spec/factories/dummy/module/paths.rb +16 -0
- data/spec/dummy/spec/factories/dummy/module/platforms.rb +35 -0
- data/spec/dummy/spec/factories/dummy/module/ranks.rb +14 -0
- data/spec/dummy/spec/factories/dummy/module/references.rb +17 -0
- data/spec/dummy/spec/factories/dummy/module/target/architectures.rb +40 -0
- data/spec/dummy/spec/factories/dummy/module/target/platforms.rb +41 -0
- data/spec/dummy/spec/factories/dummy/module/targets.rb +46 -0
- data/spec/dummy/spec/factories/dummy/platforms.rb +3 -0
- data/spec/dummy/spec/factories/dummy/references.rb +26 -0
- data/spec/factories/metasploit/model/architectures.rb +6 -0
- data/spec/factories/metasploit/model/association/reflections.rb +9 -0
- data/spec/factories/metasploit/model/authorities.rb +28 -0
- data/spec/factories/metasploit/model/authors.rb +9 -0
- data/spec/factories/metasploit/model/bases.rb +10 -0
- data/spec/factories/metasploit/model/email_addresses.rb +14 -0
- data/spec/factories/metasploit/model/module/actions.rb +9 -0
- data/spec/factories/metasploit/model/module/ancestors.rb +180 -0
- data/spec/factories/metasploit/model/module/architectures.rb +15 -0
- data/spec/factories/metasploit/model/module/classes.rb +47 -0
- data/spec/factories/metasploit/model/module/handlers.rb +3 -0
- data/spec/factories/metasploit/model/module/instances.rb +83 -0
- data/spec/factories/metasploit/model/module/paths.rb +51 -0
- data/spec/factories/metasploit/model/module/platforms.rb +15 -0
- data/spec/factories/metasploit/model/module/ranks.rb +9 -0
- data/spec/factories/metasploit/model/module/references.rb +11 -0
- data/spec/factories/metasploit/model/module/stances.rb +3 -0
- data/spec/factories/metasploit/model/module/targets.rb +22 -0
- data/spec/factories/metasploit/model/module/types.rb +5 -0
- data/spec/factories/metasploit/model/references.rb +88 -0
- data/spec/factories/metasploit/model/search/operator/associations.rb +5 -0
- data/spec/factories/metasploit/model/search/operator/attributes.rb +7 -0
- data/spec/factories/metasploit/model/search/operator/bases.rb +5 -0
- data/spec/lib/metasploit/model/architecture_spec.rb +52 -0
- data/spec/lib/metasploit/model/association/error_spec.rb +48 -0
- data/spec/lib/metasploit/model/association_spec.rb +145 -0
- data/spec/lib/metasploit/model/author_spec.rb +6 -0
- data/spec/lib/metasploit/model/authority/bid_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/cve_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/msb_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/osvdb_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/pmasa_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/secunia_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/us_cert_vu_spec.rb +17 -0
- data/spec/lib/metasploit/model/authority/waraxe_spec.rb +51 -0
- data/spec/lib/metasploit/model/authority/zdi_spec.rb +21 -0
- data/spec/lib/metasploit/model/authority_spec.rb +10 -0
- data/spec/lib/metasploit/model/base_spec.rb +58 -0
- data/spec/lib/metasploit/model/configuration/autoload_spec.rb +165 -0
- data/spec/lib/metasploit/model/configuration/child_spec.rb +24 -0
- data/spec/lib/metasploit/model/configuration/error_spec.rb +5 -0
- data/spec/lib/metasploit/model/configuration/i18n_spec.rb +103 -0
- data/spec/lib/metasploit/model/configuration_spec.rb +106 -0
- data/spec/lib/metasploit/model/configured_spec.rb +41 -0
- data/spec/lib/metasploit/model/derivation/full_name_spec.rb +75 -0
- data/spec/lib/metasploit/model/derivation_spec.rb +217 -0
- data/spec/lib/metasploit/model/email_address_spec.rb +19 -0
- data/spec/lib/metasploit/model/engine_spec.rb +84 -0
- data/spec/lib/metasploit/model/file_spec.rb +43 -0
- data/spec/lib/metasploit/model/invalid_spec.rb +54 -0
- data/spec/lib/metasploit/model/module/action_spec.rb +6 -0
- data/spec/lib/metasploit/model/module/ancestor_spec.rb +6 -0
- data/spec/lib/metasploit/model/module/architecture_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/author_spec.rb +6 -0
- data/spec/lib/metasploit/model/module/class_spec.rb +19 -0
- data/spec/lib/metasploit/model/module/handler_spec.rb +61 -0
- data/spec/lib/metasploit/model/module/instance_spec.rb +183 -0
- data/spec/lib/metasploit/model/module/path_spec.rb +6 -0
- data/spec/lib/metasploit/model/module/platform_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/rank_spec.rb +29 -0
- data/spec/lib/metasploit/model/module/reference_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/stance_spec.rb +30 -0
- data/spec/lib/metasploit/model/module/target/architecture_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/target/platform_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/target_spec.rb +9 -0
- data/spec/lib/metasploit/model/module/type_spec.rb +125 -0
- data/spec/lib/metasploit/model/nilify_blanks_spec.rb +156 -0
- data/spec/lib/metasploit/model/platform_spec.rb +100 -0
- data/spec/lib/metasploit/model/reference_spec.rb +21 -0
- data/spec/lib/metasploit/model/search/association_spec.rb +33 -0
- data/spec/lib/metasploit/model/search/attribute_spec.rb +99 -0
- data/spec/lib/metasploit/model/search/operation/integer/value_spec.rb +20 -0
- data/spec/lib/metasploit/model/search/operation/string/value_spec.rb +20 -0
- data/spec/lib/metasploit/model/search/operation_spec.rb +144 -0
- data/spec/lib/metasploit/model/search/operator/help_spec.rb +41 -0
- data/spec/lib/metasploit/model/search/with_spec.rb +81 -0
- data/spec/lib/metasploit/model/search_spec.rb +230 -0
- data/spec/lib/metasploit/model/spec/error_spec.rb +5 -0
- data/spec/lib/metasploit/model/spec/i18n_exception_handler_spec.rb +42 -0
- data/spec/lib/metasploit/model/spec/pathname_collision_spec.rb +55 -0
- data/spec/lib/metasploit/model/spec_spec.rb +114 -0
- data/spec/lib/metasploit/model/translation_spec.rb +82 -0
- data/spec/lib/metasploit/model/version_spec.rb +141 -0
- data/spec/lib/metasploit/model/visitation/visit_spec.rb +316 -0
- data/spec/lib/metasploit/model_spec.rb +68 -0
- data/spec/spec_helper.rb +48 -0
- data/spec/support/shared/contexts/metasploit/model/configuration.rb +11 -0
- data/spec/support/shared/contexts/metasploit/model/module/ancestor/contents/metasploit_module.rb +12 -0
- data/spec/support/shared/contexts/metasploit/model/module/ancestor/factory/contents.rb +10 -0
- data/spec/support/shared/contexts/metasploit/model/module/ancestor/factory/contents/metasploit_module.rb +15 -0
- data/spec/support/shared/contexts/metasploit/model/search/operator/union/children.rb +13 -0
- data/spec/support/shared/examples/derives.rb +115 -0
- data/spec/support/shared/examples/metasploit/model/architecture.rb +425 -0
- data/spec/support/shared/examples/metasploit/model/architecture/seed.rb +25 -0
- data/spec/support/shared/examples/metasploit/model/author.rb +27 -0
- data/spec/support/shared/examples/metasploit/model/authority.rb +124 -0
- data/spec/support/shared/examples/metasploit/model/authority/seed.rb +49 -0
- data/spec/support/shared/examples/metasploit/model/configuration/parent/child.rb +60 -0
- data/spec/support/shared/examples/metasploit/model/email_address.rb +220 -0
- data/spec/support/shared/examples/metasploit/model/module/action.rb +26 -0
- data/spec/support/shared/examples/metasploit/model/module/ancestor.rb +2004 -0
- data/spec/support/shared/examples/metasploit/model/module/ancestor/payload_factory.rb +63 -0
- data/spec/support/shared/examples/metasploit/model/module/architecture.rb +36 -0
- data/spec/support/shared/examples/metasploit/model/module/author.rb +29 -0
- data/spec/support/shared/examples/metasploit/model/module/class.rb +1514 -0
- data/spec/support/shared/examples/metasploit/model/module/handler.rb +21 -0
- data/spec/support/shared/examples/metasploit/model/module/instance.rb +1384 -0
- data/spec/support/shared/examples/metasploit/model/module/instance/class_methods.rb +537 -0
- data/spec/support/shared/examples/metasploit/model/module/instance/is_not_stanced_with_module_type.rb +22 -0
- data/spec/support/shared/examples/metasploit/model/module/instance/is_stanced_with_module_type.rb +38 -0
- data/spec/support/shared/examples/metasploit/model/module/instance/validates/dynamic_length_of.rb +131 -0
- data/spec/support/shared/examples/metasploit/model/module/path.rb +493 -0
- data/spec/support/shared/examples/metasploit/model/module/platform.rb +36 -0
- data/spec/support/shared/examples/metasploit/model/module/rank.rb +92 -0
- data/spec/support/shared/examples/metasploit/model/module/reference.rb +16 -0
- data/spec/support/shared/examples/metasploit/model/module/target.rb +29 -0
- data/spec/support/shared/examples/metasploit/model/module/target/architecture.rb +56 -0
- data/spec/support/shared/examples/metasploit/model/module/target/platform.rb +56 -0
- data/spec/support/shared/examples/metasploit/model/platform.rb +213 -0
- data/spec/support/shared/examples/metasploit/model/real_pathname.rb +29 -0
- data/spec/support/shared/examples/metasploit/model/reference.rb +410 -0
- data/spec/support/shared/examples/metasploit/model/search/operation/integer/value.rb +79 -0
- data/spec/support/shared/examples/metasploit/model/search/operation/string/value.rb +53 -0
- data/spec/support/shared/examples/metasploit/model/search/operator/help.rb +134 -0
- data/spec/support/shared/examples/metasploit/model/translation.rb +37 -0
- data/spec/support/shared/examples/search/query.rb +43 -0
- data/spec/support/shared/examples/search/query/metasploit/model/search/operator/deprecated/app.rb +44 -0
- data/spec/support/shared/examples/search/query/metasploit/model/search/operator/deprecated/authority.rb +60 -0
- data/spec/support/shared/examples/search_association.rb +13 -0
- data/spec/support/shared/examples/search_attribute.rb +27 -0
- data/spec/support/shared/examples/search_with.rb +36 -0
- data/spec/support/shared/matchers/allow_attribute.rb +17 -0
- data/spec/support/templates/metasploit/model/module/ancestors/_attributes.rb.erb +9 -0
- data/spec/support/templates/metasploit/model/module/ancestors/_methods.rb.erb +8 -0
- data/spec/support/templates/metasploit/model/module/ancestors/_validations.rb.erb +6 -0
- data/spec/support/templates/metasploit/model/module/ancestors/base.rb.erb +3 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_auxiliary.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_encoder.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_exploit.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_non_payload.rb.erb +5 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_nop.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_payload.rb.erb +4 -0
- data/spec/support/templates/metasploit/model/module/ancestors/module_types/_post.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/payload_types/_handled.rb.erb +20 -0
- data/spec/support/templates/metasploit/model/module/ancestors/payload_types/_single.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/ancestors/payload_types/_stage.rb.erb +0 -0
- data/spec/support/templates/metasploit/model/module/ancestors/payload_types/_stager.rb.erb +1 -0
- data/spec/support/templates/metasploit/model/module/classes/_methods.rb.erb +9 -0
- metadata +748 -0
@@ -0,0 +1,174 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Metasploit::Model::Module::Ancestor::Spec::Template do
|
4
|
+
subject(:template) do
|
5
|
+
described_class.new(
|
6
|
+
module_ancestor: module_ancestor
|
7
|
+
)
|
8
|
+
end
|
9
|
+
|
10
|
+
let(:module_ancestor) do
|
11
|
+
FactoryGirl.build(:dummy_module_ancestor)
|
12
|
+
end
|
13
|
+
|
14
|
+
context 'CONSTANTS' do
|
15
|
+
context 'DEFAULT_SEARCH_PATHNAMES' do
|
16
|
+
subject(:default_search_pathnames) do
|
17
|
+
described_class::DEFAULT_SEARCH_PATHNAMES
|
18
|
+
end
|
19
|
+
|
20
|
+
it "includes 'module/ancestors'" do
|
21
|
+
expect(default_search_pathnames).to include(Pathname.new('module/ancestors'))
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
context 'DEFAULT_SOURCE_RELATIVE_NAME' do
|
26
|
+
subject(:default_source_relative_name) do
|
27
|
+
described_class::DEFAULT_SOURCE_RELATIVE_NAME
|
28
|
+
end
|
29
|
+
|
30
|
+
it { should == 'base' }
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
context 'validations' do
|
35
|
+
it { should validate_presence_of :module_ancestor }
|
36
|
+
end
|
37
|
+
|
38
|
+
context '#destination_pathname' do
|
39
|
+
subject(:destination_pathname) do
|
40
|
+
template.destination_pathname
|
41
|
+
end
|
42
|
+
|
43
|
+
context 'with #module_ancestor' do
|
44
|
+
it 'defaults to module_ancestor.real_pathname' do
|
45
|
+
expect(destination_pathname).to eq(module_ancestor.real_pathname)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
context 'without #module_ancestor' do
|
50
|
+
let(:module_ancestor) do
|
51
|
+
nil
|
52
|
+
end
|
53
|
+
|
54
|
+
it { should be_nil }
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
context '#locals' do
|
59
|
+
subject(:locals) do
|
60
|
+
template.locals
|
61
|
+
end
|
62
|
+
|
63
|
+
it { should be_a Hash }
|
64
|
+
|
65
|
+
context '[:metasploit_module_relative_name]' do
|
66
|
+
subject(:metasploit_module_relative_name) do
|
67
|
+
locals[:metasploit_module_relative_name]
|
68
|
+
end
|
69
|
+
|
70
|
+
it 'is #metasploit_module_relative_name' do
|
71
|
+
expect(metasploit_module_relative_name).to eq(template.metasploit_module_relative_name)
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
context '[:module_ancestor]' do
|
76
|
+
subject(:locals_module_ancestor) do
|
77
|
+
locals[:module_ancestor]
|
78
|
+
end
|
79
|
+
|
80
|
+
it 'is #module_ancestor' do
|
81
|
+
expect(locals_module_ancestor).to eq(template.module_ancestor)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
context '#metapsloit_module_relative_name' do
|
87
|
+
subject(:metasploit_module_relative_name) do
|
88
|
+
template.metasploit_module_relative_name
|
89
|
+
end
|
90
|
+
|
91
|
+
it { should be_a String }
|
92
|
+
|
93
|
+
it 'uses FactoryGirl.generate' do
|
94
|
+
# ensure template is memoized so only metasploit_module_relative_name's usage of FactoryGirl is seen
|
95
|
+
template
|
96
|
+
|
97
|
+
expect(FactoryGirl).to receive(:generate).with(:metasploit_model_module_ancestor_metasploit_module_relative_name).and_call_original
|
98
|
+
|
99
|
+
metasploit_module_relative_name
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
context '#overwrite' do
|
104
|
+
subject(:overwrite) do
|
105
|
+
template.overwrite
|
106
|
+
end
|
107
|
+
|
108
|
+
it { should be_false }
|
109
|
+
end
|
110
|
+
|
111
|
+
context '#search_pathnames' do
|
112
|
+
subject(:search_pathnames) do
|
113
|
+
template.search_pathnames
|
114
|
+
end
|
115
|
+
|
116
|
+
it 'uses DEFAULT_SEARCH_PATHNAMES' do
|
117
|
+
expect(search_pathnames).to match_array(described_class::DEFAULT_SEARCH_PATHNAMES)
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
context '#source_relative_name' do
|
122
|
+
subject(:source_relative_name) do
|
123
|
+
template.source_relative_name
|
124
|
+
end
|
125
|
+
|
126
|
+
it 'uses DEFAULT_SOURCE_RELATIVE_NAME' do
|
127
|
+
expect(source_relative_name).to eq(described_class::DEFAULT_SOURCE_RELATIVE_NAME)
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
context 'write' do
|
132
|
+
subject(:write) do
|
133
|
+
described_class.write(attributes)
|
134
|
+
end
|
135
|
+
|
136
|
+
before(:each) do
|
137
|
+
# Since overwrite is false, have to delete the template that the factories make.
|
138
|
+
module_ancestor.real_pathname.delete
|
139
|
+
end
|
140
|
+
|
141
|
+
context 'with valid' do
|
142
|
+
let(:attributes) do
|
143
|
+
{
|
144
|
+
module_ancestor: module_ancestor
|
145
|
+
}
|
146
|
+
end
|
147
|
+
|
148
|
+
it { should be_true }
|
149
|
+
|
150
|
+
it 'writes template' do
|
151
|
+
# memoize attributes so any other writes besides the one under-test are already run.
|
152
|
+
attributes
|
153
|
+
|
154
|
+
described_class.any_instance.should_receive(:write)
|
155
|
+
|
156
|
+
write
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
160
|
+
context 'without valid' do
|
161
|
+
let(:attributes) do
|
162
|
+
{}
|
163
|
+
end
|
164
|
+
|
165
|
+
it { should be_false }
|
166
|
+
|
167
|
+
it 'does not write template' do
|
168
|
+
described_class.any_instance.should_not_receive(:write)
|
169
|
+
|
170
|
+
write
|
171
|
+
end
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
@@ -0,0 +1,222 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Metasploit::Model::Module::Class::Spec::Template do
|
4
|
+
subject(:template) do
|
5
|
+
described_class.new(
|
6
|
+
module_class: module_class
|
7
|
+
)
|
8
|
+
end
|
9
|
+
|
10
|
+
let(:module_class) do
|
11
|
+
FactoryGirl.build(
|
12
|
+
:dummy_module_class
|
13
|
+
)
|
14
|
+
end
|
15
|
+
|
16
|
+
context 'validations' do
|
17
|
+
it { should validate_presence_of :module_class }
|
18
|
+
|
19
|
+
context '#ancestor_templates_valid' do
|
20
|
+
subject(:ancestor_templates_valid) do
|
21
|
+
template.send(:ancestor_templates_valid)
|
22
|
+
end
|
23
|
+
|
24
|
+
#
|
25
|
+
# let
|
26
|
+
#
|
27
|
+
|
28
|
+
let(:error) do
|
29
|
+
I18n.translate!(:'errors.messages.invalid')
|
30
|
+
end
|
31
|
+
|
32
|
+
#
|
33
|
+
# Callbacks
|
34
|
+
#
|
35
|
+
|
36
|
+
before(:each) do
|
37
|
+
allow(template).to receive(:ancestor_templates).and_return(ancestor_templates)
|
38
|
+
end
|
39
|
+
|
40
|
+
context 'with ancestor_templates' do
|
41
|
+
#
|
42
|
+
# lets
|
43
|
+
#
|
44
|
+
|
45
|
+
let(:ancestor_templates) do
|
46
|
+
Array.new(2) { |i|
|
47
|
+
double("Ancestor Template #{i}")
|
48
|
+
}
|
49
|
+
end
|
50
|
+
|
51
|
+
#
|
52
|
+
# Callbacks
|
53
|
+
#
|
54
|
+
|
55
|
+
context 'with all valid' do
|
56
|
+
before(:each) do
|
57
|
+
ancestor_templates.each do |child|
|
58
|
+
child.stub(valid?: true)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
it 'does not add error on :ancestor_templates' do
|
63
|
+
template.valid?
|
64
|
+
|
65
|
+
template.errors[:ancestor_templates].should_not include(error)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
context 'with later valid' do
|
70
|
+
before(:each) do
|
71
|
+
ancestor_templates.first.stub(valid?: false)
|
72
|
+
ancestor_templates.second.stub(valid?: true)
|
73
|
+
end
|
74
|
+
|
75
|
+
it 'does not short-circuit and validates all ancestor_templates' do
|
76
|
+
ancestor_templates.second.should_receive(:valid?).and_return(true)
|
77
|
+
|
78
|
+
ancestor_templates_valid
|
79
|
+
end
|
80
|
+
|
81
|
+
it 'should add error on :ancestor_templates' do
|
82
|
+
template.valid?
|
83
|
+
|
84
|
+
template.errors[:ancestor_templates].should include(error)
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
context 'without ancestor_templates' do
|
90
|
+
let(:ancestor_templates) do
|
91
|
+
[]
|
92
|
+
end
|
93
|
+
|
94
|
+
it 'does not add error on :ancestor_templates' do
|
95
|
+
template.valid?
|
96
|
+
|
97
|
+
template.errors[:ancestor_templates].should_not include(error)
|
98
|
+
end
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
context '#ancestor_templates' do
|
104
|
+
subject(:ancestor_templates) do
|
105
|
+
template.ancestor_templates
|
106
|
+
end
|
107
|
+
|
108
|
+
it 'creates Metasploit::Model::Module::Ancestor::Spec::Template for each ancestor in module_class.ancestors' do
|
109
|
+
template_module_ancestors = ancestor_templates.map(&:module_ancestor)
|
110
|
+
|
111
|
+
expect(template_module_ancestors).to match_array(module_class.ancestors)
|
112
|
+
end
|
113
|
+
|
114
|
+
context 'Metasploit::Model::Module::Ancestor::Spec::Template' do
|
115
|
+
context 'locals' do
|
116
|
+
subject(:ancestor_template_locals) do
|
117
|
+
ancestor_templates.map(&:locals)
|
118
|
+
end
|
119
|
+
|
120
|
+
context '[:module_class]' do
|
121
|
+
subject(:local_module_classes) do
|
122
|
+
ancestor_template_locals.collect { |locals|
|
123
|
+
locals[:module_class]
|
124
|
+
}
|
125
|
+
end
|
126
|
+
|
127
|
+
it 'is #module_class' do
|
128
|
+
expect(
|
129
|
+
local_module_classes.all? { |local_module_class|
|
130
|
+
local_module_class == module_class
|
131
|
+
}
|
132
|
+
).to be_true
|
133
|
+
end
|
134
|
+
end
|
135
|
+
end
|
136
|
+
|
137
|
+
context 'overwrite' do
|
138
|
+
subject(:overwrites) do
|
139
|
+
ancestor_templates.map(&:overwrite)
|
140
|
+
end
|
141
|
+
|
142
|
+
it 'is true so the the ancestor written templates will be overwritten by the class templates' do
|
143
|
+
expect(
|
144
|
+
overwrites.all? { |overwrite|
|
145
|
+
overwrite == true
|
146
|
+
}
|
147
|
+
).to be_true
|
148
|
+
end
|
149
|
+
end
|
150
|
+
|
151
|
+
context 'search_pathnames' do
|
152
|
+
subject(:search_pathnames) do
|
153
|
+
ancestor_templates.map(&:search_pathnames)
|
154
|
+
end
|
155
|
+
|
156
|
+
it "has 'module/classes' before 'module/ancestors'" do
|
157
|
+
expect(
|
158
|
+
search_pathnames.all? { |template_search_pathnames|
|
159
|
+
module_classes_index = template_search_pathnames.index(Pathname.new('module/classes'))
|
160
|
+
module_ancestors_index = template_search_pathnames.index(Pathname.new('module/ancestors'))
|
161
|
+
|
162
|
+
module_classes_index < module_ancestors_index
|
163
|
+
}
|
164
|
+
).to be_true
|
165
|
+
end
|
166
|
+
end
|
167
|
+
end
|
168
|
+
end
|
169
|
+
|
170
|
+
context 'write' do
|
171
|
+
subject(:write) do
|
172
|
+
described_class.write(attributes)
|
173
|
+
end
|
174
|
+
|
175
|
+
context 'with valid' do
|
176
|
+
let(:attributes) do
|
177
|
+
{
|
178
|
+
module_class: module_class
|
179
|
+
}
|
180
|
+
end
|
181
|
+
|
182
|
+
it { should be_true }
|
183
|
+
|
184
|
+
it 'writes template' do
|
185
|
+
# memoize attributes so any other writes besides the one under-test are already run.
|
186
|
+
attributes
|
187
|
+
|
188
|
+
described_class.any_instance.should_receive(:write)
|
189
|
+
|
190
|
+
write
|
191
|
+
end
|
192
|
+
end
|
193
|
+
|
194
|
+
context 'without valid' do
|
195
|
+
let(:attributes) do
|
196
|
+
{}
|
197
|
+
end
|
198
|
+
|
199
|
+
it { should be_false }
|
200
|
+
|
201
|
+
it 'does not write template' do
|
202
|
+
described_class.any_instance.should_not_receive(:write)
|
203
|
+
|
204
|
+
write
|
205
|
+
end
|
206
|
+
end
|
207
|
+
end
|
208
|
+
|
209
|
+
context '#write' do
|
210
|
+
subject(:write) do
|
211
|
+
template.write
|
212
|
+
end
|
213
|
+
|
214
|
+
it 'writes each ancestor template' do
|
215
|
+
template.ancestor_templates.each do |ancestor_template|
|
216
|
+
expect(ancestor_template).to receive(:write)
|
217
|
+
end
|
218
|
+
|
219
|
+
write
|
220
|
+
end
|
221
|
+
end
|
222
|
+
end
|
@@ -0,0 +1,201 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Metasploit::Model::Module::Instance::Spec::Template do
|
4
|
+
subject(:template) do
|
5
|
+
described_class.new(
|
6
|
+
module_instance: module_instance
|
7
|
+
)
|
8
|
+
end
|
9
|
+
|
10
|
+
let(:module_instance) do
|
11
|
+
FactoryGirl.build(:dummy_module_instance)
|
12
|
+
end
|
13
|
+
|
14
|
+
context 'validations' do
|
15
|
+
context '#class_template' do
|
16
|
+
subject(:class_template_errors) do
|
17
|
+
template.errors[:class_template]
|
18
|
+
end
|
19
|
+
|
20
|
+
context 'presence' do
|
21
|
+
let(:error) do
|
22
|
+
I18n.translate!('errors.messages.blank')
|
23
|
+
end
|
24
|
+
|
25
|
+
context 'with nil' do
|
26
|
+
before(:each) do
|
27
|
+
allow(template).to receive(:class_template).and_return(nil)
|
28
|
+
template.valid?
|
29
|
+
end
|
30
|
+
|
31
|
+
it { should include error }
|
32
|
+
end
|
33
|
+
|
34
|
+
context 'without nil' do
|
35
|
+
before(:each) do
|
36
|
+
template.valid?
|
37
|
+
end
|
38
|
+
|
39
|
+
it { should_not include error }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
context '#class_template_valid' do
|
44
|
+
let(:error) do
|
45
|
+
I18n.translate!('errors.messages.invalid')
|
46
|
+
end
|
47
|
+
|
48
|
+
context 'with #class_template' do
|
49
|
+
context 'with valid' do
|
50
|
+
before(:each) do
|
51
|
+
template.valid?
|
52
|
+
end
|
53
|
+
|
54
|
+
it { should_not include(error) }
|
55
|
+
end
|
56
|
+
|
57
|
+
context 'without valid' do
|
58
|
+
before(:each) do
|
59
|
+
expect(template.class_template).to receive(:valid?).and_return(false)
|
60
|
+
template.valid?
|
61
|
+
end
|
62
|
+
|
63
|
+
it { should include(error) }
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
context 'without #class_template' do
|
68
|
+
before(:each) do
|
69
|
+
allow(template).to receive(:class_template).and_return(nil)
|
70
|
+
template.valid?
|
71
|
+
end
|
72
|
+
|
73
|
+
it { should_not include(error) }
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
it { should validate_presence_of :module_instance }
|
79
|
+
end
|
80
|
+
|
81
|
+
context '#class_template' do
|
82
|
+
subject(:class_template) do
|
83
|
+
template.class_template
|
84
|
+
end
|
85
|
+
|
86
|
+
context 'with #module_instance' do
|
87
|
+
it { should be_a Metasploit::Model::Module::Class::Spec::Template }
|
88
|
+
|
89
|
+
context '#ancestor_templates' do
|
90
|
+
subject(:ancestor_templates) do
|
91
|
+
class_template.ancestor_templates
|
92
|
+
end
|
93
|
+
|
94
|
+
context 'locals' do
|
95
|
+
subject(:ancestor_template_locals) do
|
96
|
+
ancestor_templates.map(&:locals)
|
97
|
+
end
|
98
|
+
|
99
|
+
context '[:module_instance]' do
|
100
|
+
subject(:module_instances) do
|
101
|
+
ancestor_template_locals.collect { |locals|
|
102
|
+
locals[:module_instance]
|
103
|
+
}
|
104
|
+
end
|
105
|
+
|
106
|
+
it 'is #module_instance' do
|
107
|
+
expect(
|
108
|
+
module_instances.all? { |actual_module_instance|
|
109
|
+
actual_module_instance == module_instance
|
110
|
+
}
|
111
|
+
).to be_true
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
context 'search_pathnames' do
|
117
|
+
subject(:search_pathnames) do
|
118
|
+
ancestor_templates.map(&:search_pathnames)
|
119
|
+
end
|
120
|
+
|
121
|
+
it "has 'module/instances', then 'module/classes', then 'module/ancestors'" do
|
122
|
+
search_pathnames.each do |actual_search_pathnames|
|
123
|
+
module_instances_index = actual_search_pathnames.index(Pathname.new('module/instances'))
|
124
|
+
module_classes_index = actual_search_pathnames.index(Pathname.new('module/classes'))
|
125
|
+
module_ancestors_index = actual_search_pathnames.index(Pathname.new('module/ancestors'))
|
126
|
+
|
127
|
+
expect(module_instances_index).to be < module_classes_index
|
128
|
+
expect(module_classes_index).to be < module_ancestors_index
|
129
|
+
end
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
133
|
+
|
134
|
+
context '#module_class' do
|
135
|
+
it 'is module_instance.module_class' do
|
136
|
+
expect(class_template.module_class).to eq(module_instance.module_class)
|
137
|
+
end
|
138
|
+
end
|
139
|
+
end
|
140
|
+
|
141
|
+
context 'without #module_instance' do
|
142
|
+
let(:module_instance) do
|
143
|
+
nil
|
144
|
+
end
|
145
|
+
|
146
|
+
it { should be_nil }
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
context 'write' do
|
151
|
+
subject(:write) do
|
152
|
+
described_class.write(attributes)
|
153
|
+
end
|
154
|
+
|
155
|
+
context 'with valid' do
|
156
|
+
let(:attributes) do
|
157
|
+
{
|
158
|
+
module_instance: module_instance
|
159
|
+
}
|
160
|
+
end
|
161
|
+
|
162
|
+
it { should be_true }
|
163
|
+
|
164
|
+
it 'writes template' do
|
165
|
+
# memoize attributes so any other writes besides the one under-test are already run.
|
166
|
+
attributes
|
167
|
+
|
168
|
+
described_class.any_instance.should_receive(:write)
|
169
|
+
|
170
|
+
write
|
171
|
+
end
|
172
|
+
end
|
173
|
+
|
174
|
+
context 'without valid' do
|
175
|
+
let(:attributes) do
|
176
|
+
{}
|
177
|
+
end
|
178
|
+
|
179
|
+
it { should be_false }
|
180
|
+
|
181
|
+
it 'does not write template' do
|
182
|
+
described_class.any_instance.should_not_receive(:write)
|
183
|
+
|
184
|
+
write
|
185
|
+
end
|
186
|
+
end
|
187
|
+
end
|
188
|
+
|
189
|
+
context '#write' do
|
190
|
+
subject(:write) do
|
191
|
+
template.write
|
192
|
+
end
|
193
|
+
|
194
|
+
it 'delegates to #class_template' do
|
195
|
+
expected = double('#write')
|
196
|
+
|
197
|
+
expect(template.class_template).to receive(:write).and_return(expected)
|
198
|
+
expect(write).to eq(expected)
|
199
|
+
end
|
200
|
+
end
|
201
|
+
end
|