hyrax 2.6.0 → 2.9.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.circleci/config.yml +60 -33
- data/.gitignore +1 -0
- data/.regen +1 -0
- data/README.md +4 -4
- data/app/actors/hyrax/actors/attach_members_actor.rb +9 -2
- data/app/actors/hyrax/actors/collections_membership_actor.rb +10 -11
- data/app/actors/hyrax/actors/file_set_actor.rb +2 -2
- data/app/assets/javascripts/hyrax/autocomplete.es6 +29 -0
- data/app/assets/javascripts/hyrax/collections/editor.es6 +12 -2
- data/app/assets/javascripts/hyrax/editor.es6 +9 -10
- data/app/controllers/concerns/hyrax/local_file_downloads_controller_behavior.rb +2 -1
- data/app/controllers/concerns/hyrax/works_controller_behavior.rb +18 -7
- data/app/helpers/hyrax/hyrax_helper_behavior.rb +1 -0
- data/app/helpers/hyrax/work_form_helper.rb +48 -0
- data/app/indexers/hyrax/collection_indexer.rb +1 -3
- data/app/indexers/hyrax/deep_indexing_service.rb +21 -12
- data/app/indexers/hyrax/file_set_indexer.rb +6 -1
- data/app/jobs/iiif_manifest_cache_prewarm_job.rb +16 -0
- data/app/models/concerns/hyrax/collection_behavior.rb +8 -34
- data/app/models/concerns/hyrax/solr_document/characterization.rb +5 -1
- data/app/models/concerns/hyrax/solr_document/metadata.rb +9 -7
- data/app/models/concerns/hyrax/solr_document/ordered_members.rb +46 -0
- data/app/models/concerns/hyrax/solr_document_behavior.rb +10 -0
- data/app/models/hyrax/uploaded_file.rb +0 -2
- data/app/presenters/hyrax/collection_presenter.rb +12 -1
- data/app/presenters/hyrax/displays_image.rb +41 -15
- data/app/presenters/hyrax/file_set_presenter.rb +5 -0
- data/app/presenters/hyrax/iiif_manifest_presenter.rb +232 -0
- data/app/presenters/hyrax/member_presenter_factory.rb +1 -7
- data/app/search_builders/hyrax/embargo_search_builder.rb +1 -1
- data/app/search_builders/hyrax/lease_search_builder.rb +1 -1
- data/app/services/hyrax/caching_iiif_manifest_builder.rb +53 -0
- data/app/services/hyrax/file_set_csv_service.rb +1 -0
- data/app/services/hyrax/identifier/builder.rb +45 -0
- data/app/services/hyrax/identifier/dispatcher.rb +61 -0
- data/app/services/hyrax/identifier/registrar.rb +41 -0
- data/app/services/hyrax/manifest_builder_service.rb +88 -0
- data/app/services/hyrax/versioning_service.rb +9 -0
- data/app/services/hyrax/workflow/workflow_schema.rb +92 -32
- data/app/views/hyrax/base/_form.html.erb +1 -1
- data/app/views/hyrax/base/_form_progress.html.erb +4 -0
- data/app/views/hyrax/base/_guts4form.html.erb +7 -1
- data/app/views/hyrax/batch_uploads/_form.html.erb +1 -1
- data/app/views/hyrax/dashboard/_sidebar.html.erb +1 -1
- data/config/features.rb +4 -0
- data/hyrax.gemspec +8 -6
- data/lib/generators/hyrax/templates/config/initializers/hyrax.rb +5 -0
- data/lib/hyrax.rb +2 -0
- data/lib/hyrax/configuration.rb +15 -0
- data/lib/hyrax/engine.rb +1 -0
- data/lib/hyrax/specs/shared_specs.rb +1 -0
- data/lib/hyrax/specs/shared_specs/identifiers.rb +27 -0
- data/lib/hyrax/version.rb +1 -1
- data/template.rb +1 -1
- metadata +88 -1415
- data/spec/.gitignore +0 -1
- data/spec/abilities/ability_spec.rb +0 -183
- data/spec/abilities/admin_ability_spec.rb +0 -18
- data/spec/abilities/admin_set_ability_spec.rb +0 -177
- data/spec/abilities/collection_ability_spec.rb +0 -194
- data/spec/abilities/collection_type_ability_spec.rb +0 -72
- data/spec/abilities/embargo_and_lease_ability_spec.rb +0 -22
- data/spec/abilities/file_set_abilities_spec.rb +0 -70
- data/spec/abilities/generic_work_abilities_spec.rb +0 -63
- data/spec/abilities/operation_ability_spec.rb +0 -12
- data/spec/abilities/permission_template_ability_spec.rb +0 -145
- data/spec/abilities/proxies_and_transfer_abilities_spec.rb +0 -109
- data/spec/abilities/solr_document_ability_spec.rb +0 -27
- data/spec/actors/hyrax/actors/apply_order_actor_spec.rb +0 -92
- data/spec/actors/hyrax/actors/apply_permission_template_actor_spec.rb +0 -135
- data/spec/actors/hyrax/actors/attach_members_actor_spec.rb +0 -68
- data/spec/actors/hyrax/actors/cleanup_file_sets_actor_spec.rb +0 -24
- data/spec/actors/hyrax/actors/cleanup_trophies_actor_spec.rb +0 -25
- data/spec/actors/hyrax/actors/collections_membership_actor_spec.rb +0 -364
- data/spec/actors/hyrax/actors/create_with_files_actor_spec.rb +0 -60
- data/spec/actors/hyrax/actors/create_with_files_ordered_members_actor_spec.rb +0 -41
- data/spec/actors/hyrax/actors/create_with_remote_files_actor_spec.rb +0 -136
- data/spec/actors/hyrax/actors/create_with_remote_files_ordered_members_actor_spec.rb +0 -49
- data/spec/actors/hyrax/actors/default_admin_set_actor_spec.rb +0 -81
- data/spec/actors/hyrax/actors/embargo_actor_spec.rb +0 -37
- data/spec/actors/hyrax/actors/featured_work_actor_spec.rb +0 -38
- data/spec/actors/hyrax/actors/file_actor_spec.rb +0 -125
- data/spec/actors/hyrax/actors/file_set_actor_spec.rb +0 -347
- data/spec/actors/hyrax/actors/file_set_ordered_members_actor_spec.rb +0 -35
- data/spec/actors/hyrax/actors/generic_work_actor_spec.rb +0 -316
- data/spec/actors/hyrax/actors/initialize_workflow_actor_spec.rb +0 -35
- data/spec/actors/hyrax/actors/interpret_visibility_actor_spec.rb +0 -445
- data/spec/actors/hyrax/actors/lease_actor_spec.rb +0 -54
- data/spec/actors/hyrax/actors/model_actor_spec.rb +0 -24
- data/spec/actors/hyrax/actors/optimistic_lock_validator_spec.rb +0 -55
- data/spec/actors/hyrax/actors/ordered_members_actor_spec.rb +0 -59
- data/spec/actors/hyrax/actors/transactional_request_spec.rb +0 -46
- data/spec/actors/hyrax/actors/transfer_request_actor_spec.rb +0 -43
- data/spec/authorities/qa/authorities/collections_spec.rb +0 -68
- data/spec/authorities/qa/authorities/find_works_spec.rb +0 -52
- data/spec/channels/hyrax/application_cable/channel_spec.rb +0 -14
- data/spec/channels/hyrax/application_cable/connection_spec.rb +0 -37
- data/spec/channels/hyrax/notifications_channel_spec.rb +0 -45
- data/spec/config/hyrax_events_spec.rb +0 -44
- data/spec/controllers/catalog_controller_spec.rb +0 -135
- data/spec/controllers/hyrax/accepts_batches_controller_spec.rb +0 -67
- data/spec/controllers/hyrax/admin/admin_sets_controller_spec.rb +0 -284
- data/spec/controllers/hyrax/admin/appearances_controller_spec.rb +0 -66
- data/spec/controllers/hyrax/admin/collection_type_participants_controller_spec.rb +0 -152
- data/spec/controllers/hyrax/admin/collection_types_controller_spec.rb +0 -322
- data/spec/controllers/hyrax/admin/features_controller_spec.rb +0 -31
- data/spec/controllers/hyrax/admin/permission_template_accesses_controller_spec.rb +0 -101
- data/spec/controllers/hyrax/admin/permission_templates_controller_spec.rb +0 -71
- data/spec/controllers/hyrax/admin/stats_controller_spec.rb +0 -61
- data/spec/controllers/hyrax/admin/strategies_controller_spec.rb +0 -39
- data/spec/controllers/hyrax/admin/users_controller_spec.rb +0 -17
- data/spec/controllers/hyrax/admin/workflow_roles_controller_spec.rb +0 -76
- data/spec/controllers/hyrax/admin/workflows_controller_spec.rb +0 -18
- data/spec/controllers/hyrax/api/items_controller_spec.rb +0 -404
- data/spec/controllers/hyrax/api/zotero_controller_spec.rb +0 -162
- data/spec/controllers/hyrax/batch_edits_controller_spec.rb +0 -232
- data/spec/controllers/hyrax/batch_uploads_controller_spec.rb +0 -131
- data/spec/controllers/hyrax/citations_controller_spec.rb +0 -61
- data/spec/controllers/hyrax/collections_controller_spec.rb +0 -126
- data/spec/controllers/hyrax/contact_form_controller_spec.rb +0 -96
- data/spec/controllers/hyrax/content_blocks_controller_spec.rb +0 -71
- data/spec/controllers/hyrax/dashboard/collection_members_controller_spec.rb +0 -411
- data/spec/controllers/hyrax/dashboard/collections_controller_spec.rb +0 -518
- data/spec/controllers/hyrax/dashboard/nest_collections_controller_spec.rb +0 -360
- data/spec/controllers/hyrax/dashboard/profiles_controller_spec.rb +0 -155
- data/spec/controllers/hyrax/dashboard/works_controller_spec.rb +0 -13
- data/spec/controllers/hyrax/dashboard_controller_spec.rb +0 -42
- data/spec/controllers/hyrax/depositors_controller_spec.rb +0 -105
- data/spec/controllers/hyrax/downloads_controller_spec.rb +0 -159
- data/spec/controllers/hyrax/embargoes_controller_spec.rb +0 -147
- data/spec/controllers/hyrax/featured_work_lists_controller_spec.rb +0 -20
- data/spec/controllers/hyrax/featured_works_controller_spec.rb +0 -56
- data/spec/controllers/hyrax/file_sets_controller_spec.rb +0 -322
- data/spec/controllers/hyrax/fixity_checks_controller_spec.rb +0 -44
- data/spec/controllers/hyrax/generic_works_controller_json_spec.rb +0 -92
- data/spec/controllers/hyrax/generic_works_controller_spec.rb +0 -622
- data/spec/controllers/hyrax/homepage_controller_spec.rb +0 -138
- data/spec/controllers/hyrax/leases_controller_spec.rb +0 -117
- data/spec/controllers/hyrax/my/collections_controller_spec.rb +0 -36
- data/spec/controllers/hyrax/my/highlights_controller_spec.rb +0 -53
- data/spec/controllers/hyrax/my/shares_controller_spec.rb +0 -47
- data/spec/controllers/hyrax/my/works_controller_spec.rb +0 -54
- data/spec/controllers/hyrax/notifications_controller_spec.rb +0 -33
- data/spec/controllers/hyrax/operations_controller_spec.rb +0 -27
- data/spec/controllers/hyrax/pages_controller_spec.rb +0 -111
- data/spec/controllers/hyrax/permissions_controller_spec.rb +0 -56
- data/spec/controllers/hyrax/resource_sync_controller_spec.rb +0 -71
- data/spec/controllers/hyrax/single_use_links_controller_spec.rb +0 -100
- data/spec/controllers/hyrax/single_use_links_viewer_controller_spec.rb +0 -64
- data/spec/controllers/hyrax/static_controller_spec.rb +0 -28
- data/spec/controllers/hyrax/stats_controller_spec.rb +0 -73
- data/spec/controllers/hyrax/transfers_controller_spec.rb +0 -200
- data/spec/controllers/hyrax/trophies_controller_spec.rb +0 -40
- data/spec/controllers/hyrax/uploads_controller_spec.rb +0 -60
- data/spec/controllers/hyrax/users_controller_spec.rb +0 -151
- data/spec/controllers/hyrax/workflow_actions_controller_spec.rb +0 -54
- data/spec/conversions/power_converters/polymorphic_type_spec.rb +0 -22
- data/spec/conversions/power_converters/sipity_action_name_spec.rb +0 -32
- data/spec/conversions/power_converters/sipity_action_spec.rb +0 -43
- data/spec/conversions/power_converters/sipity_agent_spec.rb +0 -20
- data/spec/conversions/power_converters/sipity_entity_spec.rb +0 -53
- data/spec/conversions/power_converters/sipity_role_spec.rb +0 -31
- data/spec/conversions/power_converters/sipity_workflow_id_spec.rb +0 -28
- data/spec/conversions/power_converters/sipity_workflow_state_spec.rb +0 -20
- data/spec/factories/admin_sets.rb +0 -25
- data/spec/factories/admin_sets_lw.rb +0 -215
- data/spec/factories/api_items.rb +0 -91
- data/spec/factories/collection_branding_infos.rb +0 -11
- data/spec/factories/collection_type_participants.rb +0 -8
- data/spec/factories/collection_types.rb +0 -113
- data/spec/factories/collections.rb +0 -325
- data/spec/factories/collections_factory.rb +0 -134
- data/spec/factories/content_blocks.rb +0 -4
- data/spec/factories/featured_works.rb +0 -4
- data/spec/factories/file_sets.rb +0 -33
- data/spec/factories/generic_works.rb +0 -196
- data/spec/factories/object_id.rb +0 -6
- data/spec/factories/operations.rb +0 -21
- data/spec/factories/permission_template_accesses.rb +0 -16
- data/spec/factories/permission_templates.rb +0 -79
- data/spec/factories/proxy_deposit_requests.rb +0 -6
- data/spec/factories/single_use_links.rb +0 -13
- data/spec/factories/sipity_entities.rb +0 -7
- data/spec/factories/uploaded_files.rb +0 -5
- data/spec/factories/users.rb +0 -59
- data/spec/factories/workflow_actions.rb +0 -6
- data/spec/factories/workflow_states.rb +0 -6
- data/spec/factories/workflows.rb +0 -6
- data/spec/factory_tests/adminsets_factory_spec.rb +0 -132
- data/spec/factory_tests/collections_factory_spec.rb +0 -212
- data/spec/features/actor_stack_spec.rb +0 -77
- data/spec/features/admin_spec.rb +0 -30
- data/spec/features/batch_create_spec.rb +0 -75
- data/spec/features/batch_edit_spec.rb +0 -119
- data/spec/features/browse_catalog_spec.rb +0 -59
- data/spec/features/browse_dashboard_works_spec.rb +0 -56
- data/spec/features/catalog_search_spec.rb +0 -72
- data/spec/features/collection_multi_membership_spec.rb +0 -205
- data/spec/features/collection_spec.rb +0 -122
- data/spec/features/collection_type_spec.rb +0 -393
- data/spec/features/contact_form_spec.rb +0 -16
- data/spec/features/create_child_work_spec.rb +0 -82
- data/spec/features/create_work_admin_spec.rb +0 -44
- data/spec/features/create_work_spec.rb +0 -124
- data/spec/features/dashboard/all_works.rb +0 -23
- data/spec/features/dashboard/collection_spec.rb +0 -918
- data/spec/features/dashboard/display_admin_dashboard_spec.rb +0 -29
- data/spec/features/dashboard/display_dashboard_spec.rb +0 -18
- data/spec/features/delete_work_spec.rb +0 -23
- data/spec/features/edit_content_block_admin_spec.rb +0 -62
- data/spec/features/edit_file_spec.rb +0 -23
- data/spec/features/edit_work_spec.rb +0 -61
- data/spec/features/embargo_spec.rb +0 -90
- data/spec/features/homepage_spec.rb +0 -43
- data/spec/features/lease_spec.rb +0 -35
- data/spec/features/notifications_spec.rb +0 -20
- data/spec/features/ownership_transfer_spec.rb +0 -101
- data/spec/features/proxy_spec.rb +0 -25
- data/spec/features/search_spec.rb +0 -62
- data/spec/features/static_pages_spec.rb +0 -7
- data/spec/features/users_spec.rb +0 -48
- data/spec/features/work_generator_spec.rb +0 -29
- data/spec/features/work_show_spec.rb +0 -148
- data/spec/features/workflow_roles_spec.rb +0 -46
- data/spec/features/workflow_state_changes_spec.rb +0 -59
- data/spec/fixtures/1.5mb-avatar.jpg +0 -0
- data/spec/fixtures/4-20.png +0 -0
- data/spec/fixtures/Example.ogg +0 -0
- data/spec/fixtures/authorities/licenses.yml +0 -13
- data/spec/fixtures/charter.docx +0 -0
- data/spec/fixtures/config/schema_org.yml +0 -7
- data/spec/fixtures/config/schema_org_second.yml +0 -7
- data/spec/fixtures/countdown.avi +0 -0
- data/spec/fixtures/docx_fits.xml +0 -21
- data/spec/fixtures/dublin_core_rdf_descMetadata.nt +0 -13
- data/spec/fixtures/hyrax/.gitignore +0 -1
- data/spec/fixtures/hyrax/hyrax_test4.pdf +0 -0
- data/spec/fixtures/hyrax/hyrax_test5.mp3 +0 -0
- data/spec/fixtures/hyrax_generic_stub.txt +0 -1
- data/spec/fixtures/icons.zip +0 -0
- data/spec/fixtures/image.jp2 +0 -0
- data/spec/fixtures/image.jpg +0 -0
- data/spec/fixtures/image.png +0 -0
- data/spec/fixtures/jp2_fits.xml +0 -36
- data/spec/fixtures/jpg_fits.xml +0 -43
- data/spec/fixtures/mp3_fits.xml +0 -32
- data/spec/fixtures/pdf_fits.xml +0 -43
- data/spec/fixtures/piano_note.wav +0 -0
- data/spec/fixtures/png_fits.xml +0 -29
- data/spec/fixtures/sample_mpeg4.mp4 +0 -0
- data/spec/fixtures/small_file.txt +0 -1
- data/spec/fixtures/spoken-text.m4a +0 -0
- data/spec/fixtures/txt_fits.xml +0 -29
- data/spec/fixtures/world.png +0 -0
- data/spec/fixtures/xls_fits.xml +0 -18
- data/spec/fixtures/xml_fits.xml +0 -37
- data/spec/forms/hyrax/forms/admin/appearance_spec.rb +0 -46
- data/spec/forms/hyrax/forms/admin/collection_type_form_spec.rb +0 -108
- data/spec/forms/hyrax/forms/admin/collection_type_participant_form_spec.rb +0 -10
- data/spec/forms/hyrax/forms/admin_set_form_spec.rb +0 -88
- data/spec/forms/hyrax/forms/batch_edit_form_spec.rb +0 -111
- data/spec/forms/hyrax/forms/batch_upload_form_spec.rb +0 -75
- data/spec/forms/hyrax/forms/collection_form_spec.rb +0 -196
- data/spec/forms/hyrax/forms/dashboard/nest_collection_form_spec.rb +0 -159
- data/spec/forms/hyrax/forms/file_manager_form_spec.rb +0 -19
- data/spec/forms/hyrax/forms/file_set_edit_form_spec.rb +0 -53
- data/spec/forms/hyrax/forms/permission_template_form_spec.rb +0 -599
- data/spec/forms/hyrax/forms/work_form_spec.rb +0 -346
- data/spec/forms/hyrax/forms/workflow_action_form_spec.rb +0 -129
- data/spec/forms/hyrax/forms/workflow_responsibility_form_spec.rb +0 -41
- data/spec/forms/hyrax/generic_work_form_spec.rb +0 -127
- data/spec/helpers/blacklight_helper_spec.rb +0 -137
- data/spec/helpers/hyrax/ability_helper_spec.rb +0 -61
- data/spec/helpers/hyrax/batch_edits_helper_spec.rb +0 -59
- data/spec/helpers/hyrax/charts_helper_spec.rb +0 -63
- data/spec/helpers/hyrax/citations_behaviors/formatters/chicago_formatter_spec.rb +0 -10
- data/spec/helpers/hyrax/collections_helper_spec.rb +0 -117
- data/spec/helpers/hyrax/content_block_helper_spec.rb +0 -44
- data/spec/helpers/hyrax/dashboard_helper_behavior_spec.rb +0 -74
- data/spec/helpers/hyrax/file_set_helper_spec.rb +0 -65
- data/spec/helpers/hyrax/iiif_helper_spec.rb +0 -44
- data/spec/helpers/hyrax/trophy_helper_spec.rb +0 -37
- data/spec/helpers/hyrax_helper_spec.rb +0 -399
- data/spec/hyrax/transactions/create_work_spec.rb +0 -155
- data/spec/hyrax/transactions/steps/apply_permission_template_spec.rb +0 -72
- data/spec/hyrax/transactions/steps/ensure_admin_set_spec.rb +0 -25
- data/spec/hyrax/transactions/steps/ensure_permission_template_spec.rb +0 -33
- data/spec/hyrax/transactions/steps/save_work_spec.rb +0 -32
- data/spec/hyrax/transactions/steps/set_default_admin_set_spec.rb +0 -38
- data/spec/hyrax/transactions/steps/set_modified_date_spec.rb +0 -22
- data/spec/hyrax/transactions/steps/set_uploaded_date_spec.rb +0 -32
- data/spec/indexers/hyrax/collection_indexer_spec.rb +0 -43
- data/spec/indexers/hyrax/file_set_indexer_spec.rb +0 -126
- data/spec/indexers/hyrax/generic_work_indexer_spec.rb +0 -123
- data/spec/indexers/hyrax/repository_reindexer_spec.rb +0 -8
- data/spec/inputs/controlled_vocabulary_input_spec.rb +0 -57
- data/spec/inputs/multifile_input_spec.rb +0 -31
- data/spec/javascripts/authority_select_spec.js +0 -22
- data/spec/javascripts/autocomplete_spec.js.coffee +0 -199
- data/spec/javascripts/batch_select_spec.js +0 -15
- data/spec/javascripts/charts_spec.coffee +0 -10
- data/spec/javascripts/checklist_item_spec.js +0 -23
- data/spec/javascripts/deposit_agreement_spec.js +0 -70
- data/spec/javascripts/file_manager_member_spec.coffee +0 -88
- data/spec/javascripts/file_manager_sorting_spec.coffee +0 -23
- data/spec/javascripts/fixtures/chart_example.html +0 -1
- data/spec/javascripts/fixtures/dashboard_batch_forms.html +0 -11
- data/spec/javascripts/fixtures/file_manager_member.html +0 -40
- data/spec/javascripts/fixtures/save_button.html +0 -3
- data/spec/javascripts/fixtures/sortable.html +0 -182
- data/spec/javascripts/fixtures/sul_table.html +0 -29
- data/spec/javascripts/grant_spec.js +0 -43
- data/spec/javascripts/helpers/jasmine-ajax.js +0 -751
- data/spec/javascripts/helpers/jasmine-jquery.js +0 -838
- data/spec/javascripts/helpers/test_fixtures.js.coffee +0 -18
- data/spec/javascripts/helpers/test_responses.js +0 -12
- data/spec/javascripts/jasmine_spec.rb +0 -25
- data/spec/javascripts/relationships_control_spec.js.coffee +0 -27
- data/spec/javascripts/required_field_spec.js +0 -41
- data/spec/javascripts/save_manager_spec.coffee +0 -87
- data/spec/javascripts/save_work_spec.js +0 -262
- data/spec/javascripts/settings_spec.js +0 -74
- data/spec/javascripts/single_use_links_spec.coffee +0 -51
- data/spec/javascripts/support/jasmine.yml +0 -125
- data/spec/javascripts/support/jasmine_helper.rb +0 -14
- data/spec/javascripts/tabs_spec.js.coffee +0 -38
- data/spec/javascripts/uploaded_files_spec.js +0 -23
- data/spec/javascripts/visibility_component_spec.js +0 -531
- data/spec/jobs/attach_files_to_work_job_spec.rb +0 -80
- data/spec/jobs/attach_files_to_work_with_ordered_members_job_spec.rb +0 -13
- data/spec/jobs/batch_create_job_spec.rb +0 -79
- data/spec/jobs/characterize_job_spec.rb +0 -66
- data/spec/jobs/content_delete_event_job_spec.rb +0 -36
- data/spec/jobs/content_deposit_event_job_spec.rb +0 -25
- data/spec/jobs/content_depositor_change_event_job_spec.rb +0 -28
- data/spec/jobs/content_new_version_event_job_spec.rb +0 -21
- data/spec/jobs/content_restored_version_event_job_spec.rb +0 -28
- data/spec/jobs/content_update_event_job_spec.rb +0 -25
- data/spec/jobs/create_derivatives_job_spec.rb +0 -93
- data/spec/jobs/create_work_job_spec.rb +0 -60
- data/spec/jobs/file_set_attached_event_job_spec.rb +0 -34
- data/spec/jobs/fixity_check_job_spec.rb +0 -50
- data/spec/jobs/hyrax/grant_edit_job_spec.rb +0 -11
- data/spec/jobs/hyrax/grant_edit_to_members_job_spec.rb +0 -16
- data/spec/jobs/hyrax/grant_read_job_spec.rb +0 -11
- data/spec/jobs/hyrax/grant_read_to_members_job_spec.rb +0 -16
- data/spec/jobs/hyrax/revoke_edit_from_members_job_spec.rb +0 -16
- data/spec/jobs/hyrax/revoke_edit_job_spec.rb +0 -11
- data/spec/jobs/import_export_job_spec.rb +0 -28
- data/spec/jobs/import_url_job_spec.rb +0 -180
- data/spec/jobs/ingest_local_file_job_spec.rb +0 -40
- data/spec/jobs/inherit_permissions_job_spec.rb +0 -94
- data/spec/jobs/stream_notifications_job_spec.rb +0 -45
- data/spec/jobs/user_edit_profile_event_job_spec.rb +0 -17
- data/spec/jobs/visibility_copy_job_spec.rb +0 -53
- data/spec/lib/hyrax/analytics_spec.rb +0 -65
- data/spec/lib/hyrax/arkivo/actor_spec.rb +0 -78
- data/spec/lib/hyrax/arkivo/create_subscription_job_spec.rb +0 -50
- data/spec/lib/hyrax/arkivo/metadata_munger_spec.rb +0 -46
- data/spec/lib/hyrax/arkivo/schema_validator_spec.rb +0 -63
- data/spec/lib/hyrax/arkivo_spec.rb +0 -12
- data/spec/lib/hyrax/collections/search_service_spec.rb +0 -35
- data/spec/lib/hyrax/configuration_spec.rb +0 -91
- data/spec/lib/hyrax/controlled_vocabulary/importer/downloader_spec.rb +0 -33
- data/spec/lib/hyrax/controlled_vocabulary/importer/language_spec.rb +0 -24
- data/spec/lib/hyrax/move_all_works_to_admin_set_spec.rb +0 -13
- data/spec/lib/hyrax/name_spec.rb +0 -21
- data/spec/lib/hyrax/redis_event_store_spec.rb +0 -54
- data/spec/lib/hyrax/resource_sync/capability_list_writer_spec.rb +0 -33
- data/spec/lib/hyrax/resource_sync/change_list_writer_spec.rb +0 -78
- data/spec/lib/hyrax/resource_sync/resource_list_writer_spec.rb +0 -25
- data/spec/lib/hyrax/resource_sync/source_description_writer_spec.rb +0 -18
- data/spec/lib/hyrax/role_registry_spec.rb +0 -43
- data/spec/lib/hyrax/search_state_spec.rb +0 -26
- data/spec/lib/hyrax/zotero/config_spec.rb +0 -26
- data/spec/lib/hyrax/zotero_spec.rb +0 -9
- data/spec/lib/hyrax_spec.rb +0 -9
- data/spec/models/admin_set_spec.rb +0 -229
- data/spec/models/batch_upload_item_spec.rb +0 -7
- data/spec/models/checksum_audit_log_spec.rb +0 -162
- data/spec/models/collection_branding_info_spec.rb +0 -61
- data/spec/models/collection_spec.rb +0 -326
- data/spec/models/concerns/hyrax/collection_nesting_spec.rb +0 -83
- data/spec/models/content_block_spec.rb +0 -198
- data/spec/models/featured_work_list_spec.rb +0 -56
- data/spec/models/featured_work_spec.rb +0 -53
- data/spec/models/file_download_stat_spec.rb +0 -104
- data/spec/models/file_set_spec.rb +0 -668
- data/spec/models/file_view_stat_spec.rb +0 -81
- data/spec/models/flipflop_spec.rb +0 -49
- data/spec/models/generic_work_spec.rb +0 -117
- data/spec/models/hyrax/batch_create_operation_spec.rb +0 -59
- data/spec/models/hyrax/collection_type_participant_spec.rb +0 -43
- data/spec/models/hyrax/collection_type_spec.rb +0 -236
- data/spec/models/hyrax/download_spec.rb +0 -13
- data/spec/models/hyrax/operation_spec.rb +0 -123
- data/spec/models/hyrax/pageview_spec.rb +0 -13
- data/spec/models/hyrax/permission_template_access_spec.rb +0 -180
- data/spec/models/hyrax/permission_template_spec.rb +0 -291
- data/spec/models/hyrax/permissions/readable_permissions_spec.rb +0 -52
- data/spec/models/hyrax/permissions/writable_permissions_spec.rb +0 -12
- data/spec/models/hyrax/uploaded_file_spec.rb +0 -10
- data/spec/models/hyrax/user_usage_stats_spec.rb +0 -43
- data/spec/models/hyrax/work_behavior_spec.rb +0 -64
- data/spec/models/job_io_wrapper_spec.rb +0 -172
- data/spec/models/proxy_deposit_request_spec.rb +0 -152
- data/spec/models/single_use_link_spec.rb +0 -37
- data/spec/models/sipity/agent_spec.rb +0 -8
- data/spec/models/sipity/comment_spec.rb +0 -24
- data/spec/models/sipity/entity_spec.rb +0 -27
- data/spec/models/sipity/entity_specific_responsibility_spec.rb +0 -9
- data/spec/models/sipity/notifiable_context_spec.rb +0 -7
- data/spec/models/sipity/notification_recipient_spec.rb +0 -9
- data/spec/models/sipity/notification_spec.rb +0 -15
- data/spec/models/sipity/role_spec.rb +0 -40
- data/spec/models/sipity/workflow_action_spec.rb +0 -11
- data/spec/models/sipity/workflow_responsibility_spec.rb +0 -8
- data/spec/models/sipity/workflow_role_spec.rb +0 -8
- data/spec/models/sipity/workflow_spec.rb +0 -84
- data/spec/models/sipity/workflow_state_action_permission_spec.rb +0 -8
- data/spec/models/sipity/workflow_state_action_spec.rb +0 -8
- data/spec/models/sipity/workflow_state_spec.rb +0 -17
- data/spec/models/solr_document_spec.rb +0 -205
- data/spec/models/trophy_spec.rb +0 -19
- data/spec/models/user_mailbox_spec.rb +0 -134
- data/spec/models/user_spec.rb +0 -269
- data/spec/models/work_view_stat_spec.rb +0 -107
- data/spec/presenters/hyrax/admin/dashboard_presenter_spec.rb +0 -33
- data/spec/presenters/hyrax/admin/repository_growth_presenter_spec.rb +0 -25
- data/spec/presenters/hyrax/admin/repository_object_presenter_spec.rb +0 -24
- data/spec/presenters/hyrax/admin/user_activity_presenter_spec.rb +0 -20
- data/spec/presenters/hyrax/admin/users_presenter_spec.rb +0 -48
- data/spec/presenters/hyrax/admin/workflow_role_presenter_spec.rb +0 -12
- data/spec/presenters/hyrax/admin/workflow_roles_presenter_spec.rb +0 -16
- data/spec/presenters/hyrax/admin_set_options_presenter_spec.rb +0 -73
- data/spec/presenters/hyrax/admin_set_presenter_spec.rb +0 -143
- data/spec/presenters/hyrax/admin_stats_presenter_spec.rb +0 -143
- data/spec/presenters/hyrax/collection_options_presenter_spec.rb +0 -15
- data/spec/presenters/hyrax/collection_presenter_spec.rb +0 -461
- data/spec/presenters/hyrax/dashboard/user_presenter_spec.rb +0 -65
- data/spec/presenters/hyrax/embargo_presenter_spec.rb +0 -51
- data/spec/presenters/hyrax/file_set_presenter_spec.rb +0 -426
- data/spec/presenters/hyrax/file_usage_spec.rb +0 -162
- data/spec/presenters/hyrax/fixity_status_presenter_spec.rb +0 -55
- data/spec/presenters/hyrax/homepage_presenter_spec.rb +0 -42
- data/spec/presenters/hyrax/inspect_work_presenter_spec.rb +0 -59
- data/spec/presenters/hyrax/lease_presenter_spec.rb +0 -51
- data/spec/presenters/hyrax/member_presenter_factory_spec.rb +0 -26
- data/spec/presenters/hyrax/menu_presenter_spec.rb +0 -107
- data/spec/presenters/hyrax/permission_badge_spec.rb +0 -77
- data/spec/presenters/hyrax/presenter_factory_spec.rb +0 -53
- data/spec/presenters/hyrax/presenter_renderer_spec.rb +0 -30
- data/spec/presenters/hyrax/select_collection_type_list_presenter_spec.rb +0 -59
- data/spec/presenters/hyrax/select_collection_type_presenter_spec.rb +0 -10
- data/spec/presenters/hyrax/select_type_list_presenter_spec.rb +0 -37
- data/spec/presenters/hyrax/select_type_presenter_spec.rb +0 -74
- data/spec/presenters/hyrax/single_use_link_presenter_spec.rb +0 -41
- data/spec/presenters/hyrax/transfers_presenter_spec.rb +0 -44
- data/spec/presenters/hyrax/trophy_presenter_spec.rb +0 -53
- data/spec/presenters/hyrax/twitter_presenter_spec.rb +0 -27
- data/spec/presenters/hyrax/user_profile_presenter_spec.rb +0 -28
- data/spec/presenters/hyrax/version_list_presenter_spec.rb +0 -30
- data/spec/presenters/hyrax/version_presenter_spec.rb +0 -57
- data/spec/presenters/hyrax/work_show_presenter_spec.rb +0 -580
- data/spec/presenters/hyrax/work_usage_spec.rb +0 -144
- data/spec/presenters/hyrax/workflow_presenter_spec.rb +0 -75
- data/spec/rails_helper.rb +0 -2
- data/spec/renderers/hyrax/renderers/attribute_renderer_spec.rb +0 -118
- data/spec/renderers/hyrax/renderers/date_attribute_renderer_spec.rb +0 -39
- data/spec/renderers/hyrax/renderers/external_link_attribute_renderer_spec.rb +0 -22
- data/spec/renderers/hyrax/renderers/faceted_attribute_renderer_spec.rb +0 -35
- data/spec/renderers/hyrax/renderers/license_attribute_renderer_spec.rb +0 -21
- data/spec/renderers/hyrax/renderers/linked_attribute_renderer_spec.rb +0 -21
- data/spec/renderers/hyrax/renderers/rights_statement_attribute_renderer_spec.rb +0 -29
- data/spec/requests/legacy_routing_spec.rb +0 -7
- data/spec/requests/riiif_spec.rb +0 -32
- data/spec/routing/admin_routes_spec.rb +0 -29
- data/spec/routing/api_route_spec.rb +0 -89
- data/spec/routing/citations_route_spec.rb +0 -21
- data/spec/routing/collection_permission_templates_routes_spec.rb +0 -31
- data/spec/routing/collection_types_routes.rb +0 -35
- data/spec/routing/dashboard_routes_spec.rb +0 -37
- data/spec/routing/featured_works_route_spec.rb +0 -15
- data/spec/routing/operations_spec.rb +0 -9
- data/spec/routing/ownership_transfers_route_spec.rb +0 -43
- data/spec/routing/resource_sync_spec.rb +0 -19
- data/spec/routing/route_spec.rb +0 -205
- data/spec/routing/single_use_link_spec.rb +0 -27
- data/spec/routing/stats_route_spec.rb +0 -21
- data/spec/search_builders/hyrax/abstract_type_relation_spec.rb +0 -18
- data/spec/search_builders/hyrax/admin_admin_set_member_search_builder_spec.rb +0 -39
- data/spec/search_builders/hyrax/admin_set_search_builder_spec.rb +0 -78
- data/spec/search_builders/hyrax/catalog_search_builder_spec.rb +0 -86
- data/spec/search_builders/hyrax/collection_member_search_builder_spec.rb +0 -53
- data/spec/search_builders/hyrax/collection_search_builder_spec.rb +0 -74
- data/spec/search_builders/hyrax/dashboard/collections_search_builder_spec.rb +0 -103
- data/spec/search_builders/hyrax/dashboard/nested_collections_search_builder_spec.rb +0 -85
- data/spec/search_builders/hyrax/dashboard/works_search_builder_spec.rb +0 -44
- data/spec/search_builders/hyrax/embargo_search_builder_spec.rb +0 -17
- data/spec/search_builders/hyrax/file_set_search_builder_spec.rb +0 -28
- data/spec/search_builders/hyrax/lease_search_builder_spec.rb +0 -17
- data/spec/search_builders/hyrax/my/collections_search_builder_spec.rb +0 -35
- data/spec/search_builders/hyrax/my/find_works_search_builder_spec.rb +0 -63
- data/spec/search_builders/hyrax/my/shares_search_builder_spec.rb +0 -32
- data/spec/search_builders/hyrax/my/works_search_builder_spec.rb +0 -52
- data/spec/search_builders/hyrax/parent_collection_search_builder_spec.rb +0 -15
- data/spec/search_builders/hyrax/single_admin_set_search_builder_spec.rb +0 -20
- data/spec/search_builders/hyrax/stats/work_status_search_builder_spec.rb +0 -32
- data/spec/search_builders/hyrax/work_relation_spec.rb +0 -9
- data/spec/search_builders/hyrax/work_search_builder_spec.rb +0 -106
- data/spec/search_builders/hyrax/works_search_builder_spec.rb +0 -23
- data/spec/services/hyrax/abstract_message_service_spec.rb +0 -25
- data/spec/services/hyrax/adapters/nesting_index_adapter_spec.rb +0 -205
- data/spec/services/hyrax/admin_set_create_service_spec.rb +0 -114
- data/spec/services/hyrax/admin_set_member_service_spec.rb +0 -21
- data/spec/services/hyrax/admin_set_service_spec.rb +0 -171
- data/spec/services/hyrax/batch_create_failure_service_spec.rb +0 -18
- data/spec/services/hyrax/batch_create_success_service_spec.rb +0 -14
- data/spec/services/hyrax/change_content_depositor_service_spec.rb +0 -49
- data/spec/services/hyrax/collection_member_service_spec.rb +0 -19
- data/spec/services/hyrax/collection_size_service_spec.rb +0 -74
- data/spec/services/hyrax/collection_types/create_service_spec.rb +0 -127
- data/spec/services/hyrax/collection_types/permissions_service_spec.rb +0 -297
- data/spec/services/hyrax/collections/collection_member_service_spec.rb +0 -49
- data/spec/services/hyrax/collections/managed_collections_service_spec.rb +0 -17
- data/spec/services/hyrax/collections/migration_service_spec.rb +0 -467
- data/spec/services/hyrax/collections/nested_collection_persistence_service_spec.rb +0 -28
- data/spec/services/hyrax/collections/nested_collection_query_service_spec.rb +0 -353
- data/spec/services/hyrax/collections/permissions_create_service_spec.rb +0 -64
- data/spec/services/hyrax/collections/permissions_service_spec.rb +0 -380
- data/spec/services/hyrax/collections_service_spec.rb +0 -62
- data/spec/services/hyrax/curation_concern_spec.rb +0 -18
- data/spec/services/hyrax/database_migrator_spec.rb +0 -20
- data/spec/services/hyrax/default_middleware_stack_spec.rb +0 -36
- data/spec/services/hyrax/derivative_path_spec.rb +0 -65
- data/spec/services/hyrax/derivative_service_spec.rb +0 -49
- data/spec/services/hyrax/embargo_service_spec.rb +0 -59
- data/spec/services/hyrax/file_set_csv_service_spec.rb +0 -83
- data/spec/services/hyrax/file_set_derivatives_service_spec.rb +0 -13
- data/spec/services/hyrax/file_set_fixity_check_service_spec.rb +0 -129
- data/spec/services/hyrax/fixity_check_failure_service_spec.rb +0 -29
- data/spec/services/hyrax/graph_exporter_spec.rb +0 -58
- data/spec/services/hyrax/iiif_authorization_service_spec.rb +0 -43
- data/spec/services/hyrax/import_url_failure_service_spec.rb +0 -23
- data/spec/services/hyrax/lease_service_spec.rb +0 -50
- data/spec/services/hyrax/license_service_spec.rb +0 -34
- data/spec/services/hyrax/lock_manager_spec.rb +0 -13
- data/spec/services/hyrax/messenger_service_spec.rb +0 -15
- data/spec/services/hyrax/microdata_spec.rb +0 -94
- data/spec/services/hyrax/multiple_membership_checker_spec.rb +0 -155
- data/spec/services/hyrax/noid_spec.rb +0 -37
- data/spec/services/hyrax/permission_template_applicator_spec.rb +0 -69
- data/spec/services/hyrax/persist_derivatives_spec.rb +0 -22
- data/spec/services/hyrax/persist_directly_contained_output_file_service_spec.rb +0 -20
- data/spec/services/hyrax/qa_select_service_spec.rb +0 -109
- data/spec/services/hyrax/quick_classification_query_spec.rb +0 -38
- data/spec/services/hyrax/repository_fixity_check_service_spec.rb +0 -16
- data/spec/services/hyrax/resource_types_service_spec.rb +0 -38
- data/spec/services/hyrax/rights_statement_service_spec.rb +0 -9
- data/spec/services/hyrax/statistics/collections/over_time_spec.rb +0 -17
- data/spec/services/hyrax/statistics/depositors/summary_spec.rb +0 -66
- data/spec/services/hyrax/statistics/file_sets/by_format_spec.rb +0 -29
- data/spec/services/hyrax/statistics/query_service_spec.rb +0 -112
- data/spec/services/hyrax/statistics/system_stats_spec.rb +0 -45
- data/spec/services/hyrax/statistics/users/over_time_spec.rb +0 -22
- data/spec/services/hyrax/statistics/works/by_depositor_spec.rb +0 -24
- data/spec/services/hyrax/statistics/works/by_resource_type_spec.rb +0 -28
- data/spec/services/hyrax/statistics/works/count_spec.rb +0 -33
- data/spec/services/hyrax/statistics/works/over_time_spec.rb +0 -17
- data/spec/services/hyrax/thumbnail_path_service_spec.rb +0 -55
- data/spec/services/hyrax/tolerant_select_service_spec.rb +0 -80
- data/spec/services/hyrax/user_stat_importer_spec.rb +0 -315
- data/spec/services/hyrax/versioning_service_spec.rb +0 -26
- data/spec/services/hyrax/work_query_service_spec.rb +0 -56
- data/spec/services/hyrax/workflow/action_taken_service_spec.rb +0 -74
- data/spec/services/hyrax/workflow/activate_object_spec.rb +0 -26
- data/spec/services/hyrax/workflow/changes_required_notification_spec.rb +0 -35
- data/spec/services/hyrax/workflow/deactivate_object_spec.rb +0 -26
- data/spec/services/hyrax/workflow/deposited_notification_spec.rb +0 -35
- data/spec/services/hyrax/workflow/grant_edit_to_depositor_spec.rb +0 -53
- data/spec/services/hyrax/workflow/grant_read_to_depositor_spec.rb +0 -48
- data/spec/services/hyrax/workflow/method_generator_spec.rb +0 -42
- data/spec/services/hyrax/workflow/notification_configuration_parameter_spec.rb +0 -24
- data/spec/services/hyrax/workflow/notification_generator_spec.rb +0 -27
- data/spec/services/hyrax/workflow/notification_service_spec.rb +0 -87
- data/spec/services/hyrax/workflow/pending_review_notification_spec.rb +0 -34
- data/spec/services/hyrax/workflow/permission_generator_spec.rb +0 -50
- data/spec/services/hyrax/workflow/permission_query_spec.rb +0 -206
- data/spec/services/hyrax/workflow/revoke_edit_from_depositor_spec.rb +0 -48
- data/spec/services/hyrax/workflow/sipity_actions_generator_spec.rb +0 -40
- data/spec/services/hyrax/workflow/state_machine_generator_spec.rb +0 -45
- data/spec/services/hyrax/workflow/status_list_service_spec.rb +0 -67
- data/spec/services/hyrax/workflow/workflow_factory_spec.rb +0 -26
- data/spec/services/hyrax/workflow/workflow_importer_spec.rb +0 -241
- data/spec/services/hyrax/workflow/workflow_permissions_generator_spec.rb +0 -39
- data/spec/services/hyrax/workflow/workflow_schema_spec.rb +0 -86
- data/spec/services/hyrax/working_directory_spec.rb +0 -12
- data/spec/services/hyrax/works/managed_works_service_spec.rb +0 -17
- data/spec/spec_helper.rb +0 -300
- data/spec/strategies/hyrax/strategies/yaml_strategy_spec.rb +0 -30
- data/spec/support/controller_level_helpers.rb +0 -27
- data/spec/support/factory_helpers.rb +0 -24
- data/spec/support/fakes/fake_authority.rb +0 -13
- data/spec/support/features.rb +0 -10
- data/spec/support/features/batch_edit_actions.rb +0 -28
- data/spec/support/features/session_helpers.rb +0 -14
- data/spec/support/features/workflow.rb +0 -9
- data/spec/support/input_support.rb +0 -11
- data/spec/support/logging_formatter.rb +0 -66
- data/spec/support/matchers/api_responses.rb +0 -26
- data/spec/support/matchers/collection_type_property_matchers.rb +0 -29
- data/spec/support/matchers/response_matchers.rb +0 -7
- data/spec/support/optional_example.rb +0 -16
- data/spec/support/rake.rb +0 -41
- data/spec/support/selectors.rb +0 -100
- data/spec/support/spec_statistic.rb +0 -23
- data/spec/support/speedup.rb +0 -6
- data/spec/support/statistic_helper.rb +0 -9
- data/spec/tasks/rake_spec.rb +0 -27
- data/spec/test_app_templates/Gemfile.extra +0 -6
- data/spec/test_app_templates/disable_animations_in_test_environment.rb +0 -54
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +0 -125
- data/spec/views/_flash_msg.html.erb_spec.rb +0 -32
- data/spec/views/_user_util_links.html.erb_spec.rb +0 -44
- data/spec/views/catalog/_index_list_default.html.erb_spec.rb +0 -43
- data/spec/views/catalog/_search_form.html.erb_spec.rb +0 -16
- data/spec/views/catalog/_thumbnail_list_collection.html.erb_spec.rb +0 -43
- data/spec/views/catalog/index.html.erb_spec.rb +0 -50
- data/spec/views/content_blocks/edit.html.erb_spec.rb +0 -21
- data/spec/views/hyrax/admin/admin_sets/_form.html.erb_spec.rb +0 -29
- data/spec/views/hyrax/admin/admin_sets/_form_participant_table.html.erb_spec.rb +0 -128
- data/spec/views/hyrax/admin/admin_sets/_form_participants.html.erb_spec.rb +0 -19
- data/spec/views/hyrax/admin/admin_sets/_form_visibility.html.erb_spec.rb +0 -24
- data/spec/views/hyrax/admin/admin_sets/_form_workflow.html.erb_spec.rb +0 -22
- data/spec/views/hyrax/admin/admin_sets/_show_actions.html.erb_spec.rb +0 -68
- data/spec/views/hyrax/admin/admin_sets/_show_document_list.html.erb_spec.rb +0 -13
- data/spec/views/hyrax/admin/admin_sets/_show_document_list_row.html.erb_spec.rb +0 -28
- data/spec/views/hyrax/admin/admin_sets/index.html.erb_spec.rb +0 -40
- data/spec/views/hyrax/admin/admin_sets/index.json.erb_spec.rb +0 -29
- data/spec/views/hyrax/admin/admin_sets/show.html.erb_spec.rb +0 -21
- data/spec/views/hyrax/admin/collection_types/_form.html.erb_spec.rb +0 -45
- data/spec/views/hyrax/admin/collection_types/_form_appearance.html.erb_spec.rb +0 -22
- data/spec/views/hyrax/admin/collection_types/_form_metadata.html.erb_spec.rb +0 -27
- data/spec/views/hyrax/admin/collection_types/_form_metadata_admin_set.html.erb_spec.rb +0 -27
- data/spec/views/hyrax/admin/collection_types/_form_participants.html.erb_spec.rb +0 -24
- data/spec/views/hyrax/admin/collection_types/_form_participants_table.html.erb_spec.rb +0 -73
- data/spec/views/hyrax/admin/collection_types/_form_settings.html.erb_spec.rb +0 -86
- data/spec/views/hyrax/admin/collection_types/index.html.erb_spec.rb +0 -62
- data/spec/views/hyrax/admin/features/index.html.erb_spec.rb +0 -15
- data/spec/views/hyrax/admin/stats/show.html.erb_spec.rb +0 -54
- data/spec/views/hyrax/admin/users/index.html.erb_spec.rb +0 -45
- data/spec/views/hyrax/admin/workflow_roles/index.html.erb_spec.rb +0 -40
- data/spec/views/hyrax/base/_attribute_rows.html.erb_spec.rb +0 -30
- data/spec/views/hyrax/base/_attributes.html.erb_spec.rb +0 -35
- data/spec/views/hyrax/base/_citations.html.erb_spec.rb +0 -43
- data/spec/views/hyrax/base/_form.html.erb_spec.rb +0 -80
- data/spec/views/hyrax/base/_form_child_work_relationships.html.erb_spec.rb +0 -68
- data/spec/views/hyrax/base/_form_files.html.erb_spec.rb +0 -38
- data/spec/views/hyrax/base/_form_metadata.html.erb_spec.rb +0 -40
- data/spec/views/hyrax/base/_form_progress.html.erb_spec.rb +0 -131
- data/spec/views/hyrax/base/_form_relationships.html.erb_spec.rb +0 -48
- data/spec/views/hyrax/base/_form_rendering.html.erb_spec.rb +0 -22
- data/spec/views/hyrax/base/_items.html.erb_spec.rb +0 -55
- data/spec/views/hyrax/base/_member.html.erb_spec.rb +0 -43
- data/spec/views/hyrax/base/_relationships.html.erb_spec.rb +0 -92
- data/spec/views/hyrax/base/_show_actions.html.erb_spec.rb +0 -149
- data/spec/views/hyrax/base/_social_media.html.erb_spec.rb +0 -16
- data/spec/views/hyrax/base/edit.html.erb_spec.rb +0 -26
- data/spec/views/hyrax/base/file_manager.html.erb_spec.rb +0 -88
- data/spec/views/hyrax/base/show.html.erb_spec.rb +0 -201
- data/spec/views/hyrax/base/show.json.jbuilder_spec.rb +0 -23
- data/spec/views/hyrax/base/unauthorized.html.erb_spec.rb +0 -30
- data/spec/views/hyrax/base/unavailable.html.erb_spec.rb +0 -36
- data/spec/views/hyrax/batch_edits/check_all_spec.rb +0 -13
- data/spec/views/hyrax/batch_edits/edit.html.erb_spec.rb +0 -35
- data/spec/views/hyrax/batch_uploads/_form.html.erb_spec.rb +0 -24
- data/spec/views/hyrax/citations/work.html.erb_spec.rb +0 -175
- data/spec/views/hyrax/collections/_show_descriptions.html.erb_spec.rb +0 -32
- data/spec/views/hyrax/collections/_show_document_list.html.erb_spec.rb +0 -24
- data/spec/views/hyrax/collections/_show_document_list_row.html.erb_spec.rb +0 -35
- data/spec/views/hyrax/collections/_show_parent_collections.html.erb_spec.rb +0 -74
- data/spec/views/hyrax/collections/_sort_and_per_page.html.erb_spec.rb +0 -60
- data/spec/views/hyrax/collections/_subcollection_list.html.erb_spec.rb +0 -39
- data/spec/views/hyrax/collections/show.html.erb_spec.rb +0 -48
- data/spec/views/hyrax/dashboard/_sidebar.html.erb_spec.rb +0 -132
- data/spec/views/hyrax/dashboard/collections/_default_group.html.erb_spec.rb +0 -43
- data/spec/views/hyrax/dashboard/collections/_form.html.erb_spec.rb +0 -60
- data/spec/views/hyrax/dashboard/collections/_form_branding.html.erb_spec.rb +0 -23
- data/spec/views/hyrax/dashboard/collections/_form_discovery.erb_spec.rb +0 -67
- data/spec/views/hyrax/dashboard/collections/_form_for_select_collection.html.erb_spec.rb +0 -47
- data/spec/views/hyrax/dashboard/collections/_form_share.erb_spec.rb +0 -22
- data/spec/views/hyrax/dashboard/collections/_form_share_table.html.erb_spec.rb +0 -108
- data/spec/views/hyrax/dashboard/collections/_list_collections.html.erb_spec.rb +0 -51
- data/spec/views/hyrax/dashboard/collections/_show_actions.html.erb_spec.rb +0 -77
- data/spec/views/hyrax/dashboard/collections/_show_add_items_actions.html.erb_spec.rb +0 -46
- data/spec/views/hyrax/dashboard/collections/_show_descriptions.html.erb_spec.rb +0 -32
- data/spec/views/hyrax/dashboard/collections/_show_document_list.html.erb_spec.rb +0 -24
- data/spec/views/hyrax/dashboard/collections/_show_document_list_menu.html.erb_spec.rb +0 -31
- data/spec/views/hyrax/dashboard/collections/_show_document_list_row.html.erb_spec.rb +0 -35
- data/spec/views/hyrax/dashboard/collections/_show_parent_collection_row.html.erb_spec.rb +0 -61
- data/spec/views/hyrax/dashboard/collections/_show_parent_collections.html.erb_spec.rb +0 -82
- data/spec/views/hyrax/dashboard/collections/_show_subcollection_actions.html.erb_spec.rb +0 -62
- data/spec/views/hyrax/dashboard/collections/_sort_and_per_page.html.erb_spec.rb +0 -60
- data/spec/views/hyrax/dashboard/collections/_subcollection_list.html.erb_spec.rb +0 -75
- data/spec/views/hyrax/dashboard/collections/_work_action_menu.html.erb_spec.rb +0 -18
- data/spec/views/hyrax/dashboard/collections/edit.html.erb_spec.rb +0 -20
- data/spec/views/hyrax/dashboard/collections/show.html.erb_spec.rb +0 -116
- data/spec/views/hyrax/dashboard/profiles/_trophy_edit.html.erb_spec.rb +0 -36
- data/spec/views/hyrax/dashboard/profiles/edit.html.erb_spec.rb +0 -67
- data/spec/views/hyrax/dashboard/profiles/show.html.erb_spec.rb +0 -36
- data/spec/views/hyrax/dashboard/show_user_spec.rb +0 -61
- data/spec/views/hyrax/depositors/index.html.erb_spec.rb +0 -13
- data/spec/views/hyrax/embargoes/index.html.erb_spec.rb +0 -14
- data/spec/views/hyrax/file_sets/_actions.html.erb_spec.rb +0 -36
- data/spec/views/hyrax/file_sets/_permission.html.erb_spec.rb +0 -14
- data/spec/views/hyrax/file_sets/_permission_form.html.erb_spec.rb +0 -44
- data/spec/views/hyrax/file_sets/_show_actions.html.erb_spec.rb +0 -62
- data/spec/views/hyrax/file_sets/_show_characterization_details.html.erb_spec.rb +0 -29
- data/spec/views/hyrax/file_sets/_single_use_links.html.erb_spec.rb +0 -34
- data/spec/views/hyrax/file_sets/_versioning.html.erb_spec.rb +0 -16
- data/spec/views/hyrax/file_sets/media_display/_audio.html.erb_spec.rb +0 -29
- data/spec/views/hyrax/file_sets/media_display/_default.html.erb_spec.rb +0 -29
- data/spec/views/hyrax/file_sets/media_display/_video.html.erb_spec.rb +0 -29
- data/spec/views/hyrax/file_sets/show.html.erb_spec.rb +0 -47
- data/spec/views/hyrax/file_sets/show.json.jbuilder_spec.rb +0 -27
- data/spec/views/hyrax/homepage/_announcement.html.erb_spec.rb +0 -27
- data/spec/views/hyrax/homepage/_featured_works.html.erb_spec.rb +0 -40
- data/spec/views/hyrax/homepage/_sortable_featured.html.erb_spec.rb +0 -23
- data/spec/views/hyrax/homepage/index.html.erb_spec.rb +0 -129
- data/spec/views/hyrax/leases/index.html.erb_spec.rb +0 -14
- data/spec/views/hyrax/my/_collection_action_menu.html.erb_spec.rb +0 -65
- data/spec/views/hyrax/my/_search_header.html.erb_spec.rb +0 -34
- data/spec/views/hyrax/my/_work_action_menu.html.erb_spec.rb +0 -40
- data/spec/views/hyrax/my/collections/_list_collections.html.erb_spec.rb +0 -109
- data/spec/views/hyrax/my/collections/index.html.erb_spec.rb +0 -34
- data/spec/views/hyrax/my/facet.html.erb_spec.rb +0 -34
- data/spec/views/hyrax/my/works/_list_works.html.erb_spec.rb +0 -30
- data/spec/views/hyrax/my/works/index.html.erb_spec.rb +0 -69
- data/spec/views/hyrax/permissions/confirm.html.erb_spec.rb +0 -15
- data/spec/views/hyrax/single_use_links_viewer/show.html.erb_spec.rb +0 -17
- data/spec/views/hyrax/single_use_links_viewer/single_use_error.html.erb_spec.rb +0 -6
- data/spec/views/hyrax/stats/file.html.erb_spec.rb +0 -48
- data/spec/views/hyrax/uploads/create.json.jbuilder_spec.rb +0 -17
- data/spec/views/hyrax/users/_user_info.html.erb_spec.rb +0 -25
- data/spec/views/hyrax/users/index.html.erb_spec.rb +0 -25
- data/spec/views/hyrax/users/show.html.erb_spec.rb +0 -55
- data/spec/views/layouts/error.html.erb_spec.rb +0 -6
- data/spec/views/pages/edit.html.erb_spec.rb +0 -27
- data/spec/views/pages/show.html.erb_spec.rb +0 -17
- data/spec/views/records/edit_fields/_based_near.html.erb_spec.rb +0 -20
- data/spec/views/records/edit_fields/_description.html.erb_spec.rb +0 -67
- data/spec/views/records/edit_fields/_language.html.erb_spec.rb +0 -20
- data/spec/views/records/edit_fields/_subject.html.erb_spec.rb +0 -20
- data/spec/views/shared/select_work_type_modal.html.erb_spec.rb +0 -51
@@ -1,25 +0,0 @@
|
|
1
|
-
RSpec.describe Hyrax::ResourceSync::ResourceListWriter, :clean_repo do
|
2
|
-
let(:sitemap) { 'http://www.sitemaps.org/schemas/sitemap/0.9' }
|
3
|
-
let!(:private_collection) { build(:private_collection_lw) }
|
4
|
-
let!(:public_collection) { create(:public_collection) }
|
5
|
-
let!(:public_work) { create(:public_generic_work) }
|
6
|
-
let!(:private_work) { create(:work) }
|
7
|
-
let!(:file_set) { create(:file_set, :public) }
|
8
|
-
let(:capability_list) { 'http://example.com/capabilityList.xml' }
|
9
|
-
let(:xml) { Nokogiri::XML.parse(subject) }
|
10
|
-
|
11
|
-
subject { described_class.new(resource_host: 'example.com', capability_list_url: capability_list).write }
|
12
|
-
|
13
|
-
it "has a list of resources" do
|
14
|
-
capability = xml.xpath('//rs:ln/@href', 'rs' => "http://www.openarchives.org/rs/terms/").text
|
15
|
-
expect(capability).to eq capability_list
|
16
|
-
expect(query(1)).to eq "http://example.com/collections/#{public_collection.id}"
|
17
|
-
expect(query(2)).to eq "http://example.com/concern/generic_works/#{public_work.id}"
|
18
|
-
expect(query(3)).to eq "http://example.com/concern/file_sets/#{file_set.id}"
|
19
|
-
expect(xml.xpath('//x:url', 'x' => sitemap).count).to eq 3
|
20
|
-
end
|
21
|
-
|
22
|
-
def query(n)
|
23
|
-
xml.xpath("//x:url[#{n}]/x:loc", 'x' => sitemap).text
|
24
|
-
end
|
25
|
-
end
|
@@ -1,18 +0,0 @@
|
|
1
|
-
RSpec.describe Hyrax::ResourceSync::SourceDescriptionWriter do
|
2
|
-
let(:sitemap) { 'http://www.sitemaps.org/schemas/sitemap/0.9' }
|
3
|
-
let(:rs) { 'http://www.openarchives.org/rs/terms/' }
|
4
|
-
let(:capability_list) { 'http://example.com/capabilityList.xml' }
|
5
|
-
let(:xml) { Nokogiri::XML.parse(subject) }
|
6
|
-
|
7
|
-
subject { described_class.new(capability_list_url: capability_list).write }
|
8
|
-
|
9
|
-
it "has url to the capability list" do
|
10
|
-
capability = xml.xpath('/x:urlset/rs:md/@capability', 'x' => sitemap, 'rs' => rs).map(&:value)
|
11
|
-
expect(capability).to eq ["description"]
|
12
|
-
|
13
|
-
url = xml.xpath('//x:url[1]/x:loc', 'x' => sitemap).text
|
14
|
-
expect(url).to eq capability_list
|
15
|
-
capability = xml.xpath('//x:url[1]/rs:md/@capability', 'x' => sitemap, 'rs' => rs).map(&:value)
|
16
|
-
expect(capability).to eq ["capabilitylist"]
|
17
|
-
end
|
18
|
-
end
|
@@ -1,43 +0,0 @@
|
|
1
|
-
require 'rails_helper'
|
2
|
-
|
3
|
-
RSpec.describe Hyrax::RoleRegistry do
|
4
|
-
let(:role_registry) { described_class.new }
|
5
|
-
|
6
|
-
describe '#role_names (without adding roles)' do
|
7
|
-
subject { role_registry.role_names }
|
8
|
-
|
9
|
-
it { is_expected.to eq(['approving', 'depositing', 'managing']) }
|
10
|
-
end
|
11
|
-
|
12
|
-
describe '#registered_role?' do
|
13
|
-
subject { role_registry.registered_role?(name: name) }
|
14
|
-
|
15
|
-
describe 'for already registered name' do
|
16
|
-
let(:name) { described_class::MANAGING }
|
17
|
-
|
18
|
-
it { is_expected.to be_truthy }
|
19
|
-
end
|
20
|
-
describe 'for non-registered name' do
|
21
|
-
let(:name) { 'gong_farming' }
|
22
|
-
|
23
|
-
it { is_expected.to be_falsey }
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
describe '#add' do
|
28
|
-
subject { role_registry.add(name: 'captaining', description: 'Grants captain duties') }
|
29
|
-
|
30
|
-
it 'includes those added via #add' do
|
31
|
-
expect { subject }.to change { role_registry.role_names }
|
32
|
-
.from(['approving', 'depositing', 'managing']).to(['approving', 'captaining', 'depositing', 'managing'])
|
33
|
-
end
|
34
|
-
end
|
35
|
-
|
36
|
-
describe '#persist_registered_roles!' do
|
37
|
-
subject { role_registry.persist_registered_roles! }
|
38
|
-
|
39
|
-
it 'creates Sipity::Role records for each role_name' do
|
40
|
-
expect { subject }.to change { Sipity::Role.count }.by(role_registry.role_names.count)
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
@@ -1,26 +0,0 @@
|
|
1
|
-
RSpec.describe Hyrax::SearchState do
|
2
|
-
let(:controller) { CatalogController.new }
|
3
|
-
let(:config) { Blacklight::Configuration.new }
|
4
|
-
let(:state) { described_class.new({}, config, controller) }
|
5
|
-
|
6
|
-
describe "url_for_document" do
|
7
|
-
subject { state.url_for_document(document) }
|
8
|
-
|
9
|
-
context "with a collection" do
|
10
|
-
let(:document) { SolrDocument.new(id: '9999', has_model_ssim: ['Collection']) }
|
11
|
-
|
12
|
-
it "returns an array with the route set and doc" do
|
13
|
-
expect(subject.first).to be_kind_of ActionDispatch::Routing::RoutesProxy
|
14
|
-
expect(subject.last).to eq document
|
15
|
-
end
|
16
|
-
end
|
17
|
-
context "with a work" do
|
18
|
-
let(:document) { SolrDocument.new(id: '9999', has_model_ssim: ['GenericWork']) }
|
19
|
-
|
20
|
-
it "returns an array with the route set and doc" do
|
21
|
-
expect(subject.first).to be_kind_of ActionDispatch::Routing::RoutesProxy
|
22
|
-
expect(subject.last).to eq document
|
23
|
-
end
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
@@ -1,26 +0,0 @@
|
|
1
|
-
RSpec.describe Hyrax::Zotero do
|
2
|
-
it { is_expected.to respond_to(:config) }
|
3
|
-
|
4
|
-
describe 'configuration' do
|
5
|
-
subject { described_class.reload_config! }
|
6
|
-
|
7
|
-
let(:client_key) { 'abc123' }
|
8
|
-
let(:client_secret) { '789xyz' }
|
9
|
-
|
10
|
-
before do
|
11
|
-
stub_const('ENV', 'ZOTERO_CLIENT_KEY' => client_key,
|
12
|
-
'ZOTERO_CLIENT_SECRET' => client_secret)
|
13
|
-
end
|
14
|
-
|
15
|
-
# Reload the config so other tests don't see the stub_const values
|
16
|
-
after { described_class.reload_config! }
|
17
|
-
|
18
|
-
it 'has a client key' do
|
19
|
-
expect(subject['client_key']).to eq(client_key)
|
20
|
-
end
|
21
|
-
|
22
|
-
it 'has a client secret' do
|
23
|
-
expect(subject['client_secret']).to eq(client_secret)
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
data/spec/lib/hyrax_spec.rb
DELETED
@@ -1,229 +0,0 @@
|
|
1
|
-
RSpec.describe AdminSet, type: :model do
|
2
|
-
let(:gf1) { create(:generic_work, user: user) }
|
3
|
-
let(:gf2) { create(:generic_work, user: user) }
|
4
|
-
let(:gf3) { create(:generic_work, user: user) }
|
5
|
-
|
6
|
-
let(:user) { create(:user) }
|
7
|
-
|
8
|
-
subject { described_class.new(title: ['Some title']) }
|
9
|
-
|
10
|
-
describe '#active_workflow' do
|
11
|
-
it 'leverages Sipity::Workflow.find_active_workflow_for' do
|
12
|
-
admin_set = build(:admin_set, id: 1234)
|
13
|
-
expect(Sipity::Workflow).to receive(:find_active_workflow_for).with(admin_set_id: admin_set.id).and_return(:workflow)
|
14
|
-
expect(admin_set.active_workflow).to eq(:workflow)
|
15
|
-
end
|
16
|
-
end
|
17
|
-
|
18
|
-
describe '#permission_template' do
|
19
|
-
it 'queries for a Hyrax::PermissionTemplate with a matching source_id' do
|
20
|
-
admin_set = build(:admin_set, id: '123')
|
21
|
-
permission_template = build(:permission_template)
|
22
|
-
expect(Hyrax::PermissionTemplate).to receive(:find_by!).with(source_id: '123').and_return(permission_template)
|
23
|
-
expect(admin_set.permission_template).to eq(permission_template)
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
describe 'factories' do
|
28
|
-
it 'will create a permission_template when one is requested' do
|
29
|
-
expect { create(:admin_set, with_permission_template: true) }.to change { Hyrax::PermissionTemplate.count }.by(1)
|
30
|
-
end
|
31
|
-
|
32
|
-
it 'will not create a permission_template by default' do
|
33
|
-
expect { create(:admin_set) }.not_to change { Hyrax::PermissionTemplate.count }
|
34
|
-
end
|
35
|
-
|
36
|
-
it 'will create a permission_template with attributes' do
|
37
|
-
permission_template = create(:admin_set,
|
38
|
-
with_permission_template: {
|
39
|
-
visibility: Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC,
|
40
|
-
release_date: Hyrax::PermissionTemplate::RELEASE_TEXT_VALUE_FIXED,
|
41
|
-
release_period: Hyrax::PermissionTemplate::RELEASE_TEXT_VALUE_6_MONTHS
|
42
|
-
}).permission_template
|
43
|
-
expect(permission_template.visibility).to eq(Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC)
|
44
|
-
expect(permission_template.release_period).to eq(Hyrax::PermissionTemplate::RELEASE_TEXT_VALUE_6_MONTHS)
|
45
|
-
expect(permission_template.release_date).to eq(6.months.from_now.to_date)
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
describe '.after_destroy' do
|
50
|
-
let(:permission_template_access) { create(:permission_template_access) }
|
51
|
-
|
52
|
-
it 'will destroy the associated permission template and permission template access' do
|
53
|
-
admin_set = create(:admin_set, with_permission_template: true)
|
54
|
-
permission_template_access.permission_template_id = admin_set.permission_template.id
|
55
|
-
permission_template_access.save
|
56
|
-
expect { admin_set.destroy }.to change { Hyrax::PermissionTemplate.count }.by(-1).and change { Hyrax::PermissionTemplateAccess.count }.by(-1)
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
describe "#to_solr" do
|
61
|
-
let(:admin_set) do
|
62
|
-
build(:admin_set, title: ['A good title'],
|
63
|
-
creator: ['jcoyne@justincoyne.com'])
|
64
|
-
end
|
65
|
-
let(:solr_document) { admin_set.to_solr }
|
66
|
-
|
67
|
-
it "has title and creator information" do
|
68
|
-
expect(solr_document).to include 'title_tesim' => ['A good title'],
|
69
|
-
'title_sim' => ['A good title'],
|
70
|
-
'creator_ssim' => ['jcoyne@justincoyne.com']
|
71
|
-
end
|
72
|
-
end
|
73
|
-
|
74
|
-
describe "#members" do
|
75
|
-
it "is empty by default" do
|
76
|
-
skip 'This test is plagued by this bug https://github.com/samvera/active_fedora/issues/1238'
|
77
|
-
expect(subject.members).to be_empty
|
78
|
-
end
|
79
|
-
|
80
|
-
context "adding members" do
|
81
|
-
context "using assignment" do
|
82
|
-
subject { described_class.create!(title: ['Some title'], members: [gf1, gf2]) }
|
83
|
-
|
84
|
-
it "has many files" do
|
85
|
-
expect(subject.reload.members).to match_array [gf1, gf2]
|
86
|
-
end
|
87
|
-
end
|
88
|
-
|
89
|
-
context "using append" do
|
90
|
-
before do
|
91
|
-
subject.members = [gf1]
|
92
|
-
subject.save
|
93
|
-
end
|
94
|
-
it "allows new files to be added" do
|
95
|
-
subject.reload
|
96
|
-
subject.members << gf2
|
97
|
-
subject.save
|
98
|
-
expect(subject.reload.members).to match_array [gf1, gf2]
|
99
|
-
end
|
100
|
-
end
|
101
|
-
end
|
102
|
-
end
|
103
|
-
|
104
|
-
describe ".default_set?" do
|
105
|
-
context "with default AdminSet ID" do
|
106
|
-
it "returns true" do
|
107
|
-
expect(AdminSet.default_set?(described_class::DEFAULT_ID)).to be true
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
context "with a non-default ID" do
|
112
|
-
it "returns false" do
|
113
|
-
expect(AdminSet.default_set?('different-id')).to be false
|
114
|
-
end
|
115
|
-
end
|
116
|
-
end
|
117
|
-
|
118
|
-
describe "#default_set?", :clean_repo do
|
119
|
-
context "with default AdminSet ID" do
|
120
|
-
subject { described_class.new(id: described_class::DEFAULT_ID).default_set? }
|
121
|
-
|
122
|
-
it { is_expected.to be_truthy }
|
123
|
-
end
|
124
|
-
|
125
|
-
context "with a non-default ID" do
|
126
|
-
subject { described_class.new(id: 'why-would-you-name-the-default-chupacabra?').default_set? }
|
127
|
-
|
128
|
-
it { is_expected.to be_falsey }
|
129
|
-
end
|
130
|
-
end
|
131
|
-
|
132
|
-
describe ".find_or_create_default_admin_set_id" do
|
133
|
-
subject { described_class.find_or_create_default_admin_set_id }
|
134
|
-
|
135
|
-
describe 'if it already exists' do
|
136
|
-
before { expect(described_class).to receive(:exists?).and_return(true) }
|
137
|
-
it 'returns the DEFAULT_ID without creating the admin set' do
|
138
|
-
expect(Hyrax::AdminSetCreateService).not_to receive(:create_default_admin_set)
|
139
|
-
expect(subject).to eq(described_class::DEFAULT_ID)
|
140
|
-
end
|
141
|
-
end
|
142
|
-
describe 'if it does not already exist' do
|
143
|
-
before { expect(described_class).to receive(:exists?).and_return(false) }
|
144
|
-
it 'returns the DEFAULT_ID and creates the admin set' do
|
145
|
-
expect(Hyrax::AdminSetCreateService).to receive(:create_default_admin_set).with(admin_set_id: described_class::DEFAULT_ID, title: described_class::DEFAULT_TITLE)
|
146
|
-
expect(subject).to eq(described_class::DEFAULT_ID)
|
147
|
-
end
|
148
|
-
end
|
149
|
-
end
|
150
|
-
|
151
|
-
describe "#destroy" do
|
152
|
-
context "with member works" do
|
153
|
-
before do
|
154
|
-
subject.members = [gf1, gf2]
|
155
|
-
subject.save!
|
156
|
-
subject.destroy
|
157
|
-
end
|
158
|
-
|
159
|
-
it "does not delete adminset or member works" do
|
160
|
-
expect(subject.errors.full_messages).to eq ["Administrative set cannot be deleted as it is not empty"]
|
161
|
-
expect(AdminSet.exists?(subject.id)).to be true
|
162
|
-
expect(GenericWork.exists?(gf1.id)).to be true
|
163
|
-
expect(GenericWork.exists?(gf2.id)).to be true
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
context "with no member works" do
|
168
|
-
before do
|
169
|
-
subject.members = []
|
170
|
-
subject.save!
|
171
|
-
subject.destroy
|
172
|
-
end
|
173
|
-
|
174
|
-
it "deletes the adminset" do
|
175
|
-
expect(AdminSet.exists?(subject.id)).to be false
|
176
|
-
end
|
177
|
-
end
|
178
|
-
|
179
|
-
context "is default adminset" do
|
180
|
-
before do
|
181
|
-
subject.members = []
|
182
|
-
subject.id = described_class::DEFAULT_ID
|
183
|
-
subject.save!
|
184
|
-
subject.destroy
|
185
|
-
end
|
186
|
-
|
187
|
-
it "does not delete the adminset" do
|
188
|
-
expect(subject.errors.full_messages).to eq ["Administrative set cannot be deleted as it is the default set"]
|
189
|
-
expect(AdminSet.exists?(described_class::DEFAULT_ID)).to be true
|
190
|
-
end
|
191
|
-
end
|
192
|
-
end
|
193
|
-
|
194
|
-
describe '#reset_access_controls!' do
|
195
|
-
let!(:user) { build(:user) }
|
196
|
-
let!(:admin_set) { create(:admin_set, creator: [user.user_key], edit_users: [user.user_key], edit_groups: [::Ability.admin_group_name], read_users: [], read_groups: ['public']) }
|
197
|
-
let!(:permission_template) { build(:permission_template) }
|
198
|
-
|
199
|
-
before do
|
200
|
-
allow(admin_set).to receive(:permission_template).and_return(permission_template)
|
201
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'manage', agent_type: 'user').and_return(['mgr1@ex.com', 'mgr2@ex.com', user.user_key])
|
202
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'manage', agent_type: 'group').and_return(['managers', ::Ability.admin_group_name])
|
203
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'deposit', agent_type: 'user').and_return(['dep1@ex.com', 'dep2@ex.com'])
|
204
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'deposit', agent_type: 'group').and_return(['depositors', 'registered'])
|
205
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'view', agent_type: 'user').and_return(['vw1@ex.com', 'vw2@ex.com'])
|
206
|
-
allow(permission_template).to receive(:agent_ids_for).with(access: 'view', agent_type: 'group').and_return(['viewers', 'public'])
|
207
|
-
end
|
208
|
-
|
209
|
-
it 'resets user edit access' do
|
210
|
-
admin_set.reset_access_controls!
|
211
|
-
expect(admin_set.edit_users).to match_array([user.user_key, 'mgr1@ex.com', 'mgr2@ex.com'])
|
212
|
-
end
|
213
|
-
|
214
|
-
it 'resets group edit access' do
|
215
|
-
admin_set.reset_access_controls!
|
216
|
-
expect(admin_set.edit_groups).to match_array(['managers', ::Ability.admin_group_name])
|
217
|
-
end
|
218
|
-
|
219
|
-
it 'resets user read access' do
|
220
|
-
admin_set.reset_access_controls!
|
221
|
-
expect(admin_set.read_users).to match_array(['dep1@ex.com', 'dep2@ex.com', 'vw1@ex.com', 'vw2@ex.com'])
|
222
|
-
end
|
223
|
-
|
224
|
-
it 'resets group read access' do
|
225
|
-
admin_set.reset_access_controls!
|
226
|
-
expect(admin_set.read_groups).to match_array(['depositors', 'viewers'])
|
227
|
-
end
|
228
|
-
end
|
229
|
-
end
|
@@ -1,162 +0,0 @@
|
|
1
|
-
RSpec.describe ChecksumAuditLog do
|
2
|
-
let(:f) do
|
3
|
-
file = FileSet.create do |gf|
|
4
|
-
gf.apply_depositor_metadata('mjg36')
|
5
|
-
end
|
6
|
-
# TODO: Mock addition of file to fileset to avoid calls to .save.
|
7
|
-
# This will speed up tests and avoid uneccesary integration testing for fedora funcationality.
|
8
|
-
Hydra::Works::AddFileToFileSet.call(file, File.open(fixture_path + '/world.png'), :original_file)
|
9
|
-
file
|
10
|
-
end
|
11
|
-
|
12
|
-
let(:version_uri) do
|
13
|
-
Hyrax::VersioningService.create(f.original_file)
|
14
|
-
f.original_file.versions.first.uri
|
15
|
-
end
|
16
|
-
let(:content_id) { f.original_file.id }
|
17
|
-
let(:old) { described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true, created_at: 2.minutes.ago) }
|
18
|
-
let(:new) { described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: false, created_at: 1.minute.ago) }
|
19
|
-
|
20
|
-
context 'a file with multiple checksums' do
|
21
|
-
it 'returns a list of logs for this FileSet sorted by date descending' do
|
22
|
-
logs = described_class.logs_for(f.id, checked_uri: version_uri)
|
23
|
-
expect(logs).to eq([new, old])
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
describe ".create_and_prune!" do
|
28
|
-
let(:file_set_id) { 'file_set_id' }
|
29
|
-
let(:checked_uri) { "file_id/fcr:versions/version1" }
|
30
|
-
|
31
|
-
subject { described_class.create_and_prune!(passed: passed, file_set_id: 'file_set_id', file_id: 'file_id', checked_uri: checked_uri, expected_result: '1234') }
|
32
|
-
|
33
|
-
describe 'when check passed' do
|
34
|
-
let(:passed) { true }
|
35
|
-
|
36
|
-
it { is_expected.to be_a(described_class) }
|
37
|
-
it 'will prune history' do
|
38
|
-
expect(described_class).to receive(:prune_history).with(file_set_id, checked_uri: checked_uri)
|
39
|
-
subject
|
40
|
-
end
|
41
|
-
end
|
42
|
-
describe 'when check failed' do
|
43
|
-
let(:passed) { false }
|
44
|
-
|
45
|
-
it { is_expected.to be_a(described_class) }
|
46
|
-
it 'will not prune history' do
|
47
|
-
expect(described_class).not_to receive(:prune_history).with(file_set_id, checked_uri: checked_uri)
|
48
|
-
subject
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
|
53
|
-
describe ".prune_history" do
|
54
|
-
let(:file_set_id) { "file_set_id" }
|
55
|
-
let(:file_id) { "file_id" }
|
56
|
-
let(:version_uri) { "#{file_id}/fcr:versions/version1" }
|
57
|
-
|
58
|
-
context "one passing record" do
|
59
|
-
let!(:record) { described_class.create(created_at: 1.day.ago, file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
60
|
-
|
61
|
-
before do
|
62
|
-
described_class.prune_history(file_set_id, checked_uri: version_uri)
|
63
|
-
end
|
64
|
-
|
65
|
-
it "keeps record" do
|
66
|
-
expect(described_class.logs_for(file_set_id, checked_uri: version_uri).count).to eq(1)
|
67
|
-
end
|
68
|
-
end
|
69
|
-
|
70
|
-
context "two passing records" do
|
71
|
-
let!(:older) { described_class.create(created_at: 1.day.ago, file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
72
|
-
let!(:newer) { described_class.create(created_at: 0.days.ago, file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
73
|
-
|
74
|
-
before do
|
75
|
-
described_class.prune_history(file_set_id, checked_uri: version_uri)
|
76
|
-
end
|
77
|
-
|
78
|
-
it "keeps latest, gets rid of previous" do
|
79
|
-
logs = described_class.logs_for(file_set_id, checked_uri: version_uri).to_a
|
80
|
-
expect(logs.length).to eq 1
|
81
|
-
expect(logs.first.id).to eq newer.id
|
82
|
-
end
|
83
|
-
end
|
84
|
-
|
85
|
-
context "complex history" do
|
86
|
-
let!(:first) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
87
|
-
let!(:second) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
88
|
-
let!(:third) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: false) }
|
89
|
-
let!(:fourth) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
90
|
-
let!(:fifth) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
91
|
-
let!(:sixth) { described_class.create(file_set_id: file_set_id, file_id: file_id, checked_uri: version_uri, passed: true) }
|
92
|
-
|
93
|
-
before do
|
94
|
-
described_class.prune_history(file_set_id, checked_uri: version_uri)
|
95
|
-
end
|
96
|
-
it "keeps latest, failing, and previous/next of failing" do
|
97
|
-
logs = described_class.logs_for(file_set_id, checked_uri: version_uri).reorder("created_at asc")
|
98
|
-
expect(logs.collect(&:id)).to eq([second.id, third.id, fourth.id, sixth.id])
|
99
|
-
expect(logs.collect(&:passed)).to eq([true, false, true, true])
|
100
|
-
end
|
101
|
-
end
|
102
|
-
|
103
|
-
context 'after multiple checksum events where the checksum does not change' do
|
104
|
-
specify 'only one of them should be kept' do
|
105
|
-
success1 = described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true)
|
106
|
-
described_class.prune_history(f.id, checked_uri: version_uri)
|
107
|
-
success2 = described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true)
|
108
|
-
described_class.prune_history(f.id, checked_uri: version_uri)
|
109
|
-
success3 = described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true)
|
110
|
-
|
111
|
-
described_class.prune_history(f.id, checked_uri: version_uri)
|
112
|
-
|
113
|
-
expect { described_class.find(success1.id) }.to raise_exception ActiveRecord::RecordNotFound
|
114
|
-
expect { described_class.find(success2.id) }.to raise_exception ActiveRecord::RecordNotFound
|
115
|
-
expect(described_class.find(success3.id)).not_to be_nil
|
116
|
-
logs = described_class.logs_for(f.id, checked_uri: version_uri)
|
117
|
-
expect(logs.collect(&:id)).to eq([success3.id])
|
118
|
-
end
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
context "multiple versions with multiple checks" do
|
123
|
-
# I don't quite understand how our FileSet already has multiple
|
124
|
-
# versions, but that's great since I couldn't figure out a reasonable
|
125
|
-
# way to create them. Note you need to #all here, or you get
|
126
|
-
# really confusing stuff.
|
127
|
-
let(:verisons_uri) { f.original_file.versions.all.first.uri }
|
128
|
-
let(:version_uri2) { f.original_file.versions.all.second.uri }
|
129
|
-
|
130
|
-
before do
|
131
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true, created_at: 2.days.ago)
|
132
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true, created_at: 1.day.ago)
|
133
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri, passed: true)
|
134
|
-
|
135
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri2, passed: true, created_at: 2.days.ago)
|
136
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri2, passed: false, created_at: 1.day.ago)
|
137
|
-
described_class.create(file_set_id: f.id, file_id: content_id, checked_uri: version_uri2, passed: true)
|
138
|
-
end
|
139
|
-
describe ".latest_checks" do
|
140
|
-
it "returns only latest for each checked_uri" do
|
141
|
-
expected = [
|
142
|
-
described_class.where(checked_uri: version_uri).order("created_at desc").first,
|
143
|
-
described_class.where(checked_uri: version_uri2).order("created_at desc").first
|
144
|
-
]
|
145
|
-
expect(described_class.latest_checks).to match_array(expected)
|
146
|
-
end
|
147
|
-
end
|
148
|
-
describe ".latest_for_file_set_id" do
|
149
|
-
before do
|
150
|
-
# add some for another file set, doens't matter it doesn't exist
|
151
|
-
described_class.create(file_set_id: "somethingelse", file_id: "whatever", checked_uri: "http://example.org/w")
|
152
|
-
end
|
153
|
-
it "returns only the lastest check for FileSet specified" do
|
154
|
-
expected = [
|
155
|
-
described_class.where(checked_uri: version_uri).order("created_at desc").first,
|
156
|
-
described_class.where(checked_uri: version_uri2).order("created_at desc").first
|
157
|
-
]
|
158
|
-
expect(described_class.latest_for_file_set_id(f.id)).to match_array(expected)
|
159
|
-
end
|
160
|
-
end
|
161
|
-
end
|
162
|
-
end
|