sufia 7.1.0 → 7.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.codeclimate.yml +49 -0
- data/.engine_cart.yml +1 -0
- data/.eslintignore +1 -0
- data/.eslintrc +213 -0
- data/.gitignore +2 -0
- data/.hound.yml +5 -0
- data/.rubocop.yml +27 -17
- data/.rubocop_todo.yml +6 -3
- data/.scss-lint.yml +253 -0
- data/.travis.yml +3 -2
- data/Gemfile +5 -1
- data/README.md +30 -16
- data/app/assets/javascripts/sufia.js +6 -0
- data/app/assets/javascripts/sufia/app.js +13 -5
- data/app/assets/javascripts/sufia/fileupload.js.erb +12 -0
- data/app/assets/javascripts/sufia/initialize.js +3 -0
- data/app/assets/javascripts/sufia/save_work/required_fields.es6 +5 -1
- data/app/assets/javascripts/sufia/save_work/save_work_control.es6 +12 -0
- data/app/assets/javascripts/sufia/trophy.js +14 -14
- data/app/assets/javascripts/sufia/uploader.js +32 -3
- data/app/assets/stylesheets/fileupload/jquery.fileupload-ui.scss +29 -35
- data/app/assets/stylesheets/sufia/_batch-edit.scss +0 -5
- data/app/assets/stylesheets/sufia/_browse_everything_overrides.scss +1 -1
- data/app/assets/stylesheets/sufia/_buttons.scss +6 -1
- data/app/assets/stylesheets/sufia/_catalog.scss +6 -0
- data/app/assets/stylesheets/sufia/_collections.scss +29 -13
- data/app/assets/stylesheets/sufia/_dashboard.scss +27 -19
- data/app/assets/stylesheets/sufia/_file-listing.scss +7 -0
- data/app/assets/stylesheets/sufia/_file_upload.scss +20 -0
- data/app/assets/stylesheets/sufia/_form.scss +30 -0
- data/app/assets/stylesheets/sufia/_home-page.scss +87 -33
- data/app/assets/stylesheets/sufia/_representative-media.scss +4 -0
- data/app/assets/stylesheets/sufia/_styles.scss +0 -23
- data/app/assets/stylesheets/sufia/_sufia.scss +10 -7
- data/app/assets/stylesheets/sufia/_variables.scss +14 -0
- data/app/assets/stylesheets/sufia/_work-show.scss +1 -1
- data/app/assets/stylesheets/sufia/admin.scss +203 -0
- data/app/assets/stylesheets/sufia/widgets.css +288 -0
- data/app/controllers/api/items_controller.rb +1 -1
- data/app/controllers/concerns/sufia/admin/stats_behavior.rb +7 -1
- data/app/controllers/concerns/sufia/batch_edits_controller_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/batch_uploads_controller_behavior.rb +0 -1
- data/app/controllers/concerns/sufia/collections_controller_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/contact_form_controller_behavior.rb +19 -5
- data/app/controllers/concerns/sufia/deny_access_override_behavior.rb +13 -0
- data/app/controllers/concerns/sufia/depositors_controller_behavior.rb +1 -10
- data/app/controllers/concerns/sufia/file_sets_controller_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/homepage_controller_behavior.rb +11 -2
- data/app/controllers/concerns/sufia/my_controller_behavior.rb +7 -16
- data/app/controllers/concerns/sufia/singular_subresource_controller.rb +1 -10
- data/app/controllers/concerns/sufia/transfers_controller_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/users_controller_behavior.rb +2 -25
- data/app/controllers/concerns/sufia/works_controller_behavior.rb +27 -3
- data/app/controllers/content_blocks_controller.rb +12 -2
- data/app/controllers/curation_concerns/file_sets_controller.rb +0 -1
- data/app/controllers/curation_concerns/permissions_controller.rb +8 -16
- data/app/controllers/my/highlights_controller.rb +1 -1
- data/app/controllers/stats_controller.rb +2 -2
- data/app/controllers/sufia/admin/admin_sets_controller.rb +114 -0
- data/app/controllers/sufia/admin/features_controller.rb +13 -0
- data/app/controllers/sufia/admin/stats_controller.rb +5 -0
- data/app/controllers/sufia/admin/strategies_controller.rb +14 -0
- data/app/controllers/sufia/admin_controller.rb +11 -0
- data/app/controllers/sufia/admin_sets_controller.rb +25 -0
- data/app/controllers/sufia/resource_sync_controller.rb +11 -15
- data/app/forms/sufia/forms/admin_set_form.rb +30 -0
- data/app/forms/sufia/forms/batch_edit_form.rb +1 -1
- data/app/forms/sufia/forms/work_form.rb +2 -2
- data/app/helpers/sufia/citations_behaviors/title_behavior.rb +1 -1
- data/app/helpers/sufia/dashboard_helper_behavior.rb +6 -0
- data/app/helpers/sufia/permissions_helper.rb +19 -0
- data/app/helpers/sufia/sufia_helper_behavior.rb +13 -6
- data/app/indexers/sufia/work_indexer.rb +4 -0
- data/app/jobs/attach_files_to_work_job.rb +3 -1
- data/app/jobs/content_depositor_change_event_job.rb +0 -7
- data/app/jobs/content_event_job.rb +0 -7
- data/app/jobs/event_job.rb +1 -11
- data/app/jobs/inherit_permissions_job.rb +24 -0
- data/app/mailers/sufia/contact_mailer.rb +11 -0
- data/app/models/concerns/sufia/ability.rb +12 -1
- data/app/models/concerns/sufia/content_block_behavior.rb +47 -0
- data/app/models/concerns/sufia/solr_document/export.rb +6 -0
- data/app/models/concerns/sufia/solr_document_behavior.rb +4 -0
- data/app/models/concerns/sufia/user.rb +7 -8
- data/app/models/concerns/sufia/with_events.rb +5 -1
- data/app/models/concerns/sufia/works/featured.rb +1 -1
- data/app/models/concerns/sufia/works/trophies.rb +1 -1
- data/app/models/content_block.rb +1 -39
- data/app/models/featured_work_list.rb +0 -1
- data/app/models/file_download_stat.rb +18 -7
- data/app/models/file_view_stat.rb +5 -2
- data/app/models/sufia/contact_form.rb +33 -0
- data/app/models/sufia/feature.rb +5 -0
- data/app/models/sufia/statistic.rb +6 -5
- data/app/presenters/sufia/admin_dashboard_presenter.rb +8 -0
- data/app/presenters/sufia/admin_set_presenter.rb +7 -0
- data/app/presenters/sufia/admin_stats_presenter.rb +0 -4
- data/app/presenters/sufia/collection_presenter.rb +5 -4
- data/app/presenters/sufia/file_set_presenter.rb +16 -3
- data/app/presenters/sufia/file_usage.rb +37 -0
- data/app/presenters/sufia/stats_usage_presenter.rb +43 -0
- data/app/presenters/sufia/trophy_presenter.rb +2 -0
- data/app/presenters/sufia/work_show_presenter.rb +3 -1
- data/app/presenters/sufia/work_usage.rb +30 -0
- data/app/search_builders/collection_search_builder.rb +1 -1
- data/app/search_builders/sufia/admin_set_member_search_builder.rb +12 -0
- data/app/search_builders/sufia/single_admin_set_search_builder.rb +9 -0
- data/app/services/sufia/admin_set_service.rb +22 -0
- data/app/services/sufia/analytics.rb +51 -26
- data/app/services/sufia/collection_size_service.rb +1 -1
- data/app/services/sufia/file_set_csv_service.rb +1 -1
- data/app/services/sufia/statistics/system_stats.rb +0 -6
- data/app/views/_controls.html.erb +8 -4
- data/app/views/_logo.html.erb +1 -1
- data/app/views/_toolbar.html.erb +1 -1
- data/app/views/catalog/_facet_limit.html.erb +2 -2
- data/app/views/catalog/_search_form.html.erb +0 -4
- data/app/views/catalog/_thumbnail_list_collection.html.erb +1 -3
- data/app/views/catalog/index.html.erb +1 -1
- data/app/views/collections/_dashboard_document_list.html.erb +1 -3
- data/app/views/collections/_document_list.html.erb +0 -2
- data/app/views/collections/_form.html.erb +1 -1
- data/app/views/collections/_form_for_select_collection.html.erb +1 -1
- data/app/views/collections/_media_display.html.erb +1 -3
- data/app/views/collections/_show_descriptions.html.erb +1 -1
- data/app/views/collections/_show_document_list.html.erb +3 -1
- data/app/views/collections/_show_document_list_menu.html.erb +12 -12
- data/app/views/collections/_show_document_list_row.html.erb +6 -4
- data/app/views/contact_form/new.html.erb +1 -1
- data/app/views/curation_concerns/base/_attribute_rows.html.erb +12 -10
- data/app/views/curation_concerns/base/_citations.html.erb +2 -2
- data/app/views/curation_concerns/base/_form_files.html.erb +11 -3
- data/app/views/curation_concerns/base/_form_metadata.html.erb +1 -1
- data/app/views/curation_concerns/base/_form_progress.html.erb +2 -2
- data/app/views/curation_concerns/base/_form_relationships.html.erb +8 -0
- data/app/views/curation_concerns/base/_guts4form.html.erb +8 -4
- data/app/views/curation_concerns/base/_items.html.erb +7 -7
- data/app/views/curation_concerns/base/_relationships.html.erb +0 -1
- data/app/views/curation_concerns/base/_show_actions.html.erb +3 -0
- data/app/views/curation_concerns/base/_social_media.html.erb +49 -15
- data/app/views/curation_concerns/file_sets/_actions.html.erb +1 -9
- data/app/views/curation_concerns/file_sets/_groups_description.html.erb +1 -5
- data/app/views/curation_concerns/file_sets/media_display/_default.html.erb +3 -0
- data/app/views/curation_concerns/permissions/confirm_access.html.erb +12 -0
- data/app/views/dashboard/_index_partials/_heading_greetings.html.erb +1 -1
- data/app/views/layouts/admin.html.erb +71 -0
- data/app/views/layouts/{sufia-one-column.html.erb → curation_concerns/1_column.html.erb} +1 -1
- data/app/views/layouts/homepage.html.erb +35 -2
- data/app/views/layouts/sufia-dashboard.html.erb +1 -1
- data/app/views/my/_facet_pagination.html.erb +5 -5
- data/app/views/my/_index_partials/_list_collections.html.erb +1 -3
- data/app/views/my/_scripts.js.erb +1 -2
- data/app/views/my/index.html.erb +3 -3
- data/app/views/records/edit_fields/_description.html.erb +2 -2
- data/app/views/records/edit_fields/_rights.html.erb +3 -2
- data/app/views/records/show_fields/_rights.html.erb +2 -1
- data/app/views/shared/_footer.html.erb +1 -1
- data/app/views/sufia/admin/_menu.html.erb +5 -0
- data/app/views/sufia/admin/_sidebar.html.erb +23 -0
- data/app/views/sufia/admin/admin_sets/_form.html.erb +18 -0
- data/app/views/sufia/admin/admin_sets/_sort_and_per_page.html.erb +5 -0
- data/app/views/sufia/admin/admin_sets/edit.html.erb +9 -0
- data/app/views/sufia/admin/admin_sets/index.html.erb +46 -0
- data/app/views/sufia/admin/admin_sets/new.html.erb +9 -0
- data/app/views/sufia/admin/admin_sets/show.html.erb +43 -0
- data/app/views/sufia/admin/features/index.html.erb +57 -0
- data/app/views/sufia/admin/show.html.erb +36 -0
- data/app/views/{admin → sufia/admin}/stats/_date_form.html.erb +0 -0
- data/app/views/{admin → sufia/admin}/stats/_deposits.html.erb +0 -0
- data/app/views/{admin → sufia/admin}/stats/_new_users.html.erb +0 -0
- data/app/views/{admin → sufia/admin}/stats/_stats_by_date.html.erb +4 -4
- data/app/views/{admin → sufia/admin}/stats/_top_data.html.erb +2 -2
- data/app/views/{admin → sufia/admin}/stats/_works.html.erb +0 -0
- data/app/views/sufia/admin/stats/show.html.erb +7 -0
- data/app/views/sufia/admin_sets/_admin_set.html.erb +25 -0
- data/app/views/sufia/admin_sets/_document_list.html.erb +30 -0
- data/app/views/sufia/admin_sets/_member_document.html.erb +26 -0
- data/app/views/sufia/admin_sets/_search_form.html.erb +12 -0
- data/app/views/sufia/admin_sets/_sort_and_per_page.html.erb +5 -0
- data/app/views/sufia/admin_sets/index.html.erb +2 -0
- data/app/views/sufia/admin_sets/show.html.erb +33 -0
- data/app/views/sufia/contact_mailer/contact.html.erb +5 -0
- data/app/views/sufia/homepage/_explore_collections.html.erb +28 -0
- data/app/views/sufia/homepage/_featured_researcher.html.erb +7 -2
- data/app/views/sufia/homepage/_featured_works.html.erb +1 -1
- data/app/views/sufia/homepage/_home_content.html.erb +21 -3
- data/app/views/sufia/homepage/_marketing.html.erb +1 -1
- data/app/views/sufia/homepage/_recently_uploaded.html.erb +14 -16
- data/app/views/sufia/homepage/index.html.erb +14 -5
- data/app/views/users/_activity_log.html.erb +0 -1
- data/app/views/users/_contributions.html.erb +1 -1
- data/app/views/users/_profile_actions.html.erb +6 -16
- data/app/views/users/_vitals.html.erb +0 -5
- data/app/views/users/index.html.erb +16 -16
- data/config/features.rb +10 -0
- data/config/locales/sufia.en.yml +76 -25
- data/config/routes.rb +16 -17
- data/db/migrate/20160415212015_create_features.rb +10 -0
- data/lib/generators/sufia/install_generator.rb +10 -34
- data/lib/generators/sufia/templates/catalog_controller.rb +7 -6
- data/lib/generators/sufia/templates/config/sufia.rb +7 -0
- data/lib/generators/sufia/work_generator.rb +2 -2
- data/lib/sufia.rb +0 -1
- data/lib/sufia/arkivo/metadata_munger.rb +13 -2
- data/lib/sufia/configuration.rb +5 -0
- data/lib/sufia/controlled_vocabulary/importer/downloader.rb +17 -0
- data/lib/sufia/controlled_vocabulary/importer/language.rb +62 -0
- data/lib/sufia/engine.rb +7 -0
- data/lib/sufia/redis_event_store.rb +2 -2
- data/lib/sufia/resource_sync/resource_list_writer.rb +1 -1
- data/lib/sufia/version.rb +1 -1
- data/solr/config/solrconfig.xml +26 -15
- data/spec/actors/sufia/create_with_files_actor_spec.rb +6 -4
- data/spec/actors/sufia/create_with_remote_files_actor_spec.rb +26 -18
- data/spec/controllers/api/items_controller_spec.rb +32 -22
- data/spec/controllers/api/zotero_controller_spec.rb +2 -2
- data/spec/controllers/batch_edits_controller_spec.rb +5 -6
- data/spec/controllers/catalog_controller_spec.rb +11 -11
- data/spec/controllers/citations_controller_spec.rb +2 -2
- data/spec/controllers/collections_controller_spec.rb +57 -36
- data/spec/controllers/contact_form_controller_spec.rb +6 -6
- data/spec/controllers/content_blocks_controller_spec.rb +8 -8
- data/spec/controllers/curation_concerns/audits_controller_spec.rb +2 -2
- data/spec/controllers/curation_concerns/file_sets_controller_spec.rb +51 -43
- data/spec/controllers/curation_concerns/generic_works_controller_spec.rb +51 -27
- data/spec/controllers/curation_concerns/permissions_controller_spec.rb +24 -0
- data/spec/controllers/depositors_controller_spec.rb +5 -5
- data/spec/controllers/downloads_controller_spec.rb +4 -4
- data/spec/controllers/featured_work_lists_controller_spec.rb +5 -3
- data/spec/controllers/featured_works_controller_spec.rb +9 -9
- data/spec/controllers/mailbox_controller_spec.rb +1 -1
- data/spec/controllers/my/collections_controller_spec.rb +3 -7
- data/spec/controllers/my/highlights_controller_spec.rb +2 -2
- data/spec/controllers/my/shares_controller_spec.rb +2 -2
- data/spec/controllers/my/works_controller_spec.rb +5 -14
- data/spec/controllers/pages_controller_spec.rb +2 -2
- data/spec/controllers/static_controller_spec.rb +2 -2
- data/spec/controllers/stats_controller_spec.rb +8 -8
- data/spec/controllers/sufia/admin/admin_sets_controller_spec.rb +123 -0
- data/spec/controllers/sufia/admin/features_controller_spec.rb +29 -0
- data/spec/controllers/{admin → sufia/admin}/stats_controller_spec.rb +10 -6
- data/spec/controllers/sufia/admin/strategies_controller_spec.rb +30 -0
- data/spec/controllers/sufia/admin_controller_spec.rb +13 -0
- data/spec/controllers/sufia/admin_sets_controller_spec.rb +28 -0
- data/spec/controllers/sufia/batch_uploads_controller_spec.rb +48 -17
- data/spec/controllers/sufia/homepage_controller_spec.rb +21 -0
- data/spec/controllers/sufia/trophies_controller_spec.rb +2 -2
- data/spec/controllers/sufia/uploads_controller_spec.rb +5 -5
- data/spec/controllers/tinymce_assets_controller_spec.rb +5 -5
- data/spec/controllers/transfers_controller_spec.rb +23 -16
- data/spec/controllers/users_controller_spec.rb +21 -69
- data/spec/factories/admin_sets.rb +9 -0
- data/spec/factories/collections_factory.rb +5 -3
- data/spec/factories/generic_works.rb +3 -1
- data/spec/features/admin_admin_set_spec.rb +30 -0
- data/spec/features/browse_dashboard_files_spec.rb +3 -3
- data/spec/features/contact_form_spec.rb +5 -5
- data/spec/features/create_work_spec.rb +1 -1
- data/spec/features/display_dashboard_spec.rb +1 -1
- data/spec/features/ownership_transfer_spec.rb +29 -30
- data/spec/features/search_spec.rb +2 -1
- data/spec/features/user_admin_set_spec.rb +55 -0
- data/spec/features/work_show_spec.rb +13 -3
- data/spec/forms/curation_concerns/generic_work_form_spec.rb +30 -24
- data/spec/forms/sufia/forms/admin_set_form_spec.rb +20 -0
- data/spec/forms/sufia/forms/batch_edit_form_spec.rb +27 -25
- data/spec/forms/sufia/forms/batch_upload_form_spec.rb +29 -26
- data/spec/forms/sufia/forms/collection_form_spec.rb +36 -32
- data/spec/helpers/sufia_helper_spec.rb +17 -28
- data/spec/indexers/sufia/work_indexer_spec.rb +16 -0
- data/spec/javascripts/required_field_spec.js +41 -0
- data/spec/javascripts/save_work_spec.js +9 -0
- data/spec/jobs/attach_files_to_work_job_spec.rb +6 -1
- data/spec/jobs/batch_create_job_spec.rb +8 -6
- data/spec/jobs/content_delete_event_job_spec.rb +6 -18
- data/spec/jobs/content_deposit_event_job_spec.rb +3 -12
- data/spec/jobs/content_depositor_change_event_job_spec.rb +3 -8
- data/spec/jobs/content_new_version_event_job_spec.rb +3 -12
- data/spec/jobs/content_restored_version_event_job_spec.rb +3 -11
- data/spec/jobs/content_update_event_job_spec.rb +13 -79
- data/spec/jobs/file_set_attached_event_job_spec.rb +2 -10
- data/spec/jobs/inherit_permissions_job_spec.rb +96 -0
- data/spec/jobs/user_edit_profile_event_job_spec.rb +3 -7
- data/spec/lib/sufia/analytics_spec.rb +42 -11
- data/spec/lib/sufia/arkivo/actor_spec.rb +4 -4
- data/spec/lib/sufia/arkivo/schema_validator_spec.rb +18 -18
- data/spec/lib/sufia/controlled_vocabulary/importer/language_spec.rb +24 -0
- data/spec/lib/sufia/redis_event_store_spec.rb +8 -0
- data/spec/lib/sufia/resource_sync/capability_list_writer_spec.rb +4 -2
- data/spec/lib/sufia/resource_sync/resource_list_writer_spec.rb +10 -7
- data/spec/models/file_download_stat_spec.rb +35 -12
- data/spec/models/file_view_stat_spec.rb +12 -12
- data/spec/models/flipflop_spec.rb +8 -0
- data/spec/models/generic_work_spec.rb +3 -1
- data/spec/models/solr_document_spec.rb +20 -8
- data/spec/models/sufia/ability_spec.rb +5 -0
- data/spec/models/user_spec.rb +4 -28
- data/spec/models/work_view_stat_spec.rb +26 -17
- data/spec/presenters/sufia/admin_dashboard_presenter_spec.rb +14 -0
- data/spec/presenters/sufia/admin_set_presenter_spec.rb +28 -0
- data/spec/presenters/sufia/admin_stats_presenter_spec.rb +0 -8
- data/spec/presenters/sufia/collection_presenter_spec.rb +21 -16
- data/spec/presenters/sufia/file_set_presenter_spec.rb +44 -1
- data/spec/presenters/sufia/file_usage_spec.rb +49 -55
- data/spec/presenters/sufia/work_show_presenter_spec.rb +12 -2
- data/spec/presenters/sufia/work_usage_spec.rb +37 -36
- data/spec/routing/route_spec.rb +19 -21
- data/spec/search_builder/sufia/my_shares_search_builder_spec.rb +14 -7
- data/spec/search_builder/sufia/single_admin_set_search_builder_spec.rb +17 -0
- data/spec/services/sufia/actor_factory_spec.rb +11 -9
- data/spec/services/sufia/admin_set_service_spec.rb +27 -0
- data/spec/services/sufia/audit_failure_service_spec.rb +1 -1
- data/spec/services/sufia/file_set_csv_service_spec.rb +6 -7
- data/spec/services/sufia/statistics/system_stats_spec.rb +0 -10
- data/spec/services/sufia/user_stat_importer_spec.rb +306 -2
- data/spec/spec_helper.rb +43 -4
- data/spec/support/backport_test_helpers.rb +19 -0
- data/spec/support/selectors.rb +0 -19
- data/spec/test_app_templates/Gemfile.extra +1 -0
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +0 -2
- data/spec/views/_toolbar.html.erb_spec.rb +6 -6
- data/spec/views/catalog/_index_list_default.html.erb_spec.rb +10 -1
- data/spec/views/catalog/_thumbnail_list_collection.html.erb_spec.rb +10 -0
- data/spec/views/citations/work.html.erb_spec.rb +2 -2
- data/spec/views/collections/_form_for_select_collection.html.erb_spec.rb +6 -4
- data/spec/views/collections/_show_document_list.html.erb_spec.rb +1 -0
- data/spec/views/collections/_show_document_list_menu.html.erb_spec.rb +14 -3
- data/spec/views/collections/show.html.erb_spec.rb +7 -2
- data/spec/views/curation_concerns/base/_attribute_rows.html.erb_spec.rb +19 -0
- data/spec/views/curation_concerns/base/_citations.html.erb_spec.rb +2 -2
- data/spec/views/curation_concerns/base/_form.html.erb_spec.rb +2 -0
- data/spec/views/curation_concerns/base/_form_relationships.html.erb_spec.rb +48 -0
- data/spec/views/curation_concerns/base/_items.html.erb_spec.rb +49 -0
- data/spec/views/curation_concerns/base/_relationships.html.erb_spec.rb +2 -30
- data/spec/views/curation_concerns/base/_show_actions.html.erb_spec.rb +69 -0
- data/spec/views/curation_concerns/base/_social_media.html.erb_spec.rb +18 -0
- data/spec/views/curation_concerns/file_sets/_permission_form.html.erb_spec.rb +2 -2
- data/spec/views/curation_concerns/file_sets/_show_actions.html.erb_spec.rb +18 -3
- data/spec/views/curation_concerns/file_sets/media_display/_default.html.erb_spec.rb +26 -0
- data/spec/views/dashboard/index_spec.rb +5 -9
- data/spec/views/my/_list_collections.html.erb_spec.rb +1 -0
- data/spec/views/records/edit_fields/_description.html.erb_spec.rb +66 -0
- data/spec/views/stats_file.html.erb_spec.rb +5 -5
- data/spec/views/sufia/admin/admin_sets/index.html.erb_spec.rb +27 -0
- data/spec/views/{admin/stats/index.html.erb_spec.rb → sufia/admin/stats/show.html.erb_spec.rb} +1 -1
- data/spec/views/sufia/batch_uploads/_form.html.erb_spec.rb +3 -1
- data/spec/views/sufia/homepage/_featured_works.html.erb_spec.rb +9 -7
- data/spec/views/sufia/homepage/{_home_header.html.erb_spec.rb → index.html.erb_spec.rb} +3 -3
- data/spec/views/users/_user_util_links.html.erb_spec.rb +1 -1
- data/spec/views/users/index.html.erb_spec.rb +2 -1
- data/spec/views/users/show.html.erb_spec.rb +5 -1
- data/sufia.gemspec +13 -8
- data/tasks/controlled_vocabularies.rake +9 -0
- data/vendor/assets/stylesheets/sharing_buttons.css +163 -0
- metadata +246 -124
- data/app/assets/images/old_main_tulips.jpg +0 -0
- data/app/assets/javascripts/sufia/fileupload.js +0 -6
- data/app/assets/stylesheets/sufia.scss +0 -10
- data/app/controllers/admin/stats_controller.rb +0 -3
- data/app/controllers/errors_controller.rb +0 -12
- data/app/jobs/user_follow_event_job.rb +0 -21
- data/app/jobs/user_unfollow_event_job.rb +0 -20
- data/app/models/contact_form.rb +0 -28
- data/app/models/follow.rb +0 -12
- data/app/presenters/file_usage.rb +0 -49
- data/app/presenters/sufia/characterization_behavior.rb +0 -80
- data/app/presenters/work_usage.rb +0 -51
- data/app/views/admin/_menu.html.erb +0 -8
- data/app/views/admin/stats/index.html.erb +0 -10
- data/app/views/advanced/_advanced_search_facets.html.erb +0 -1
- data/app/views/advanced/_advanced_search_fields.html.erb +0 -8
- data/app/views/advanced/_advanced_search_form.html.erb +0 -34
- data/app/views/advanced/_advanced_search_help.html.erb +0 -13
- data/app/views/advanced/_facet_layout.html.erb +0 -5
- data/app/views/advanced/_facet_limit.html.erb +0 -7
- data/app/views/advanced/index.html.erb +0 -21
- data/app/views/collections/_search_collection_dashboard_form.html.erb +0 -11
- data/app/views/curation_concerns/base/_relationships_member_rows.html.erb +0 -24
- data/app/views/errors/404.html.erb +0 -8
- data/app/views/layouts/error.html.erb +0 -27
- data/app/views/static/subject_libraries.html.erb +0 -32
- data/app/views/sufia/homepage/_home_header.html.erb +0 -13
- data/app/views/users/_follower_modal.html.erb +0 -32
- data/app/views/users/_following_modal.html.erb +0 -32
- data/db/migrate/20160328222155_acts_as_follower_migration.rb +0 -17
- data/spec/controllers/my_controller_spec.rb +0 -2
- data/spec/jobs/user_follow_event_job_spec.rb +0 -24
- data/spec/jobs/user_unfollow_event_job_spec.rb +0 -25
- data/spec/lib/sufia/user_stat_importer_spec.rb +0 -309
- data/spec/views/catalog/sort_and_per_page.html.erb_spec.rb +0 -33
- data/spec/views/users/_follower_modal.html.erb_spec.rb +0 -46
- data/spec/views/users/_following_modal.html.erb_spec.rb +0 -55
data/spec/spec_helper.rb
CHANGED
@@ -4,7 +4,12 @@ Coveralls.wear!
|
|
4
4
|
ENV["RAILS_ENV"] ||= 'test'
|
5
5
|
require "bundler/setup"
|
6
6
|
|
7
|
-
|
7
|
+
def coverage_needed?
|
8
|
+
(!ENV['RAILS_VERSION'] || ENV['RAILS_VERSION'].start_with?('5.0')) &&
|
9
|
+
(ENV['COVERAGE'] || ENV['TRAVIS'])
|
10
|
+
end
|
11
|
+
|
12
|
+
if coverage_needed?
|
8
13
|
require 'simplecov'
|
9
14
|
SimpleCov.root(File.expand_path('../..', __FILE__))
|
10
15
|
SimpleCov.formatter = Coveralls::SimpleCov::Formatter
|
@@ -23,6 +28,7 @@ EngineCart.load_application!
|
|
23
28
|
require 'devise'
|
24
29
|
require 'devise/version'
|
25
30
|
require 'mida'
|
31
|
+
require 'rails-controller-testing' if Rails::VERSION::MAJOR >= 5
|
26
32
|
require 'rspec/rails'
|
27
33
|
require 'rspec/its'
|
28
34
|
require 'rspec/matchers'
|
@@ -34,6 +40,7 @@ require 'equivalent-xml'
|
|
34
40
|
require 'equivalent-xml/rspec_matchers'
|
35
41
|
require 'database_cleaner'
|
36
42
|
require 'support/features'
|
43
|
+
require 'support/backport_test_helpers'
|
37
44
|
require 'support/rake'
|
38
45
|
require 'byebug' unless ENV['TRAVIS']
|
39
46
|
|
@@ -41,14 +48,14 @@ Capybara.default_driver = :rack_test # This is a faster driver
|
|
41
48
|
Capybara.javascript_driver = :poltergeist # This is slower
|
42
49
|
Capybara.default_max_wait_time = ENV['TRAVIS'] ? 30 : 15
|
43
50
|
|
51
|
+
ActiveJob::Base.queue_adapter = :inline
|
52
|
+
|
44
53
|
# require 'http_logger'
|
45
54
|
# HttpLogger.logger = Logger.new(STDOUT)
|
46
55
|
# HttpLogger.ignore = [/localhost:8983\/solr/]
|
47
56
|
# HttpLogger.colorize = false
|
48
57
|
|
49
|
-
|
50
|
-
|
51
|
-
if $in_travis
|
58
|
+
if ENV['TRAVIS'] == 'true'
|
52
59
|
# Monkey-patches the FITS runner to return the PDF FITS fixture
|
53
60
|
module Hydra::Works
|
54
61
|
class CharacterizationService
|
@@ -140,6 +147,17 @@ RSpec.configure do |config|
|
|
140
147
|
end
|
141
148
|
end
|
142
149
|
|
150
|
+
config.before(:all, type: :feature) do
|
151
|
+
# Assets take a long time to compile. This causes two problems:
|
152
|
+
# 1) the profile will show the first feature test taking much longer than it
|
153
|
+
# normally would.
|
154
|
+
# 2) The first feature test will trigger rack-timeout
|
155
|
+
#
|
156
|
+
# Precompile the assets to prevent these issues.
|
157
|
+
visit "/assets/application.css"
|
158
|
+
visit "/assets/application.js"
|
159
|
+
end
|
160
|
+
|
143
161
|
config.after do
|
144
162
|
DatabaseCleaner.clean
|
145
163
|
end
|
@@ -158,6 +176,10 @@ RSpec.configure do |config|
|
|
158
176
|
config.include Devise::TestHelpers, type: :controller
|
159
177
|
end
|
160
178
|
|
179
|
+
if Rails::VERSION::MAJOR < 5
|
180
|
+
config.include BackportTestHelpers, type: :controller
|
181
|
+
end
|
182
|
+
|
161
183
|
config.include EngineRoutes, type: :controller
|
162
184
|
config.include Warden::Test::Helpers, type: :feature
|
163
185
|
config.after(:each, type: :feature) { Warden.test_reset! }
|
@@ -166,4 +188,21 @@ RSpec.configure do |config|
|
|
166
188
|
config.include FactoryGirl::Syntax::Methods
|
167
189
|
|
168
190
|
config.infer_spec_type_from_file_location!
|
191
|
+
|
192
|
+
config.expect_with :rspec do |expectations|
|
193
|
+
expectations.include_chain_clauses_in_custom_matcher_descriptions = true
|
194
|
+
end
|
195
|
+
|
196
|
+
config.default_formatter = 'doc' if config.files_to_run.one?
|
197
|
+
|
198
|
+
config.order = :random
|
199
|
+
Kernel.srand config.seed
|
200
|
+
|
201
|
+
config.shared_context_metadata_behavior = :apply_to_host_groups
|
202
|
+
|
203
|
+
config.filter_run_when_matching :focus
|
204
|
+
|
205
|
+
config.example_status_persistence_file_path = 'spec/examples.txt'
|
206
|
+
|
207
|
+
config.profile_examples = 10
|
169
208
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# Backport the Rails 5 controller test methods to Rails 4
|
2
|
+
module BackportTestHelpers
|
3
|
+
[:delete, :get, :post, :put, :patch].each do |http_action|
|
4
|
+
define_method(http_action) do |*args|
|
5
|
+
(action, rest) = *args
|
6
|
+
rest ||= {}
|
7
|
+
if rest[:xhr]
|
8
|
+
@request.env['HTTP_X_REQUESTED_WITH'] = 'XMLHttpRequest'
|
9
|
+
@request.env['HTTP_ACCEPT'] ||= [Mime::JS, Mime::HTML, Mime::XML, 'text/xml', Mime::ALL].join(', ')
|
10
|
+
end
|
11
|
+
|
12
|
+
if rest[:body]
|
13
|
+
super(action, rest[:body], rest.except(:params).merge(rest.fetch(:params, {})))
|
14
|
+
else
|
15
|
+
super(action, rest.except(:params).merge(rest.fetch(:params, {})))
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
data/spec/support/selectors.rb
CHANGED
@@ -1,23 +1,4 @@
|
|
1
1
|
module Selectors
|
2
|
-
module Header
|
3
|
-
def nav_toggle(section, link)
|
4
|
-
within '#masthead' do
|
5
|
-
click_on section
|
6
|
-
click_on link
|
7
|
-
end
|
8
|
-
end
|
9
|
-
|
10
|
-
def user_notifications_link
|
11
|
-
nav_toggle('Dashboard', 'Notifications')
|
12
|
-
end
|
13
|
-
|
14
|
-
def user_utility_toggle
|
15
|
-
within '#user_utility_links' do
|
16
|
-
find '.dropdown-toggle.btn.btn-default'
|
17
|
-
end
|
18
|
-
end
|
19
|
-
end
|
20
|
-
|
21
2
|
module Dashboard
|
22
3
|
def db_item_actions_toggle(item)
|
23
4
|
within "#document_#{item.id}" do
|
@@ -42,8 +42,6 @@ class TestAppGenerator < Rails::Generators::Base
|
|
42
42
|
end
|
43
43
|
|
44
44
|
def enable_i18n_translation_errors
|
45
|
-
say_status("info", "Adding i18n_translation_errors = true to dev and test", :blue)
|
46
|
-
|
47
45
|
gsub_file "config/environments/development.rb",
|
48
46
|
"# config.action_view.raise_on_missing_translations = true", "config.action_view.raise_on_missing_translations = true"
|
49
47
|
gsub_file "config/environments/test.rb",
|
@@ -21,21 +21,21 @@ describe '/_toolbar.html.erb', type: :view do
|
|
21
21
|
|
22
22
|
context 'with an admin user' do
|
23
23
|
before do
|
24
|
-
allow(view).to receive(:can?).with(:
|
24
|
+
allow(view).to receive(:can?).with(:read, :admin_dashboard).and_return(true)
|
25
25
|
end
|
26
26
|
|
27
27
|
it 'shows the admin menu' do
|
28
28
|
render
|
29
|
-
expect(rendered).to have_link 'Admin', sufia.
|
29
|
+
expect(rendered).to have_link 'Admin', href: sufia.admin_path
|
30
30
|
end
|
31
31
|
end
|
32
32
|
|
33
33
|
it 'has dashboard links' do
|
34
34
|
render
|
35
|
-
expect(rendered).to have_link 'My Dashboard', sufia.dashboard_index_path
|
36
|
-
expect(rendered).to have_link 'Transfers', sufia.transfers_path
|
37
|
-
expect(rendered).to have_link 'Highlights', sufia.dashboard_highlights_path
|
38
|
-
expect(rendered).to have_link 'Shares', sufia.dashboard_shares_path
|
35
|
+
expect(rendered).to have_link 'My Dashboard', href: sufia.dashboard_index_path
|
36
|
+
expect(rendered).to have_link 'Transfers', href: sufia.transfers_path
|
37
|
+
expect(rendered).to have_link 'Highlights', href: sufia.dashboard_highlights_path
|
38
|
+
expect(rendered).to have_link 'Shares', href: sufia.dashboard_shares_path
|
39
39
|
end
|
40
40
|
|
41
41
|
describe "New Work button" do
|
@@ -6,7 +6,10 @@ describe 'catalog/_index_list_default', type: :view do
|
|
6
6
|
'proxy_depositor_ssim' => [''],
|
7
7
|
'description_tesim' => [''],
|
8
8
|
'date_uploaded_dtsi' => 'a date',
|
9
|
-
'
|
9
|
+
'date_modified_dtsi' => 'a date',
|
10
|
+
'rights_tesim' => [''],
|
11
|
+
'embargo_release_date_dtsi' => 'a date',
|
12
|
+
'lease_expiration_date_dtsi' => 'a date' }
|
10
13
|
end
|
11
14
|
let(:document) { SolrDocument.new(attributes) }
|
12
15
|
let(:blacklight_configuration_context) do
|
@@ -29,11 +32,17 @@ describe 'catalog/_index_list_default', type: :view do
|
|
29
32
|
expect(rendered).to include 'Test description_tesim'
|
30
33
|
expect(rendered).to include '<span class="attribute-label h4">Date Uploaded:</span>'
|
31
34
|
expect(rendered).to include 'Test date_uploaded_dtsi'
|
35
|
+
expect(rendered).to include '<span class="attribute-label h4">Date Modified:</span>'
|
36
|
+
expect(rendered).to include 'Test date_modified_dtsi'
|
32
37
|
expect(rendered).to include '<span class="attribute-label h4">Depositor:</span>'
|
33
38
|
expect(rendered).to include 'Test proxy_depositor_ssim'
|
34
39
|
expect(rendered).to include '<span class="attribute-label h4">Owner:</span>'
|
35
40
|
expect(rendered).to include 'Test depositor_tesim'
|
36
41
|
expect(rendered).to include '<span class="attribute-label h4">Rights:</span>'
|
37
42
|
expect(rendered).to include 'Test rights_tesim'
|
43
|
+
expect(rendered).to include '<span class="attribute-label h4">Embargo release date:</span>'
|
44
|
+
expect(rendered).to include 'Test embargo_release_date_dtsi'
|
45
|
+
expect(rendered).to include '<span class="attribute-label h4">Lease expiration date:</span>'
|
46
|
+
expect(rendered).to include 'Test lease_expiration_date_dtsi'
|
38
47
|
end
|
39
48
|
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
describe 'catalog/_thumbnail_list_collection.html.erb', type: :view do
|
2
|
+
before do
|
3
|
+
stub_template 'catalog/_thumbnail_list_collection.html.erb' => '<div class="col-sm-3"><span class="fa fa-cubes collection-icon-search"></span></div>'
|
4
|
+
render
|
5
|
+
end
|
6
|
+
|
7
|
+
it 'displays the collection icon in the search results' do
|
8
|
+
expect(rendered).to match '<div class="col-sm-3"><span class="fa fa-cubes collection-icon-search"></span></div>'
|
9
|
+
end
|
10
|
+
end
|
@@ -3,7 +3,7 @@ describe 'citations/work.html.erb', type: :view do
|
|
3
3
|
let(:object_profile) { ["{\"id\":\"999\"}"] }
|
4
4
|
let(:contributor) { ['Gandalf Grey'] }
|
5
5
|
let(:creator) { ['Bilbo Baggins', 'Baggins, Frodo'] }
|
6
|
-
let(:solr_document)
|
6
|
+
let(:solr_document) do
|
7
7
|
SolrDocument.new(
|
8
8
|
id: '999',
|
9
9
|
object_profile_ssm: object_profile,
|
@@ -16,7 +16,7 @@ describe 'citations/work.html.erb', type: :view do
|
|
16
16
|
based_near_tesim: ['London'],
|
17
17
|
date_created_tesim: ['1969']
|
18
18
|
)
|
19
|
-
|
19
|
+
end
|
20
20
|
let(:ability) { nil }
|
21
21
|
let(:presenter) do
|
22
22
|
Sufia::WorkShowPresenter.new(solr_document, ability)
|
@@ -1,19 +1,19 @@
|
|
1
1
|
describe 'collections/_form_for_select_collection.html.erb', type: :view do
|
2
|
-
let(:collections)
|
2
|
+
let(:collections) do
|
3
3
|
[
|
4
4
|
build(:collection, id: '1234', create_date: Time.zone.parse('Thu, 13 Aug 2015 14:20:22 +0100')),
|
5
5
|
build(:collection, id: '1235', create_date: Time.zone.parse('Thu, 13 Aug 2015 14:18:22 +0100')),
|
6
6
|
build(:collection, id: '1236', create_date: Time.zone.parse('Thu, 13 Aug 2015 14:16:22 +0100')),
|
7
7
|
build(:collection, id: '1237', create_date: Time.zone.parse('Thu, 13 Aug 2015 14:29:22 +0100'))
|
8
8
|
]
|
9
|
-
|
10
|
-
let(:solr_collections)
|
9
|
+
end
|
10
|
+
let(:solr_collections) do
|
11
11
|
collections.map do |c|
|
12
12
|
SolrDocument.new(c.to_solr).tap do |sd|
|
13
13
|
sd['system_create_dtsi'] = c.create_date.to_s
|
14
14
|
end
|
15
15
|
end
|
16
|
-
|
16
|
+
end
|
17
17
|
|
18
18
|
let(:doc) { Nokogiri::HTML(rendered) }
|
19
19
|
|
@@ -23,6 +23,8 @@ describe 'collections/_form_for_select_collection.html.erb', type: :view do
|
|
23
23
|
render
|
24
24
|
collection_ids = doc.xpath("//input[@class='collection-selector']/@id").map(&:to_s)
|
25
25
|
expect(collection_ids).to eql(["id_1237", "id_1234", "id_1235", "id_1236"])
|
26
|
+
expect(rendered).to have_selector("label", text: collections.first.title.first)
|
27
|
+
expect(rendered).not_to have_selector("label", text: "[\"#{collections.first.title.first}\"]")
|
26
28
|
end
|
27
29
|
|
28
30
|
it "selects the right collection when instructed to do so" do
|
@@ -27,6 +27,7 @@ describe 'collections/_show_document_list.html.erb', type: :view do
|
|
27
27
|
it "renders collection" do
|
28
28
|
render(partial: 'collections/show_document_list.html.erb', locals: { documents: documents })
|
29
29
|
expect(rendered).to have_content 'One Hundred Years of Solitude'
|
30
|
+
expect(rendered).not_to have_content 'Action'
|
30
31
|
end
|
31
32
|
end
|
32
33
|
end
|
@@ -1,19 +1,30 @@
|
|
1
1
|
|
2
2
|
describe 'collections/_show_document_list_menu.html.erb', type: :view do
|
3
|
-
context 'when user
|
3
|
+
context 'when user is viewing a collection' do
|
4
4
|
let(:user) { create :user }
|
5
|
+
let(:ability) { instance_double("Ability") }
|
5
6
|
let(:document) { SolrDocument.new(id: '1234') }
|
6
7
|
before do
|
7
8
|
allow(document).to receive(:to_model).and_return(stub_model(GenericWork))
|
9
|
+
allow(controller).to receive(:current_ability).and_return(ability)
|
8
10
|
end
|
9
11
|
|
10
|
-
it "displays the action list in individual work
|
12
|
+
it "displays the action list in a drop down for an individual work the user can edit" do
|
13
|
+
allow(ability).to receive(:can?).with(:edit, document).and_return(true)
|
11
14
|
render('collections/show_document_list_menu.html.erb', document: document, current_user: user)
|
12
15
|
expect(rendered).to have_content 'Select an action'
|
13
|
-
expect(rendered).not_to have_content 'Single-Use Link to File'
|
14
16
|
expect(rendered).to have_content 'Edit'
|
15
17
|
expect(rendered).not_to have_content 'Download File'
|
16
18
|
expect(rendered).to have_content 'Highlight Work on Profile'
|
17
19
|
end
|
20
|
+
|
21
|
+
it "displays the action list in a drop down for an individual work the user cannot edit" do
|
22
|
+
allow(ability).to receive(:can?).with(:edit, document).and_return(false)
|
23
|
+
render('collections/show_document_list_menu.html.erb', document: document, current_user: user)
|
24
|
+
expect(rendered).to have_content 'Select an action'
|
25
|
+
expect(rendered).not_to have_content 'Edit'
|
26
|
+
expect(rendered).not_to have_content 'Download File'
|
27
|
+
expect(rendered).to have_content 'Highlight Work on Profile'
|
28
|
+
end
|
18
29
|
end
|
19
30
|
end
|
@@ -1,6 +1,9 @@
|
|
1
1
|
describe 'collections/show.html.erb', type: :view do
|
2
|
-
let(:document)
|
3
|
-
|
2
|
+
let(:document) do
|
3
|
+
SolrDocument.new(id: 'xyz123z4',
|
4
|
+
'title_tesim' => ['Make Collections Great Again'],
|
5
|
+
'rights_tesim' => ["http://creativecommons.org/licenses/by-sa/3.0/us/"])
|
6
|
+
end
|
4
7
|
let(:ability) { double }
|
5
8
|
let(:presenter) { Sufia::CollectionPresenter.new(document, ability) }
|
6
9
|
let(:blacklight_config) { CatalogController.blacklight_config }
|
@@ -20,6 +23,7 @@ describe 'collections/show.html.erb', type: :view do
|
|
20
23
|
stub_template 'collections/_sort_and_per_page.html.erb' => 'sort and per page'
|
21
24
|
stub_template 'collections/_document_list.html.erb' => 'document list'
|
22
25
|
stub_template 'collections/_paginate.html.erb' => 'paginate'
|
26
|
+
stub_template 'collections/_media_display.html.erb' => '<span class="fa fa-cubes collection-icon-search"></span>'
|
23
27
|
render
|
24
28
|
end
|
25
29
|
|
@@ -28,5 +32,6 @@ describe 'collections/show.html.erb', type: :view do
|
|
28
32
|
expect(rendered).to have_link 'Edit'
|
29
33
|
expect(rendered).to have_link 'Delete'
|
30
34
|
expect(rendered).to have_link 'Add works'
|
35
|
+
expect(rendered).to match '<span class="fa fa-cubes collection-icon-search"></span>'
|
31
36
|
end
|
32
37
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe 'curation_concerns/base/_attribute_rows.html.erb', type: :view do
|
4
|
+
let(:url) { "http://example.com" }
|
5
|
+
let(:ability) { double }
|
6
|
+
let(:work) { stub_model(GenericWork, related_url: [url]) }
|
7
|
+
let(:solr_document) { SolrDocument.new(work.to_solr) }
|
8
|
+
let(:presenter) { Sufia::WorkShowPresenter.new(solr_document, ability) }
|
9
|
+
|
10
|
+
let(:page) do
|
11
|
+
render 'curation_concerns/base/attribute_rows', presenter: presenter
|
12
|
+
Capybara::Node::Simple.new(rendered)
|
13
|
+
end
|
14
|
+
|
15
|
+
it 'shows external link with icon for related url field' do
|
16
|
+
expect(page).to have_selector '.glyphicon-new-window'
|
17
|
+
expect(page).to have_link(url)
|
18
|
+
end
|
19
|
+
end
|
@@ -5,7 +5,7 @@ describe 'curation_concerns/base/_citations.html.erb', type: :view do
|
|
5
5
|
let(:object_profile) { ["{\"id\":\"999\"}"] }
|
6
6
|
let(:contributor) { ['Frodo'] }
|
7
7
|
let(:creator) { ['Bilbo'] }
|
8
|
-
let(:solr_document)
|
8
|
+
let(:solr_document) do
|
9
9
|
SolrDocument.new(
|
10
10
|
id: '999',
|
11
11
|
object_profile_ssm: object_profile,
|
@@ -15,7 +15,7 @@ describe 'curation_concerns/base/_citations.html.erb', type: :view do
|
|
15
15
|
creator_tesim: creator,
|
16
16
|
rights_tesim: ['http://creativecommons.org/licenses/by/3.0/us/']
|
17
17
|
)
|
18
|
-
|
18
|
+
end
|
19
19
|
let(:ability) { Ability.new(user) }
|
20
20
|
let(:presenter) do
|
21
21
|
Sufia::WorkShowPresenter.new(solr_document, ability)
|
@@ -16,6 +16,8 @@ describe 'curation_concerns/base/_form.html.erb', type: :view do
|
|
16
16
|
assign(:form, form)
|
17
17
|
allow(controller).to receive(:controller_name).and_return('batch_uploads')
|
18
18
|
allow(controller).to receive(:action_name).and_return('new')
|
19
|
+
allow(controller).to receive(:repository).and_return(CurationConcerns::GenericWorksController.new.repository)
|
20
|
+
allow(controller).to receive(:blacklight_config).and_return(CurationConcerns::GenericWorksController.new.blacklight_config)
|
19
21
|
end
|
20
22
|
|
21
23
|
let(:page) do
|
@@ -0,0 +1,48 @@
|
|
1
|
+
describe 'curation_concerns/base/_form_relationships.html.erb', type: :view do
|
2
|
+
let(:ability) { double }
|
3
|
+
let(:work) { GenericWork.new }
|
4
|
+
let(:form) do
|
5
|
+
CurationConcerns::GenericWorkForm.new(work, ability)
|
6
|
+
end
|
7
|
+
let(:service) { instance_double CurationConcerns::AdminSetService, select_options: [] }
|
8
|
+
|
9
|
+
before do
|
10
|
+
allow(view).to receive(:available_collections).and_return([])
|
11
|
+
allow(view).to receive(:action_name).and_return('new')
|
12
|
+
allow(CurationConcerns::AdminSetService).to receive(:new).with(controller).and_return(service)
|
13
|
+
end
|
14
|
+
|
15
|
+
let(:form_template) do
|
16
|
+
%(
|
17
|
+
<%= simple_form_for [main_app, @form] do |f| %>
|
18
|
+
<%= render "curation_concerns/base/form_relationships", f: f %>
|
19
|
+
<% end %>
|
20
|
+
)
|
21
|
+
end
|
22
|
+
|
23
|
+
let(:page) do
|
24
|
+
assign(:form, form)
|
25
|
+
render inline: form_template
|
26
|
+
Capybara::Node::Simple.new(rendered)
|
27
|
+
end
|
28
|
+
|
29
|
+
context 'with assign_admin_set turned on' do
|
30
|
+
before do
|
31
|
+
allow(Flipflop).to receive(:assign_admin_set?).and_return(true)
|
32
|
+
end
|
33
|
+
|
34
|
+
it "draws the page" do
|
35
|
+
expect(page).to have_content('Add as member of administrative set')
|
36
|
+
expect(page).to have_selector('select#generic_work_admin_set_id')
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
context 'with assign_admin_set disabled' do
|
41
|
+
before do
|
42
|
+
allow(Flipflop).to receive(:assign_admin_set?).and_return(false)
|
43
|
+
end
|
44
|
+
it 'draws the page, but not the admin set widget' do
|
45
|
+
expect(page).not_to have_content('administrative set')
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|