curation_concerns 0.1.0 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +7 -9
- data/.rspec +1 -1
- data/.rubocop.yml +185 -0
- data/.travis.yml +0 -10
- data/CONTRIBUTING.md +117 -0
- data/Gemfile +5 -2
- data/README.md +18 -11
- data/Rakefile +23 -11
- data/VERSION +1 -1
- data/app/assets/images/audio.png +0 -0
- data/app/assets/images/loading.gif +0 -0
- data/app/assets/images/progressbar.gif +0 -0
- data/app/assets/javascripts/curation_concerns/application.js +2 -8
- data/app/assets/javascripts/curation_concerns/curation_concerns.js +1 -15
- data/app/assets/javascripts/curation_concerns/facet_mine.js +4 -10
- data/app/assets/javascripts/curation_concerns/fileupload.js +6 -0
- data/app/assets/javascripts/curation_concerns/uploader.js +183 -0
- data/app/assets/stylesheets/curation_concerns/_curation_concerns.scss +3 -0
- data/app/assets/stylesheets/curation_concerns/_positioning.scss +6 -0
- data/app/assets/stylesheets/curation_concerns/fileupload/jquery.fileupload-ui.scss +86 -0
- data/app/assets/stylesheets/curation_concerns/fileupload/thumbnail-scaling.css +3 -0
- data/app/assets/stylesheets/curation_concerns/fileupload.scss +48 -0
- data/app/assets/stylesheets/curation_concerns/modules/attributes.scss +10 -0
- data/app/assets/stylesheets/curation_concerns/modules/embargoes.scss +1 -1
- data/app/assets/stylesheets/curation_concerns/modules/forms.scss +0 -10
- data/app/assets/stylesheets/curation_concerns/modules/search_results.scss +7 -8
- data/app/controllers/concerns/curation_concerns/api.rb +77 -0
- data/app/controllers/concerns/curation_concerns/application_controller_behavior.rb +30 -12
- data/app/controllers/concerns/curation_concerns/catalog_controller.rb +9 -276
- data/app/controllers/concerns/curation_concerns/collections_controller_behavior.rb +51 -40
- data/app/controllers/concerns/curation_concerns/curation_concern_controller.rb +60 -30
- data/app/controllers/concerns/curation_concerns/download_behavior.rb +51 -37
- data/app/controllers/concerns/curation_concerns/embargoes_controller_behavior.rb +29 -29
- data/app/controllers/concerns/curation_concerns/file_sets_controller_behavior.rb +198 -0
- data/app/controllers/concerns/curation_concerns/leases_controller_behavior.rb +27 -20
- data/app/controllers/concerns/curation_concerns/manages_embargoes.rb +2 -7
- data/app/controllers/concerns/curation_concerns/parent_container.rb +20 -4
- data/app/controllers/concerns/curation_concerns/single_use_links_controller_behavior.rb +48 -0
- data/app/controllers/concerns/curation_concerns/single_use_links_viewer_controller_behavior.rb +75 -0
- data/app/controllers/concerns/curation_concerns/themed_layout_controller.rb +0 -1
- data/app/controllers/concerns/curation_concerns/upload_sets_controller_behavior.rb +38 -0
- data/app/controllers/concerns/curation_concerns/welcome_controller_behavior.rb +8 -0
- data/app/controllers/concerns/curation_concerns/without_namespace.rb +2 -1
- data/app/controllers/curation_concerns/classify_concerns_controller.rb +9 -9
- data/app/controllers/curation_concerns/file_sets_controller.rb +5 -0
- data/app/controllers/curation_concerns/permissions_controller.rb +2 -3
- data/app/controllers/curation_concerns/single_use_links_controller.rb +5 -0
- data/app/controllers/curation_concerns/single_use_links_viewer_controller.rb +21 -0
- data/app/controllers/downloads_controller.rb +0 -1
- data/app/controllers/embargoes_controller.rb +0 -2
- data/app/controllers/leases_controller.rb +0 -2
- data/app/controllers/registrations_controller.rb +1 -2
- data/app/controllers/upload_sets_controller.rb +3 -0
- data/app/controllers/welcome_controller.rb +3 -0
- data/app/forms/curation_concerns/forms/collection_edit_form.rb +18 -2
- data/app/forms/curation_concerns/forms/file_set_edit_form.rb +15 -0
- data/app/forms/curation_concerns/forms/work_form.rb +57 -0
- data/app/helpers/curation_concerns/ability_helper.rb +24 -24
- data/app/helpers/curation_concerns/catalog_helper.rb +9 -8
- data/app/helpers/curation_concerns/collections_helper.rb +9 -12
- data/app/helpers/curation_concerns/embargo_helper.rb +0 -2
- data/app/helpers/curation_concerns/file_set_helper.rb +31 -0
- data/app/helpers/curation_concerns/lease_helper.rb +0 -3
- data/app/helpers/curation_concerns/main_app_helpers.rb +1 -3
- data/app/helpers/curation_concerns/render_constraints_helper.rb +5 -5
- data/app/helpers/curation_concerns/search_paths_helper.rb +5 -7
- data/app/helpers/curation_concerns/title_helper.rb +3 -7
- data/app/helpers/curation_concerns/url_helper.rb +4 -6
- data/app/inputs/multifile_input.rb +8 -0
- data/app/jobs/visibility_copy_job.rb +22 -0
- data/app/presenters/curation_concerns/collection_presenter.rb +14 -32
- data/app/presenters/curation_concerns/embargo_presenter.rb +26 -0
- data/app/presenters/curation_concerns/file_set_presenter.rb +34 -0
- data/app/presenters/curation_concerns/lease_presenter.rb +30 -0
- data/app/presenters/curation_concerns/model_proxy.rb +27 -0
- data/app/presenters/curation_concerns/permission_badge.rb +61 -0
- data/app/presenters/curation_concerns/presenter_factory.rb +45 -0
- data/app/presenters/curation_concerns/presents_attributes.rb +25 -0
- data/app/presenters/curation_concerns/version_list_presenter.rb +18 -0
- data/app/presenters/curation_concerns/version_presenter.rb +27 -0
- data/app/presenters/curation_concerns/work_show_presenter.rb +33 -0
- data/app/renderers/curation_concerns/attribute_renderer.rb +75 -0
- data/app/search_builders/curation_concerns/deactivated_embargo_search_builder.rb +10 -0
- data/app/search_builders/curation_concerns/deactivated_lease_search_builder.rb +10 -0
- data/app/search_builders/curation_concerns/embargo_search_builder.rb +23 -0
- data/app/search_builders/curation_concerns/expired_embargo_search_builder.rb +11 -0
- data/app/search_builders/curation_concerns/expired_lease_search_builder.rb +11 -0
- data/app/search_builders/curation_concerns/lease_search_builder.rb +23 -0
- data/app/search_builders/curation_concerns/search_builder.rb +10 -16
- data/app/services/curation_concerns/curation_concern.rb +0 -5
- data/app/services/curation_concerns/embargo_service.rb +26 -4
- data/app/services/curation_concerns/lease_service.rb +14 -5
- data/app/services/curation_concerns/parent_service.rb +19 -0
- data/app/services/curation_concerns/restriction_service.rb +24 -0
- data/app/services/rights_service.rb +14 -0
- data/app/views/catalog/_action_menu_partials/_collection.html.erb +1 -1
- data/app/views/catalog/_action_menu_partials/_default.html.erb +5 -3
- data/app/views/catalog/_document_list.html.erb +1 -1
- data/app/views/catalog/index.html.erb +1 -35
- data/app/views/collections/_edit_descriptions.html.erb +3 -4
- data/app/views/collections/_form.html.erb +1 -1
- data/app/views/collections/_form_permission.html.erb +1 -1
- data/app/views/collections/_search_form.html.erb +10 -0
- data/app/views/collections/_show_actions.html.erb +3 -3
- data/app/views/collections/_sort_and_per_page.html.erb +2 -2
- data/app/views/collections/show.html.erb +6 -6
- data/app/views/curation_concerns/base/_attribute_rows.html.erb +7 -0
- data/app/views/curation_concerns/base/_attributes.html.erb +6 -13
- data/app/views/curation_concerns/base/_form.html.erb +4 -5
- data/app/views/curation_concerns/base/_form_descriptive_fields.erb +2 -4
- data/app/views/curation_concerns/base/_form_files_and_links.html.erb +3 -5
- data/app/views/curation_concerns/base/_form_permission.html.erb +13 -26
- data/app/views/curation_concerns/base/_form_permission_note.html.erb +15 -0
- data/app/views/curation_concerns/base/_form_permission_under_embargo.html.erb +2 -2
- data/app/views/curation_concerns/base/_form_permission_under_lease.html.erb +2 -2
- data/app/views/curation_concerns/base/_form_representative_image.html.erb +16 -4
- data/app/views/curation_concerns/base/_form_rights.html.erb +17 -0
- data/app/views/curation_concerns/base/_form_supplementary_fields.html.erb +4 -9
- data/app/views/curation_concerns/base/_related_files.html.erb +4 -4
- data/app/views/curation_concerns/base/_representative_media.html.erb +2 -4
- data/app/views/curation_concerns/base/_versioning.html.erb +23 -0
- data/app/views/curation_concerns/base/show.html.erb +13 -10
- data/app/views/curation_concerns/base/show.json.jbuilder +1 -0
- data/app/views/curation_concerns/base/versions.html.erb +6 -0
- data/app/views/curation_concerns/file_sets/_actions.html.erb +16 -0
- data/app/views/curation_concerns/file_sets/_file_set.html.erb +12 -0
- data/app/views/curation_concerns/{generic_files → file_sets}/_form.html.erb +7 -7
- data/app/views/curation_concerns/file_sets/_multiple_upload.html.erb +3 -0
- data/app/views/curation_concerns/{generic_files → file_sets}/edit.html.erb +0 -0
- data/app/views/curation_concerns/file_sets/jq_upload.json.jbuilder +8 -0
- data/app/views/curation_concerns/file_sets/media_display/_audio.html.erb +6 -0
- data/app/views/curation_concerns/file_sets/media_display/_default.html.erb +4 -0
- data/app/views/curation_concerns/file_sets/media_display/_image.html.erb +8 -0
- data/app/views/curation_concerns/file_sets/media_display/_office_document.html.erb +7 -0
- data/app/views/curation_concerns/file_sets/media_display/_pdf.html.erb +7 -0
- data/app/views/curation_concerns/file_sets/media_display/_video.html.erb +6 -0
- data/app/views/curation_concerns/file_sets/show.html.erb +15 -0
- data/app/views/curation_concerns/file_sets/show.json.jbuilder +1 -0
- data/app/views/curation_concerns/file_sets/upload/_alerts.html.erb +19 -0
- data/app/views/curation_concerns/file_sets/upload/_form.html.erb +6 -0
- data/app/views/curation_concerns/file_sets/upload/_form_fields.html.erb +45 -0
- data/app/views/curation_concerns/file_sets/upload/_script_templates.html.erb +61 -0
- data/app/views/curation_concerns/single_use_links/new_download.html.erb +5 -0
- data/app/views/curation_concerns/single_use_links/new_show.html.erb +5 -0
- data/app/views/curation_concerns/single_use_links_viewer/show.html.erb +10 -0
- data/app/views/error/single_use_error.html.erb +19 -0
- data/app/views/layouts/error.html.erb +33 -0
- data/app/views/leases/_list_expired_active_leases.html.erb +6 -1
- data/app/views/records/_rights_modal.html.erb +1 -0
- data/app/views/records/edit_fields/_default.html.erb +5 -0
- data/app/views/records/show_fields/_default.html.erb +6 -0
- data/app/views/shared/_add_content.html.erb +2 -14
- data/app/views/shared/_add_works.html.erb +14 -0
- data/app/views/shared/_my_actions.html.erb +9 -1
- data/app/views/shared/_site_actions.html.erb +1 -1
- data/app/views/shared/_site_search.html.erb +7 -7
- data/app/views/upload_sets/_edit.js.erb +15 -0
- data/app/views/upload_sets/_metadata.html.erb +50 -0
- data/app/views/upload_sets/_more_metadata.html.erb +7 -0
- data/app/views/upload_sets/edit.html.erb +26 -0
- data/app/views/{catalog/_home_text.html.erb → welcome/index.html.erb} +1 -0
- data/config/initializers/simple_form.rb +14 -0
- data/config/jetty.yml +5 -0
- data/config/locales/curation_concerns.en.yml +25 -4
- data/config/routes.rb +5 -0
- data/curation_concerns.gemspec +4 -6
- data/lib/curation_concerns/callbacks/registry.rb +48 -0
- data/lib/curation_concerns/callbacks.rb +26 -0
- data/lib/curation_concerns/controller_resource.rb +4 -4
- data/lib/curation_concerns/engine.rb +4 -2
- data/lib/curation_concerns/rails/routes.rb +23 -19
- data/lib/curation_concerns/single_use_error.rb +3 -0
- data/lib/curation_concerns/spec_support.rb +0 -2
- data/lib/curation_concerns/version.rb +1 -1
- data/lib/curation_concerns.rb +1 -2
- data/lib/generators/curation_concerns/install_generator.rb +34 -30
- data/lib/generators/curation_concerns/templates/catalog_controller.rb +236 -0
- data/lib/generators/curation_concerns/templates/config/authorities/rights.yml +19 -0
- data/lib/generators/curation_concerns/templates/{curation_concerns.css.scss → curation_concerns.scss} +0 -0
- data/lib/generators/curation_concerns/work/templates/actor_spec.rb.erb +1 -1
- data/lib/generators/curation_concerns/work/templates/controller_spec.rb.erb +1 -1
- data/lib/generators/curation_concerns/work/templates/form.rb.erb +8 -0
- data/lib/generators/curation_concerns/work/templates/form_spec.rb.erb +10 -0
- data/lib/generators/curation_concerns/work/templates/model.rb.erb +2 -2
- data/lib/generators/curation_concerns/work/templates/model_spec.rb.erb +1 -1
- data/lib/generators/curation_concerns/work/work_generator.rb +31 -26
- data/spec/abilities/collection_abilities_spec.rb +13 -13
- data/spec/abilities/embargo_and_lease_ability_spec.rb +23 -0
- data/spec/abilities/file_set_abilities_spec.rb +67 -0
- data/spec/abilities/generic_work_abilities_spec.rb +12 -12
- data/spec/actors/curation_concerns/embargo_actor_spec.rb +38 -0
- data/spec/actors/curation_concerns/file_set_actor_spec.rb +180 -0
- data/spec/actors/curation_concerns/lease_actor_spec.rb +39 -0
- data/spec/actors/curation_concerns/manages_embargoes_actor_spec.rb +44 -38
- data/spec/actors/curation_concerns/work_actor_spec.rb +121 -63
- data/spec/controllers/catalog_controller_spec.rb +30 -32
- data/spec/controllers/curation_concerns/classify_concerns_controller_spec.rb +2 -3
- data/spec/controllers/curation_concerns/collections_controller_spec.rb +93 -76
- data/spec/controllers/curation_concerns/file_sets_controller_json_spec.rb +106 -0
- data/spec/controllers/curation_concerns/file_sets_controller_spec.rb +237 -0
- data/spec/controllers/curation_concerns/generic_works_controller_json_spec.rb +85 -0
- data/spec/controllers/curation_concerns/generic_works_controller_spec.rb +84 -72
- data/spec/controllers/curation_concerns/permissions_controller_spec.rb +8 -11
- data/spec/controllers/curation_concerns/single_use_links_controller_spec.rb +79 -0
- data/spec/controllers/curation_concerns/single_use_links_viewer_controller_spec.rb +74 -0
- data/spec/controllers/downloads_controller_spec.rb +49 -24
- data/spec/controllers/embargoes_controller_spec.rb +42 -51
- data/spec/controllers/leases_controller_spec.rb +53 -42
- data/spec/controllers/upload_sets_controller_spec.rb +76 -0
- data/spec/controllers/welcome_controller_spec.rb +12 -0
- data/spec/factories/collections.rb +5 -1
- data/spec/factories/{generic_files.rb → file_sets.rb} +6 -6
- data/spec/factories/generic_works.rb +5 -6
- data/spec/factories/users.rb +2 -4
- data/spec/features/add_file_spec.rb +11 -12
- data/spec/features/catalog_search_spec.rb +43 -0
- data/spec/features/collection_spec.rb +61 -46
- data/spec/features/create_work_spec.rb +26 -19
- data/spec/features/embargo_spec.rb +13 -12
- data/spec/features/lease_spec.rb +15 -16
- data/spec/features/update_file_spec.rb +11 -13
- data/spec/features/work_generator_spec.rb +34 -26
- data/spec/{helpers/curation_concerns/.keep → fixtures/empty_file.txt} +0 -0
- data/spec/fixtures/test.pdf +0 -0
- data/spec/forms/collection_edit_form_spec.rb +53 -9
- data/spec/forms/file_set_edit_form_spec.rb +53 -0
- data/spec/forms/work_form_spec.rb +54 -0
- data/spec/helpers/catalog_helper_spec.rb +9 -10
- data/spec/helpers/configuration_helper_spec.rb +1 -2
- data/spec/helpers/curation_concerns/collections_helper_spec.rb +8 -9
- data/spec/helpers/curation_concerns/file_set_helper_spec.rb +61 -0
- data/spec/helpers/render_constraints_helper_spec.rb +4 -4
- data/spec/helpers/url_helper_spec.rb +8 -7
- data/spec/indexers/collection_indexer_spec.rb +14 -0
- data/spec/indexers/file_set_indexing_service_spec.rb +69 -0
- data/spec/indexers/generic_work_indexing_service_spec.rb +22 -0
- data/spec/inputs/multifile_input_spec.rb +32 -0
- data/spec/jobs/active_fedora_id_based_job_spec.rb +10 -8
- data/spec/jobs/audit_job_spec.rb +28 -20
- data/spec/jobs/characterize_job_spec.rb +10 -15
- data/spec/jobs/create_derivatives_job_spec.rb +11 -9
- data/spec/jobs/import_url_job_spec.rb +14 -21
- data/spec/jobs/ingest_file_job_spec.rb +45 -0
- data/spec/jobs/ingest_local_file_job_spec.rb +13 -15
- data/spec/jobs/upload_set_update_job_spec.rb +30 -0
- data/spec/jobs/visibility_copy_job_spec.rb +61 -0
- data/spec/lib/curation_concerns/callbacks/registry_spec.rb +54 -0
- data/spec/lib/curation_concerns/callbacks_spec.rb +27 -0
- data/spec/lib/curation_concerns/messages_spec.rb +29 -30
- data/spec/lib/curation_concerns/readable_permissions_spec.rb +18 -20
- data/spec/lib/curation_concerns/writable_permissions_spec.rb +2 -4
- data/spec/matchers/metadata_field_matchers.rb +1 -1
- data/spec/matchers/response_matchers.rb +2 -2
- data/spec/matchers.rb +3 -2
- data/spec/models/checksum_audit_log_spec.rb +37 -32
- data/spec/models/curation_concerns/collection_behavior_spec.rb +50 -37
- data/spec/models/curation_concerns/file_set/derivatives_spec.rb +84 -0
- data/spec/models/curation_concerns/work_behavior_spec.rb +53 -0
- data/spec/models/file_set_spec.rb +601 -0
- data/spec/models/generic_work_spec.rb +15 -14
- data/spec/models/single_use_link_spec.rb +69 -0
- data/spec/models/solr_document_spec.rb +67 -0
- data/spec/models/upload_set_spec.rb +39 -0
- data/spec/models/user_spec.rb +7 -8
- data/spec/presenters/curation_concerns/collection_presenter_spec.rb +8 -24
- data/spec/presenters/curation_concerns/file_set_presenter_spec.rb +59 -0
- data/spec/presenters/curation_concerns/permission_badge_spec.rb +29 -0
- data/spec/presenters/curation_concerns/presenter_factory_spec.rb +29 -0
- data/spec/presenters/curation_concerns/version_list_presenter_spec.rb +32 -0
- data/spec/presenters/curation_concerns/version_presenter_spec.rb +51 -0
- data/spec/presenters/curation_concerns/work_show_presenter_spec.rb +35 -0
- data/spec/presenters/embargo_presenter_spec.rb +48 -0
- data/spec/presenters/lease_presenter_spec.rb +48 -0
- data/spec/renderers/curation_concerns/attribute_renderer_spec.rb +14 -0
- data/spec/routing/curation_concerns/routes_spec.rb +38 -12
- data/spec/routing/route_spec.rb +38 -39
- data/spec/search_builders/curation_concerns/embargo_search_builder_spec.rb +17 -0
- data/spec/search_builders/curation_concerns/lease_search_builder_spec.rb +17 -0
- data/spec/search_builders/curation_concerns/search_builder_spec.rb +60 -0
- data/spec/services/derivative_path_spec.rb +16 -0
- data/spec/services/embargo_service_spec.rb +15 -14
- data/spec/services/file_set_audit_service_spec.rb +71 -0
- data/spec/services/lease_service_spec.rb +13 -13
- data/spec/services/lock_manager_spec.rb +12 -0
- data/spec/services/parent_service_spec.rb +13 -0
- data/spec/services/persist_derivatives_spec.rb +24 -0
- data/spec/services/persist_directly_contained_output_file_service_spec.rb +14 -0
- data/spec/services/repository_audit_service_spec.rb +8 -7
- data/spec/services/rights_service_spec.rb +17 -0
- data/spec/services/thumbnail_path_service_spec.rb +43 -0
- data/spec/services/versioning_service_spec.rb +8 -9
- data/spec/spec_helper.rb +21 -13
- data/spec/support/curation_concerns/factory_helpers.rb +1 -0
- data/spec/support/features/fixture_file_upload.rb +3 -1
- data/spec/support/features/session_helpers.rb +3 -4
- data/spec/support/features.rb +1 -4
- data/spec/support/input_support.rb +11 -0
- data/spec/support/matchers/api_responses.rb +22 -0
- data/spec/support/shared/shared_examples_has_dc_metadata.rb +0 -2
- data/spec/support/shared/shared_examples_is_embargoable.rb +1 -3
- data/spec/support/shared/shared_examples_with_access_rights.rb +13 -16
- data/spec/tasks/rake_spec.rb +9 -11
- data/spec/test_app_templates/Gemfile.extra +4 -1
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +3 -35
- data/spec/views/catalog/index.html.erb_spec.rb +7 -10
- data/spec/views/curation_concerns/base/_attributes.html.erb_spec.rb +9 -6
- data/spec/views/curation_concerns/base/_form_permission.html.erb_spec.rb +13 -0
- data/spec/views/curation_concerns/base/show.html.erb_spec.rb +35 -15
- data/spec/views/curation_concerns/base/show.json.jbuilder_spec.rb +21 -0
- data/spec/views/curation_concerns/file_sets/_file_set.html.erb_spec.rb +37 -0
- data/spec/views/curation_concerns/file_sets/show.json.jbuilder_spec.rb +21 -0
- data/spec/views/curation_concerns/permissions/confirm.html.erb_spec.rb +6 -6
- data/spec/views/error/single_use_error.html.erb_spec.rb +8 -0
- data/spec/views/layouts/error.html.erb_spec.rb +8 -0
- data/spec/views/shared/_add_content.html.erb_spec.rb +33 -20
- data/spec/views/shared/_my_actions.html.erb_spec.rb +18 -6
- data/spec/views/single_use_links/new_download.html.erb_spec.rb +29 -0
- data/spec/views/single_use_links_viewer/show.html.erb_spec.rb +32 -0
- data/tasks/jetty.rake +1 -1
- data/vendor/assets/javascrips/fileupload/jquery.fileupload-process.js +175 -0
- data/vendor/assets/javascrips/fileupload/jquery.fileupload-ui.js +710 -0
- data/vendor/assets/javascrips/fileupload/jquery.fileupload-validate.js +122 -0
- data/vendor/assets/javascrips/fileupload/jquery.fileupload.js +1477 -0
- data/vendor/assets/javascrips/fileupload/locale.js +27 -0
- data/vendor/assets/javascrips/fileupload/tmpl.js +87 -0
- metadata +242 -213
- data/app/assets/javascripts/curation_concerns/help_modal.js +0 -36
- data/app/assets/javascripts/curation_concerns/link_groups.js.coffee +0 -123
- data/app/assets/javascripts/curation_concerns/link_users.js.coffee +0 -126
- data/app/assets/javascripts/curation_concerns/proxy_rights.js.coffee +0 -95
- data/app/assets/javascripts/curation_concerns/proxy_submission.js +0 -23
- data/app/assets/javascripts/curation_concerns/select_works.js.coffee +0 -20
- data/app/controllers/catalog_controller.rb +0 -3
- data/app/controllers/concerns/curation_concerns/generic_files_controller_behavior.rb +0 -149
- data/app/controllers/curation_concerns/generic_files_controller.rb +0 -13
- data/app/datastreams/curation_concerns/generic_work_rdf_properties.rb +0 -57
- data/app/datastreams/generic_work_metadata.rb +0 -3
- data/app/forms/curation_concerns/forms/generic_file_edit_form.rb +0 -15
- data/app/forms/curation_concerns/forms/generic_work_edit_form.rb +0 -9
- data/app/helpers/curation_concerns/attribute_helper.rb +0 -67
- data/app/helpers/curation_concerns/generic_file_helper.rb +0 -19
- data/app/helpers/curation_concerns/thumbnail_helper.rb +0 -11
- data/app/presenters/curation_concerns/generic_file_presenter.rb +0 -14
- data/app/presenters/curation_concerns/generic_work_presenter.rb +0 -13
- data/app/views/catalog/_index_default.html.erb +0 -17
- data/app/views/collections/_form_representative_image.html.erb +0 -13
- data/app/views/collections/_identifier_and_action.html.erb +0 -15
- data/app/views/curation_concerns/base/_form_content_license.html.erb +0 -16
- data/app/views/curation_concerns/base/_form_editors.html.erb +0 -15
- data/app/views/curation_concerns/generic_files/_actions.html.erb +0 -16
- data/app/views/curation_concerns/generic_files/_generic_file.html.erb +0 -12
- data/app/views/curation_concerns/generic_files/_media_display.html.erb +0 -19
- data/app/views/curation_concerns/generic_files/jq_upload.json.jbuilder +0 -8
- data/app/views/curation_concerns/generic_files/show.html.erb +0 -15
- data/app/workers/visibility_copy_worker.rb +0 -30
- data/curation_concerns-models/.gitignore +0 -17
- data/curation_concerns-models/Gemfile +0 -4
- data/curation_concerns-models/LICENSE.md +0 -177
- data/curation_concerns-models/README.md +0 -42
- data/curation_concerns-models/Rakefile +0 -1
- data/curation_concerns-models/app/actors/concerns/curation_concerns/manages_embargoes_actor.rb +0 -99
- data/curation_concerns-models/app/actors/curation_concerns/base_actor.rb +0 -90
- data/curation_concerns-models/app/actors/curation_concerns/generic_file_actor.rb +0 -150
- data/curation_concerns-models/app/actors/curation_concerns/work_actor_behavior.rb +0 -88
- data/curation_concerns-models/app/jobs/active_fedora_id_based_job.rb +0 -22
- data/curation_concerns-models/app/jobs/active_fedora_pid_based_job.rb +0 -6
- data/curation_concerns-models/app/jobs/audit_job.rb +0 -58
- data/curation_concerns-models/app/jobs/characterize_job.rb +0 -11
- data/curation_concerns-models/app/jobs/copy_permissions_job.rb +0 -24
- data/curation_concerns-models/app/jobs/create_derivatives_job.rb +0 -15
- data/curation_concerns-models/app/jobs/import_url_job.rb +0 -56
- data/curation_concerns-models/app/jobs/ingest_local_file_job.rb +0 -48
- data/curation_concerns-models/app/jobs/resolrize_job.rb +0 -9
- data/curation_concerns-models/app/models/checksum_audit_log.rb +0 -21
- data/curation_concerns-models/app/models/concerns/curation_concerns/ability.rb +0 -34
- data/curation_concerns-models/app/models/concerns/curation_concerns/basic_metadata.rb +0 -87
- data/curation_concerns-models/app/models/concerns/curation_concerns/collection_behavior.rb +0 -47
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/belongs_to_works.rb +0 -53
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/characterization.rb +0 -89
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/content.rb +0 -8
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/export.rb +0 -343
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/full_text_indexing.rb +0 -12
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/indexing.rb +0 -14
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file/versions.rb +0 -16
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file.rb +0 -5
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_file_behavior.rb +0 -44
- data/curation_concerns-models/app/models/concerns/curation_concerns/generic_work_behavior.rb +0 -38
- data/curation_concerns-models/app/models/concerns/curation_concerns/has_representative.rb +0 -14
- data/curation_concerns-models/app/models/concerns/curation_concerns/human_readable_type.rb +0 -23
- data/curation_concerns-models/app/models/concerns/curation_concerns/permissions/readable.rb +0 -19
- data/curation_concerns-models/app/models/concerns/curation_concerns/permissions/writable.rb +0 -75
- data/curation_concerns-models/app/models/concerns/curation_concerns/permissions.rb +0 -7
- data/curation_concerns-models/app/models/concerns/curation_concerns/serializers.rb +0 -15
- data/curation_concerns-models/app/models/concerns/curation_concerns/solr_document_behavior.rb +0 -135
- data/curation_concerns-models/app/models/concerns/curation_concerns/user.rb +0 -65
- data/curation_concerns-models/app/models/concerns/curation_concerns/with_basic_metadata.rb +0 -98
- data/curation_concerns-models/app/models/concerns/curation_concerns/with_generic_files.rb +0 -29
- data/curation_concerns-models/app/models/curation_concerns/classify_concern.rb +0 -47
- data/curation_concerns-models/app/models/curation_concerns/quick_classification_query.rb +0 -31
- data/curation_concerns-models/app/models/datastreams/fits_datastream.rb +0 -148
- data/curation_concerns-models/app/models/version_committer.rb +0 -2
- data/curation_concerns-models/app/services/curation_concerns/characterization_service.rb +0 -71
- data/curation_concerns-models/app/services/curation_concerns/full_text_extraction_service.rb +0 -38
- data/curation_concerns-models/app/services/curation_concerns/generic_file_audit_service.rb +0 -85
- data/curation_concerns-models/app/services/curation_concerns/generic_file_indexing_service.rb +0 -14
- data/curation_concerns-models/app/services/curation_concerns/generic_work_indexing_service.rb +0 -16
- data/curation_concerns-models/app/services/curation_concerns/noid.rb +0 -23
- data/curation_concerns-models/app/services/curation_concerns/repository_audit_service.rb +0 -9
- data/curation_concerns-models/app/services/curation_concerns/versioning_service.rb +0 -27
- data/curation_concerns-models/config/locales/curation_concerns.en.yml +0 -6
- data/curation_concerns-models/curation_concerns-models.gemspec +0 -34
- data/curation_concerns-models/lib/curation_concerns/messages.rb +0 -66
- data/curation_concerns-models/lib/curation_concerns/models/engine.rb +0 -61
- data/curation_concerns-models/lib/curation_concerns/models/resque.rb +0 -36
- data/curation_concerns-models/lib/curation_concerns/models/utils.rb +0 -22
- data/curation_concerns-models/lib/curation_concerns/models/version.rb +0 -5
- data/curation_concerns-models/lib/curation_concerns/models.rb +0 -32
- data/curation_concerns-models/lib/generators/curation_concerns/models/abstract_migration_generator.rb +0 -30
- data/curation_concerns-models/lib/generators/curation_concerns/models/clamav_generator.rb +0 -19
- data/curation_concerns-models/lib/generators/curation_concerns/models/fulltext_generator.rb +0 -28
- data/curation_concerns-models/lib/generators/curation_concerns/models/install_generator.rb +0 -70
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/app/models/collection.rb +0 -4
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/app/models/generic_file.rb +0 -4
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/clamav.rb +0 -1
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/curation_concerns.rb +0 -123
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/mime_types.rb +0 -6
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/redis.yml +0 -9
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/redis_config.rb +0 -32
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/resque-pool.yml +0 -1
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/resque_admin.rb +0 -10
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/config/resque_config.rb +0 -5
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/migrations/create_checksum_audit_logs.rb +0 -19
- data/curation_concerns-models/lib/generators/curation_concerns/models/templates/migrations/create_version_committers.rb +0 -15
- data/curation_concerns-models/lib/tasks/curation_concerns-models_tasks.rake +0 -75
- data/curation_concerns-models/lib/tasks/migrate.rake +0 -13
- data/curation_concerns-models/lib/tasks/resque.rake +0 -13
- data/curation_concerns-models/lib/tasks/solr_reindex.rake +0 -8
- data/lib/curation_concerns/configuration.rb +0 -74
- data/lib/generators/curation_concerns/templates/curation_concerns_config.rb +0 -2
- data/solr_conf/conf/solrconfig.xml +0 -223
- data/spec/abilities/generic_file_abilities_spec.rb +0 -62
- data/spec/actors/curation_concerns/generic_file_actor_spec.rb +0 -116
- data/spec/controllers/curation_concerns/generic_files_controller_spec.rb +0 -251
- data/spec/forms/generic_file_edit_form_spec.rb +0 -33
- data/spec/helpers/thumbnail_helper_spec.rb +0 -21
- data/spec/jobs/copy_permissions_job_spec.rb +0 -49
- data/spec/jobs/curation_concerns_resque_queue_spec.rb +0 -49
- data/spec/models/curation_concerns/generic_file/derivatives_spec.rb +0 -88
- data/spec/models/curation_concerns/generic_work_behavior_spec.rb +0 -35
- data/spec/models/fits_datastream_spec.rb +0 -127
- data/spec/models/generic_file_spec.rb +0 -619
- data/spec/presenters/curation_concerns/generic_file_presenter_spec.rb +0 -16
- data/spec/services/characterization_service_spec.rb +0 -30
- data/spec/services/full_text_extraction_service_spec.rb +0 -5
- data/spec/services/generic_file_audit_service_spec.rb +0 -71
- data/spec/services/generic_file_indexing_service_spec.rb +0 -57
- data/spec/services/generic_work_indexing_service_spec.rb +0 -18
- data/spec/workers/visibility_copy_worker_spec.rb +0 -70
- data/vendor/assets/javascripts/handlebars.js +0 -2278
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.autocomplete.js +0 -602
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.core.js +0 -356
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.effect-highlight.js +0 -50
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.effect.js +0 -1276
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.menu.js +0 -610
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.position.js +0 -498
- data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.widget.js +0 -528
- data/vendor/assets/javascripts/jquery.tokeninput.js +0 -1061
- data/vendor/assets/stylesheets/jquery-ui-lightness.css +0 -474
- data/vendor/assets/stylesheets/token-input-facebook.css +0 -122
- data/vendor/assets/stylesheets/token-input-mac.css +0 -204
- data/vendor/assets/stylesheets/token-input.css +0 -127
@@ -0,0 +1,69 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe SingleUseLink do
|
4
|
+
let(:file) { FileSet.new(id: 'abc123') }
|
5
|
+
let(:now) { DateTime.now }
|
6
|
+
let(:hash) { "sha2hash#{now.to_f}" }
|
7
|
+
|
8
|
+
describe "create" do
|
9
|
+
subject { described_class.create itemId: file.id, path: path }
|
10
|
+
|
11
|
+
before do
|
12
|
+
allow(DateTime).to receive(:now).and_return(now)
|
13
|
+
expect(Digest::SHA2).to receive(:new).and_return(hash)
|
14
|
+
end
|
15
|
+
after do
|
16
|
+
subject.delete
|
17
|
+
end
|
18
|
+
|
19
|
+
describe "show" do
|
20
|
+
let(:path) { Rails.application.routes.url_helpers.curation_concerns_file_set_path(file.id) }
|
21
|
+
|
22
|
+
it "creates link" do
|
23
|
+
expect(subject.downloadKey).to eq(hash)
|
24
|
+
expect(subject.itemId).to eq(file.id)
|
25
|
+
expect(subject.path).to eq(Rails.application.routes.url_helpers.curation_concerns_file_set_path(file.id))
|
26
|
+
end
|
27
|
+
end
|
28
|
+
describe "download" do
|
29
|
+
let(:path) { Rails.application.routes.url_helpers.download_path(file.id) }
|
30
|
+
|
31
|
+
it "creates link" do
|
32
|
+
expect(subject.downloadKey).to eq(hash)
|
33
|
+
expect(subject.itemId).to eq(file.id)
|
34
|
+
expect(subject.path).to eq(Rails.application.routes.url_helpers.download_path(file.id))
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
describe "find" do
|
39
|
+
describe "not expired" do
|
40
|
+
before do
|
41
|
+
@su = described_class.create(downloadKey: 'sha2hashb', itemId: file.id, path: Rails.application.routes.url_helpers.download_path(file), expires: DateTime.now.advance(hours: 1))
|
42
|
+
end
|
43
|
+
it "retrieves link" do
|
44
|
+
link = described_class.where(downloadKey: 'sha2hashb').first
|
45
|
+
expect(link.itemId).to eq(file.id)
|
46
|
+
end
|
47
|
+
it "retrieves link with find_by" do
|
48
|
+
link = described_class.find_by_downloadKey('sha2hashb')
|
49
|
+
expect(link.itemId).to eq(file.id)
|
50
|
+
end
|
51
|
+
it "expires link" do
|
52
|
+
link = described_class.where(downloadKey: 'sha2hashb').first
|
53
|
+
expect(link.expired?).to eq(false)
|
54
|
+
end
|
55
|
+
end
|
56
|
+
describe "expired" do
|
57
|
+
before do
|
58
|
+
@su = described_class.create!(downloadKey: 'sha2hashb', itemId: file.id, path: Rails.application.routes.url_helpers.download_path(file))
|
59
|
+
|
60
|
+
@su.update_attribute :expires, DateTime.now.advance(hours: -1)
|
61
|
+
end
|
62
|
+
|
63
|
+
it "expires link" do
|
64
|
+
link = described_class.where(downloadKey: 'sha2hashb').first
|
65
|
+
expect(link.expired?).to eq(true)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe SolrDocument do
|
4
|
+
let(:document) { described_class.new(attributes) }
|
5
|
+
|
6
|
+
describe "date_uploaded" do
|
7
|
+
let(:attributes) { { 'date_uploaded_dtsi' => "2015-08-31T00:00:00Z" } }
|
8
|
+
subject { document.date_uploaded }
|
9
|
+
|
10
|
+
it { is_expected.to eq '08/31/2015' }
|
11
|
+
end
|
12
|
+
|
13
|
+
describe "representative_id" do
|
14
|
+
let(:attributes) { { Solrizer.solr_name('hasRelatedMediaFragment', :symbol) => ['one'] } }
|
15
|
+
subject { document.representative_id }
|
16
|
+
it { is_expected.to eq 'one' }
|
17
|
+
end
|
18
|
+
|
19
|
+
describe "creator" do
|
20
|
+
let(:attributes) { { Solrizer.solr_name('creator') => ['one', 'two'] } }
|
21
|
+
subject { document.creator }
|
22
|
+
it { is_expected.to eq ['one', 'two'] }
|
23
|
+
end
|
24
|
+
|
25
|
+
describe "contributor" do
|
26
|
+
let(:attributes) { { Solrizer.solr_name('contributor') => ['one', 'two'] } }
|
27
|
+
subject { document.contributor }
|
28
|
+
it { is_expected.to eq ['one', 'two'] }
|
29
|
+
end
|
30
|
+
|
31
|
+
describe "subject" do
|
32
|
+
let(:attributes) { { Solrizer.solr_name('subject') => ['one', 'two'] } }
|
33
|
+
subject { document.subject }
|
34
|
+
it { is_expected.to eq ['one', 'two'] }
|
35
|
+
end
|
36
|
+
|
37
|
+
describe "publisher" do
|
38
|
+
let(:attributes) { { Solrizer.solr_name('publisher') => ['one', 'two'] } }
|
39
|
+
subject { document.publisher }
|
40
|
+
it { is_expected.to eq ['one', 'two'] }
|
41
|
+
end
|
42
|
+
|
43
|
+
describe "language" do
|
44
|
+
let(:attributes) { { Solrizer.solr_name('language') => ['one', 'two'] } }
|
45
|
+
subject { document.language }
|
46
|
+
it { is_expected.to eq ['one', 'two'] }
|
47
|
+
end
|
48
|
+
|
49
|
+
describe "visibility" do
|
50
|
+
subject { document.visibility }
|
51
|
+
|
52
|
+
context "when open" do
|
53
|
+
let(:attributes) { { 'read_access_group_ssim' => ['public'] } }
|
54
|
+
it { is_expected.to eq 'open' }
|
55
|
+
end
|
56
|
+
|
57
|
+
context "when authenticated" do
|
58
|
+
let(:attributes) { { 'read_access_group_ssim' => ['registered'] } }
|
59
|
+
it { is_expected.to eq 'authenticated' }
|
60
|
+
end
|
61
|
+
|
62
|
+
context "when restricted" do
|
63
|
+
let(:attributes) { {} }
|
64
|
+
it { is_expected.to eq 'restricted' }
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe UploadSet do
|
4
|
+
let(:user) { FactoryGirl.find_or_create(:jill) }
|
5
|
+
let(:upload_set) { described_class.create(title: ["test collection"], creator: [user.user_key]) }
|
6
|
+
subject { upload_set }
|
7
|
+
|
8
|
+
it "has dc metadata" do
|
9
|
+
expect(subject.creator).to eq [user.user_key]
|
10
|
+
expect(subject.title).to eq ["test collection"]
|
11
|
+
end
|
12
|
+
|
13
|
+
it "responds to .file_sets" do
|
14
|
+
expect(subject).to respond_to(:file_sets)
|
15
|
+
end
|
16
|
+
|
17
|
+
it "supports to_solr" do
|
18
|
+
expect(subject.to_solr).to_not be_nil
|
19
|
+
expect(subject.to_solr["upload_set__title_t"]).to be_nil
|
20
|
+
expect(subject.to_solr["upload_set__creator_t"]).to be_nil
|
21
|
+
end
|
22
|
+
|
23
|
+
describe "find_or_create" do
|
24
|
+
describe "when the object exists" do
|
25
|
+
let!(:upload_set) { described_class.create(title: ["test collection"], creator: [user.user_key]) }
|
26
|
+
it "finds upload_set instead of creating" do
|
27
|
+
expect(described_class).to_not receive(:create)
|
28
|
+
described_class.find_or_create(subject.id)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
describe "when the object does not exist" do
|
32
|
+
it "creates a new Batch" do
|
33
|
+
expect { described_class.find("upload_set-123") }.to raise_error(ActiveFedora::ObjectNotFoundError)
|
34
|
+
expect(described_class).to receive(:create).once.and_return("the upload_set")
|
35
|
+
expect(described_class.find_or_create("upload_set-123")).to eq "the upload_set"
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
data/spec/models/user_spec.rb
CHANGED
@@ -1,23 +1,22 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
|
-
describe User, :
|
3
|
+
describe User, type: :model do
|
4
4
|
let(:user) { FactoryGirl.build(:user) }
|
5
5
|
let(:another_user) { FactoryGirl.build(:user) }
|
6
6
|
|
7
|
-
it
|
7
|
+
it 'has an email' do
|
8
8
|
expect(user.user_key).to be_kind_of String
|
9
9
|
end
|
10
10
|
|
11
|
-
describe
|
12
|
-
let(:user) {
|
11
|
+
describe '#to_param' do
|
12
|
+
let(:user) { described_class.new(email: 'jilluser@example.com') }
|
13
13
|
|
14
|
-
it
|
15
|
-
expect(user.to_param).to eq(
|
14
|
+
it 'overrides to_param to make keys more recognizable in redis (and useable within Rails URLs)' do
|
15
|
+
expect(user.to_param).to eq('jilluser@example-dot-com')
|
16
16
|
end
|
17
17
|
end
|
18
18
|
|
19
|
-
it
|
19
|
+
it 'has a cancan ability defined' do
|
20
20
|
expect(user).to respond_to(:can?)
|
21
21
|
end
|
22
|
-
|
23
22
|
end
|
@@ -1,34 +1,18 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe CurationConcerns::CollectionPresenter do
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
:language, :identifier, :based_near, :related_url] }
|
9
|
-
end
|
10
|
-
|
11
|
-
let(:collection) { Collection.new(description: 'a nice collection', title: 'A clever title') }
|
12
|
-
let(:presenter) { described_class.new(collection) }
|
4
|
+
let(:collection) { Collection.new(id: 'adc12v', description: 'a nice collection', title: 'A clever title') }
|
5
|
+
let(:solr_document) { SolrDocument.new(collection.to_solr) }
|
6
|
+
let(:ability) { double }
|
7
|
+
let(:presenter) { described_class.new(solr_document, ability) }
|
13
8
|
|
14
|
-
describe
|
15
|
-
subject { presenter.terms_with_values }
|
16
|
-
|
17
|
-
it { is_expected.to eq [:title, :total_items, :size, :description] }
|
18
|
-
end
|
19
|
-
|
20
|
-
describe "#title" do
|
9
|
+
describe '#title' do
|
21
10
|
subject { presenter.title }
|
22
11
|
it { is_expected.to eq 'A clever title' }
|
23
12
|
end
|
24
13
|
|
25
|
-
describe
|
26
|
-
subject { presenter.
|
27
|
-
it { is_expected.to eq '
|
28
|
-
end
|
29
|
-
|
30
|
-
describe "#total_items" do
|
31
|
-
subject { presenter.total_items }
|
32
|
-
it { is_expected.to eq 0 }
|
14
|
+
describe '#to_key' do
|
15
|
+
subject { presenter.to_key }
|
16
|
+
it { is_expected.to eq ['adc12v'] }
|
33
17
|
end
|
34
18
|
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::FileSetPresenter do
|
4
|
+
let(:solr_document) { SolrDocument.new("title_tesim" => ["foo bar"],
|
5
|
+
"human_readable_type_tesim" => ["File Set"],
|
6
|
+
"mime_type_ssi" => 'image/jpeg',
|
7
|
+
"has_model_ssim" => ["FileSet"]) }
|
8
|
+
let(:ability) { nil }
|
9
|
+
let(:presenter) { described_class.new(solr_document, ability) }
|
10
|
+
|
11
|
+
describe "#to_s" do
|
12
|
+
subject { presenter.to_s }
|
13
|
+
it { is_expected.to eq 'foo bar' }
|
14
|
+
end
|
15
|
+
|
16
|
+
describe "#human_readable_type" do
|
17
|
+
subject { presenter.human_readable_type }
|
18
|
+
it { is_expected.to eq 'File Set' }
|
19
|
+
end
|
20
|
+
|
21
|
+
describe "#model_name" do
|
22
|
+
subject { presenter.model_name }
|
23
|
+
it { is_expected.to be_kind_of ActiveModel::Name }
|
24
|
+
end
|
25
|
+
|
26
|
+
describe "#to_partial_path" do
|
27
|
+
subject { presenter.to_partial_path }
|
28
|
+
it { is_expected.to eq 'file_sets/file_set' }
|
29
|
+
end
|
30
|
+
|
31
|
+
describe "office_document?" do
|
32
|
+
subject { presenter.office_document? }
|
33
|
+
it { is_expected.to be false }
|
34
|
+
end
|
35
|
+
|
36
|
+
describe "has?" do
|
37
|
+
subject { presenter.has?('thumbnail_path_ss') }
|
38
|
+
it { is_expected.to be false }
|
39
|
+
end
|
40
|
+
|
41
|
+
describe "first" do
|
42
|
+
subject { presenter.first('human_readable_type_tesim') }
|
43
|
+
it { is_expected.to eq 'File Set' }
|
44
|
+
end
|
45
|
+
|
46
|
+
describe "date_uploaded" do
|
47
|
+
it "delegates to the solr_document" do
|
48
|
+
expect(solr_document).to receive(:date_uploaded)
|
49
|
+
presenter.date_uploaded
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
describe "fetch" do
|
54
|
+
it "delegates to the solr_document" do
|
55
|
+
expect(solr_document).to receive(:fetch).and_call_original
|
56
|
+
expect(presenter.fetch("has_model_ssim")).to eq ["FileSet"]
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::PermissionBadge do
|
4
|
+
let(:badge) { described_class.new(solr_doc) }
|
5
|
+
let(:solr_doc) { SolrDocument.new(attributes) }
|
6
|
+
let(:attributes) { {} }
|
7
|
+
|
8
|
+
describe "#render" do
|
9
|
+
subject { badge.render }
|
10
|
+
context "when open-access with embargo" do
|
11
|
+
let(:attributes) { { read_access_group_ssim: ['public'], embargo_release_date_dtsi: '2016-05-04' } }
|
12
|
+
it { is_expected.to eq "<span title=\"Open Access with Embargo\" class=\"label label-warning\">Open Access with Embargo</span>" }
|
13
|
+
end
|
14
|
+
|
15
|
+
context "when open-access" do
|
16
|
+
let(:attributes) { { read_access_group_ssim: ['public'] } }
|
17
|
+
it { is_expected.to eq "<span title=\"Open Access\" class=\"label label-success\">Open Access</span>" }
|
18
|
+
end
|
19
|
+
|
20
|
+
context "when registered" do
|
21
|
+
let(:attributes) { { read_access_group_ssim: ['registered'] } }
|
22
|
+
it { is_expected.to eq "<span title=\"Institution Name\" class=\"label label-info\">Institution Name</span>" }
|
23
|
+
end
|
24
|
+
|
25
|
+
context "when private" do
|
26
|
+
it { is_expected.to eq "<span title=\"Private\" class=\"label label-danger\">Private</span>" }
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::PresenterFactory do
|
4
|
+
describe "#build_presenters" do
|
5
|
+
let(:presenter_class) { CurationConcerns::FileSetPresenter }
|
6
|
+
|
7
|
+
before do
|
8
|
+
allow(ActiveFedora::SolrService.instance.conn).to receive(:post)
|
9
|
+
.with('select', data: { q: "{!terms f=id}12,13", rows: 1000, qt: 'standard' })
|
10
|
+
.and_return('response' => { 'docs' => results })
|
11
|
+
end
|
12
|
+
|
13
|
+
subject { described_class.build_presenters(['12', '13'], presenter_class, nil) }
|
14
|
+
|
15
|
+
context "when some ids are found in solr" do
|
16
|
+
let(:results) { [{ "id" => "12" }, { "id" => "13" }] }
|
17
|
+
it "has two results" do
|
18
|
+
expect(subject.size).to eq 2
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
context "when some ids are not found in solr" do
|
23
|
+
let(:results) { [{ "id" => "13" }] }
|
24
|
+
it "has one result" do
|
25
|
+
expect(subject.size).to eq 1
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::VersionListPresenter, :no_clean do
|
4
|
+
let(:resource_version) do
|
5
|
+
ActiveFedora::VersionsGraph::ResourceVersion.new.tap do |v|
|
6
|
+
v.uri = 'http://example.com/version1'
|
7
|
+
v.label = 'version1'
|
8
|
+
v.created = '2014-12-09T02:03:18.296Z'
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
let(:resource_version2) do
|
13
|
+
ActiveFedora::VersionsGraph::ResourceVersion.new.tap do |v|
|
14
|
+
v.uri = 'http://example.com/version2'
|
15
|
+
v.label = 'version2'
|
16
|
+
v.created = '2014-12-19T02:03:18.296Z'
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
subject { described_class.new([resource_version, resource_version2]) }
|
21
|
+
|
22
|
+
describe "#each" do
|
23
|
+
it "yields version_presenters" do
|
24
|
+
versions_descending = []
|
25
|
+
subject.each do |v|
|
26
|
+
expect(v).to be_kind_of CurationConcerns::VersionPresenter
|
27
|
+
versions_descending.push(v.label)
|
28
|
+
end
|
29
|
+
expect(versions_descending).to eq ['version2', 'version1']
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,51 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::VersionPresenter, :no_clean do
|
4
|
+
let(:resource_version) do
|
5
|
+
ActiveFedora::VersionsGraph::ResourceVersion.new.tap do |v|
|
6
|
+
v.uri = 'http://example.com/version1'
|
7
|
+
v.label = 'version1'
|
8
|
+
v.created = '2014-12-09T02:03:18.296Z'
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
let(:presenter) { described_class.new(resource_version) }
|
13
|
+
|
14
|
+
describe "#label" do
|
15
|
+
subject { presenter.label }
|
16
|
+
it { is_expected.to eq 'version1' }
|
17
|
+
end
|
18
|
+
|
19
|
+
describe "#uri" do
|
20
|
+
subject { presenter.uri }
|
21
|
+
it { is_expected.to eq 'http://example.com/version1' }
|
22
|
+
end
|
23
|
+
|
24
|
+
describe "#created" do
|
25
|
+
before do
|
26
|
+
# Stub out the local timezone to (+08:00)
|
27
|
+
t2 = Time.new(2014, 12, 8, 18, 3, 18, 8)
|
28
|
+
allow_any_instance_of(Time).to receive(:getlocal).and_return(t2)
|
29
|
+
end
|
30
|
+
subject { presenter.created }
|
31
|
+
it { is_expected.to eq "December 8th, 2014 18:03" }
|
32
|
+
end
|
33
|
+
|
34
|
+
describe "#current?" do
|
35
|
+
subject { presenter.current? }
|
36
|
+
it { is_expected.to be false }
|
37
|
+
|
38
|
+
context "when current! is set" do
|
39
|
+
before { presenter.current! }
|
40
|
+
it { is_expected.to be true }
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
describe "#committer" do
|
45
|
+
before do
|
46
|
+
VersionCommitter.create(version_id: resource_version.uri, committer_login: 'jill')
|
47
|
+
end
|
48
|
+
subject { presenter.committer }
|
49
|
+
it { is_expected.to eq 'jill' }
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::WorkShowPresenter do
|
4
|
+
let(:solr_document) { SolrDocument.new(attributes) }
|
5
|
+
let(:attributes) do
|
6
|
+
{ "title_tesim" => ["foo bar"],
|
7
|
+
"human_readable_type_tesim" => ["Generic Work"],
|
8
|
+
"has_model_ssim" => ["GenericWork"] }
|
9
|
+
end
|
10
|
+
|
11
|
+
let(:ability) { nil }
|
12
|
+
let(:presenter) { described_class.new(solr_document, ability) }
|
13
|
+
|
14
|
+
describe "#to_s" do
|
15
|
+
subject { presenter.to_s }
|
16
|
+
it { is_expected.to eq 'foo bar' }
|
17
|
+
end
|
18
|
+
|
19
|
+
describe "#human_readable_type" do
|
20
|
+
subject { presenter.human_readable_type }
|
21
|
+
it { is_expected.to eq 'Generic Work' }
|
22
|
+
end
|
23
|
+
|
24
|
+
describe "#model_name" do
|
25
|
+
subject { presenter.model_name }
|
26
|
+
it { is_expected.to be_kind_of ActiveModel::Name }
|
27
|
+
end
|
28
|
+
|
29
|
+
describe "#permission_badge" do
|
30
|
+
it "calls the PermissionBadge object" do
|
31
|
+
expect_any_instance_of(CurationConcerns::PermissionBadge).to receive(:render)
|
32
|
+
presenter.permission_badge
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,48 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::EmbargoPresenter do
|
4
|
+
let(:document) { SolrDocument.new(attributes) }
|
5
|
+
let(:presenter) { described_class.new(document) }
|
6
|
+
let(:attributes) { {} }
|
7
|
+
|
8
|
+
describe "visibility" do
|
9
|
+
subject { presenter.visibility }
|
10
|
+
|
11
|
+
it { is_expected.to eq 'restricted' }
|
12
|
+
end
|
13
|
+
|
14
|
+
describe "to_s" do
|
15
|
+
let(:attributes) { { 'title_tesim' => ['Hey guys!'] } }
|
16
|
+
subject { presenter.to_s }
|
17
|
+
|
18
|
+
it { is_expected.to eq 'Hey guys!' }
|
19
|
+
end
|
20
|
+
|
21
|
+
describe "human_readable_type" do
|
22
|
+
let(:attributes) { { 'human_readable_type_tesim' => ['File'] } }
|
23
|
+
subject { presenter.human_readable_type }
|
24
|
+
|
25
|
+
it { is_expected.to eq 'File' }
|
26
|
+
end
|
27
|
+
|
28
|
+
describe "embargo_release_date" do
|
29
|
+
let(:attributes) { { 'embargo_release_date_dtsi' => '2015-10-15T00:00:00Z' } }
|
30
|
+
subject { presenter.embargo_release_date }
|
31
|
+
|
32
|
+
it { is_expected.to eq '15 Oct 2015' }
|
33
|
+
end
|
34
|
+
|
35
|
+
describe "visibility_after_embargo" do
|
36
|
+
let(:attributes) { { 'visibility_after_embargo_ssim' => ['restricted'] } }
|
37
|
+
subject { presenter.visibility_after_embargo }
|
38
|
+
|
39
|
+
it { is_expected.to eq 'restricted' }
|
40
|
+
end
|
41
|
+
|
42
|
+
describe "embargo_history" do
|
43
|
+
let(:attributes) { { 'embargo_history_ssim' => ['This is in the past'] } }
|
44
|
+
subject { presenter.embargo_history }
|
45
|
+
|
46
|
+
it { is_expected.to eq ['This is in the past'] }
|
47
|
+
end
|
48
|
+
end
|
@@ -0,0 +1,48 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::LeasePresenter do
|
4
|
+
let(:document) { SolrDocument.new(attributes) }
|
5
|
+
let(:presenter) { described_class.new(document) }
|
6
|
+
let(:attributes) { {} }
|
7
|
+
|
8
|
+
describe "visibility" do
|
9
|
+
subject { presenter.visibility }
|
10
|
+
|
11
|
+
it { is_expected.to eq 'restricted' }
|
12
|
+
end
|
13
|
+
|
14
|
+
describe "to_s" do
|
15
|
+
let(:attributes) { { 'title_tesim' => ['Hey guys!'] } }
|
16
|
+
subject { presenter.to_s }
|
17
|
+
|
18
|
+
it { is_expected.to eq 'Hey guys!' }
|
19
|
+
end
|
20
|
+
|
21
|
+
describe "human_readable_type" do
|
22
|
+
let(:attributes) { { 'human_readable_type_tesim' => ['File'] } }
|
23
|
+
subject { presenter.human_readable_type }
|
24
|
+
|
25
|
+
it { is_expected.to eq 'File' }
|
26
|
+
end
|
27
|
+
|
28
|
+
describe "lease_expiration_date" do
|
29
|
+
let(:attributes) { { 'lease_expiration_date_dtsi' => '2015-10-15T00:00:00Z' } }
|
30
|
+
subject { presenter.lease_expiration_date }
|
31
|
+
|
32
|
+
it { is_expected.to eq '15 Oct 2015' }
|
33
|
+
end
|
34
|
+
|
35
|
+
describe "visibility_after_lease" do
|
36
|
+
let(:attributes) { { 'visibility_after_lease_ssim' => ['restricted'] } }
|
37
|
+
subject { presenter.visibility_after_lease }
|
38
|
+
|
39
|
+
it { is_expected.to eq 'restricted' }
|
40
|
+
end
|
41
|
+
|
42
|
+
describe "lease_history" do
|
43
|
+
let(:attributes) { { 'lease_history_ssim' => ['This is in the past'] } }
|
44
|
+
subject { presenter.lease_history }
|
45
|
+
|
46
|
+
it { is_expected.to eq ['This is in the past'] }
|
47
|
+
end
|
48
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe CurationConcerns::AttributeRenderer do
|
4
|
+
let(:renderer) { described_class.new(:name, ['Bob', 'Jessica']) }
|
5
|
+
|
6
|
+
describe "#attribute_to_html" do
|
7
|
+
subject { renderer.render }
|
8
|
+
|
9
|
+
it { is_expected.to eq "<tr><th>Name</th>\n" \
|
10
|
+
"<td><ul class='tabular'><li class=\"attribute name\">Bob</li>\n" \
|
11
|
+
"<li class=\"attribute name\">Jessica</li>\n" \
|
12
|
+
"</ul></td></tr>" }
|
13
|
+
end
|
14
|
+
end
|