blacklight-spotlight 0.4.1 → 0.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (367) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +22 -8
  3. data/Rakefile +40 -39
  4. data/app/assets/javascripts/spotlight/blacklight_configuration.js +16 -0
  5. data/app/assets/javascripts/spotlight/blocks/resources_block.js +3 -1
  6. data/app/assets/stylesheets/spotlight/_blacklight_configuration.scss +2 -2
  7. data/app/assets/stylesheets/spotlight/_blacklight_overrides.scss +24 -0
  8. data/app/assets/stylesheets/spotlight/_header.scss +150 -47
  9. data/app/assets/stylesheets/spotlight/_pages.scss +62 -11
  10. data/app/assets/stylesheets/spotlight/_report_a_problem.scss +1 -0
  11. data/app/assets/stylesheets/spotlight/_spotlight.scss +1 -0
  12. data/app/builders/spotlight/bootstrap_breadcrumbs_builder.rb +28 -21
  13. data/app/controllers/spotlight/about_pages_controller.rb +25 -14
  14. data/app/controllers/spotlight/appearances_controller.rb +34 -30
  15. data/app/controllers/spotlight/application_controller.rb +2 -1
  16. data/app/controllers/spotlight/attachments_controller.rb +9 -7
  17. data/app/controllers/spotlight/browse_controller.rb +13 -9
  18. data/app/controllers/spotlight/catalog_controller.rb +179 -161
  19. data/app/controllers/spotlight/concerns/application_controller.rb +22 -20
  20. data/app/controllers/spotlight/concerns/catalog_search_context.rb +44 -0
  21. data/app/controllers/spotlight/confirmations_controller.rb +5 -2
  22. data/app/controllers/spotlight/contact_forms_controller.rb +13 -7
  23. data/app/controllers/spotlight/contacts_controller.rb +13 -4
  24. data/app/controllers/spotlight/custom_fields_controller.rb +48 -40
  25. data/app/controllers/spotlight/dashboards_controller.rb +17 -8
  26. data/app/controllers/spotlight/default_controller.rb +3 -1
  27. data/app/controllers/spotlight/exhibits_controller.rb +69 -62
  28. data/app/controllers/spotlight/feature_pages_controller.rb +21 -11
  29. data/app/controllers/spotlight/home_pages_controller.rb +6 -5
  30. data/app/controllers/spotlight/lock_controller.rb +3 -1
  31. data/app/controllers/spotlight/metadata_configurations_controller.rb +49 -0
  32. data/app/controllers/spotlight/pages_controller.rb +28 -18
  33. data/app/controllers/spotlight/resources/upload_controller.rb +53 -46
  34. data/app/controllers/spotlight/resources_controller.rb +9 -5
  35. data/app/controllers/spotlight/roles_controller.rb +26 -22
  36. data/app/controllers/spotlight/search_configurations_controller.rb +66 -0
  37. data/app/controllers/spotlight/searches_controller.rb +91 -82
  38. data/app/controllers/spotlight/solr_controller.rb +20 -13
  39. data/app/controllers/spotlight/tags_controller.rb +5 -3
  40. data/app/controllers/spotlight/versions_controller.rb +15 -12
  41. data/app/controllers/spotlight/view_configurations_controller.rb +17 -0
  42. data/app/helpers/spotlight/application_helper.rb +44 -32
  43. data/app/helpers/spotlight/browse_helper.rb +13 -1
  44. data/app/helpers/spotlight/crud_link_helpers.rb +22 -14
  45. data/app/helpers/spotlight/jcrop_helper.rb +4 -2
  46. data/app/helpers/spotlight/main_app_helpers.rb +45 -41
  47. data/app/helpers/spotlight/navbar_helper.rb +6 -0
  48. data/app/helpers/spotlight/pages_helper.rb +23 -15
  49. data/app/helpers/spotlight/roles_helper.rb +10 -4
  50. data/app/helpers/spotlight/search_configurations_helper.rb +22 -0
  51. data/app/helpers/spotlight/title_helper.rb +16 -13
  52. data/app/jobs/spotlight/add_uploads_from_csv.rb +13 -9
  53. data/app/jobs/spotlight/reindex_job.rb +9 -9
  54. data/app/jobs/spotlight/rename_sidecar_field_job.rb +3 -0
  55. data/app/mailers/spotlight/confirmation_mailer.rb +2 -0
  56. data/app/mailers/spotlight/indexing_complete_mailer.rb +4 -2
  57. data/app/models/ability.rb +3 -0
  58. data/app/models/concerns/spotlight/ar_light.rb +49 -25
  59. data/app/models/concerns/spotlight/blacklight_configuration_defaults.rb +25 -10
  60. data/app/models/concerns/spotlight/exhibit_analytics.rb +28 -0
  61. data/app/models/concerns/spotlight/image_derivatives.rb +25 -26
  62. data/app/models/concerns/spotlight/resources/open_graph.rb +23 -19
  63. data/app/models/concerns/spotlight/resources/web.rb +25 -24
  64. data/app/models/concerns/spotlight/solr_document.rb +40 -34
  65. data/app/models/concerns/spotlight/solr_document/active_model_concern.rb +29 -40
  66. data/app/models/concerns/spotlight/solr_document/atomic_updates.rb +22 -18
  67. data/app/models/concerns/spotlight/solr_document/finder.rb +23 -18
  68. data/app/models/concerns/spotlight/solr_document/spotlight_images.rb +43 -39
  69. data/app/models/concerns/spotlight/solr_document/uploaded_resource.rb +41 -29
  70. data/app/models/concerns/spotlight/user.rb +25 -19
  71. data/app/models/sir_trevor_rails/blocks/browse_block.rb +36 -30
  72. data/app/models/sir_trevor_rails/blocks/featured_pages_block.rb +24 -18
  73. data/app/models/sir_trevor_rails/blocks/oembed_block.rb +8 -4
  74. data/app/models/sir_trevor_rails/blocks/search_results_block.rb +29 -23
  75. data/app/models/sir_trevor_rails/blocks/solr_documents_block.rb +43 -42
  76. data/app/models/sir_trevor_rails/blocks/solr_documents_carousel_block.rb +16 -12
  77. data/app/models/sir_trevor_rails/blocks/solr_documents_embed_block.rb +7 -3
  78. data/app/models/sir_trevor_rails/blocks/solr_documents_features_block.rb +7 -3
  79. data/app/models/sir_trevor_rails/blocks/solr_documents_grid_block.rb +7 -3
  80. data/app/models/sir_trevor_rails/blocks/textable.rb +18 -18
  81. data/app/models/spotlight/ability.rb +32 -33
  82. data/app/models/spotlight/about_page.rb +3 -1
  83. data/app/models/spotlight/analytics/ga.rb +46 -27
  84. data/app/models/spotlight/attachment.rb +3 -1
  85. data/app/models/spotlight/blacklight_configuration.rb +146 -68
  86. data/app/models/spotlight/contact.rb +35 -30
  87. data/app/models/spotlight/contact_email.rb +6 -3
  88. data/app/models/spotlight/contact_form.rb +4 -3
  89. data/app/models/spotlight/custom_field.rb +41 -33
  90. data/app/models/spotlight/exhibit.rb +104 -130
  91. data/app/models/spotlight/feature_page.rb +9 -7
  92. data/app/models/spotlight/featured_image.rb +10 -10
  93. data/app/models/spotlight/field_metadata.rb +46 -0
  94. data/app/models/spotlight/home_page.rb +8 -5
  95. data/app/models/spotlight/lock.rb +4 -3
  96. data/app/models/spotlight/main_navigation.rb +9 -3
  97. data/app/models/spotlight/masthead.rb +17 -16
  98. data/app/models/spotlight/page.rb +16 -16
  99. data/app/models/spotlight/resource.rb +69 -22
  100. data/app/models/spotlight/resources/csv_upload.rb +8 -4
  101. data/app/models/spotlight/resources/upload.rb +68 -57
  102. data/app/models/spotlight/role.rb +30 -34
  103. data/app/models/spotlight/search.rb +74 -63
  104. data/app/models/spotlight/solr_document_sidecar.rb +17 -15
  105. data/app/serializers/spotlight/exhibit_export_serializer.rb +65 -29
  106. data/app/serializers/spotlight/page_representer.rb +10 -6
  107. data/app/uploaders/spotlight/attachment_uploader.rb +4 -6
  108. data/app/uploaders/spotlight/avatar_uploader.rb +4 -3
  109. data/app/uploaders/spotlight/featured_image_uploader.rb +15 -14
  110. data/app/uploaders/spotlight/item_uploader.rb +3 -1
  111. data/app/uploaders/spotlight/masthead_uploader.rb +4 -2
  112. data/app/views/catalog/_search_form.html.erb +24 -0
  113. data/app/views/shared/_browse_navbar.html.erb +1 -1
  114. data/app/views/shared/_exhibit_navbar.html.erb +1 -1
  115. data/app/views/spotlight/appearances/edit.html.erb +13 -45
  116. data/app/views/spotlight/catalog/_edit_default.html.erb +1 -1
  117. data/app/views/spotlight/custom_fields/_form.html.erb +1 -1
  118. data/app/views/spotlight/exhibits/edit.html.erb +4 -4
  119. data/app/views/spotlight/home_pages/_empty.html.erb +1 -3
  120. data/app/views/spotlight/home_pages/_page_options.html.erb +1 -1
  121. data/app/views/spotlight/{blacklight_configurations → metadata_configurations}/_metadata_field.html.erb +0 -0
  122. data/app/views/spotlight/{blacklight_configurations/edit_metadata_fields.html.erb → metadata_configurations/edit.html.erb} +1 -1
  123. data/app/views/spotlight/pages/show.html.erb +2 -2
  124. data/app/views/spotlight/search_configurations/_default_per_page.html.erb +5 -0
  125. data/app/views/spotlight/search_configurations/_document_index_view_types.html.erb +7 -0
  126. data/app/views/spotlight/search_configurations/_facets.html.erb +38 -0
  127. data/app/views/spotlight/search_configurations/_search_fields.html.erb +58 -0
  128. data/app/views/spotlight/search_configurations/_sort.html.erb +53 -0
  129. data/app/views/spotlight/search_configurations/edit.html.erb +46 -0
  130. data/app/views/spotlight/searches/_search.html.erb +1 -1
  131. data/app/views/spotlight/shared/_admin_sidebar.html.erb +0 -2
  132. data/app/views/spotlight/shared/_curation_sidebar.html.erb +2 -3
  133. data/app/views/spotlight/shared/_report_a_problem.html.erb +2 -2
  134. data/app/views/spotlight/sir_trevor/blocks/_oembed_block.html.erb +5 -1
  135. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb +7 -5
  136. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb +2 -2
  137. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_embed_block.html.erb +7 -5
  138. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb +2 -2
  139. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_grid_block.html.erb +14 -9
  140. data/config/locales/spotlight.en.yml +94 -49
  141. data/config/routes.rb +11 -20
  142. data/db/migrate/20150410180014_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +15 -0
  143. data/db/migrate/20150410180015_add_missing_taggable_index.acts_as_taggable_on_engine.rb +10 -0
  144. data/db/migrate/20150410180016_change_collation_for_tag_names.acts_as_taggable_on_engine.rb +10 -0
  145. data/db/migrate/20150713160101_change_spotlight_searches_to_published.rb +5 -0
  146. data/db/migrate/20151016092343_remove_searchable_from_exhibit.rb +20 -0
  147. data/lib/blacklight/spotlight.rb +1 -1
  148. data/lib/generators/spotlight/install_generator.rb +27 -25
  149. data/lib/generators/spotlight/templates/catalog_controller.rb +7 -5
  150. data/lib/generators/spotlight/templates/jetty.rake +8 -2
  151. data/lib/generators/spotlight/templates/spotlight_helper.rb +3 -1
  152. data/lib/spotlight.rb +4 -2
  153. data/lib/spotlight/base.rb +21 -14
  154. data/lib/spotlight/catalog.rb +10 -9
  155. data/lib/spotlight/catalog/access_controls_enforcement.rb +30 -15
  156. data/lib/spotlight/config.rb +4 -2
  157. data/lib/spotlight/controller.rb +12 -11
  158. data/lib/spotlight/engine.rb +30 -22
  159. data/lib/spotlight/rails/routes.rb +7 -4
  160. data/lib/spotlight/version.rb +2 -1
  161. data/lib/tasks/spotlight_tasks.rake +56 -50
  162. data/spec/controllers/application_controller_spec.rb +13 -13
  163. data/spec/controllers/spotlight/about_pages_controller_spec.rb +63 -59
  164. data/spec/controllers/spotlight/appearances_controller_spec.rb +29 -24
  165. data/spec/controllers/spotlight/application_controller_spec.rb +3 -3
  166. data/spec/controllers/spotlight/attachments_controller_spec.rb +10 -10
  167. data/spec/controllers/spotlight/browse_controller_spec.rb +23 -25
  168. data/spec/controllers/spotlight/catalog_controller_spec.rb +82 -87
  169. data/spec/controllers/spotlight/confirmations_controller_spec.rb +13 -11
  170. data/spec/controllers/spotlight/contact_forms_controller_spec.rb +17 -12
  171. data/spec/controllers/spotlight/contacts_controller_spec.rb +36 -36
  172. data/spec/controllers/spotlight/custom_fields_controller_spec.rb +26 -26
  173. data/spec/controllers/spotlight/dashboards_controller_spec.rb +14 -14
  174. data/spec/controllers/spotlight/exhibits_controller_spec.rb +59 -54
  175. data/spec/controllers/spotlight/feature_pages_controller_spec.rb +59 -59
  176. data/spec/controllers/spotlight/home_pages_controller_spec.rb +28 -29
  177. data/spec/controllers/spotlight/metadata_configurations_controller_spec.rb +84 -0
  178. data/spec/controllers/spotlight/resources/upload_controller_spec.rb +42 -33
  179. data/spec/controllers/spotlight/resources_controller_spec.rb +25 -29
  180. data/spec/controllers/spotlight/roles_controller_spec.rb +37 -19
  181. data/spec/controllers/spotlight/search_configurations_controller_spec.rb +125 -0
  182. data/spec/controllers/spotlight/searches_controller_spec.rb +84 -63
  183. data/spec/controllers/spotlight/solr_controller_spec.rb +13 -14
  184. data/spec/controllers/spotlight/tags_controller_spec.rb +16 -16
  185. data/spec/controllers/spotlight/versions_controller_spec.rb +15 -18
  186. data/spec/controllers/spotlight/view_configurations_controller_spec.rb +31 -0
  187. data/spec/factories/contacts.rb +1 -3
  188. data/spec/factories/custom_fields.rb +2 -4
  189. data/spec/factories/exhibits.rb +4 -2
  190. data/spec/factories/pages.rb +8 -11
  191. data/spec/factories/resources.rb +4 -4
  192. data/spec/factories/searches.rb +10 -13
  193. data/spec/factories/tags.rb +0 -3
  194. data/spec/factories/users.rb +2 -4
  195. data/spec/features/about_page_spec.rb +19 -19
  196. data/spec/features/add_contacts_spec.rb +34 -34
  197. data/spec/features/add_custom_field_metadata_spec.rb +24 -26
  198. data/spec/features/add_item_bookmarklet_spec.rb +12 -12
  199. data/spec/features/browse_category_admin_spec.rb +39 -39
  200. data/spec/features/catalog_spec.rb +9 -10
  201. data/spec/features/confirm_email_spec.rb +10 -10
  202. data/spec/features/create_exhibit_spec.rb +18 -15
  203. data/spec/features/create_page_spec.rb +8 -8
  204. data/spec/features/curator_items.rb +3 -3
  205. data/spec/features/dashboard_spec.rb +15 -16
  206. data/spec/features/edit_contact_spec.rb +8 -10
  207. data/spec/features/edit_search_fields_spec.rb +79 -0
  208. data/spec/features/exhibits/add_tags_spec.rb +15 -16
  209. data/spec/features/exhibits/administration_spec.rb +25 -25
  210. data/spec/features/exhibits/custom_metadata_fields_spec.rb +41 -43
  211. data/spec/features/exhibits/edit_metadata_fields_spec.rb +19 -19
  212. data/spec/features/feature_page_spec.rb +49 -48
  213. data/spec/features/home_page_spec.rb +38 -38
  214. data/spec/features/import_exhibit_spec.rb +23 -20
  215. data/spec/features/item_admin_spec.rb +28 -29
  216. data/spec/features/javascript/about_page_admin_spec.rb +9 -9
  217. data/spec/features/javascript/block_controls_spec.rb +16 -18
  218. data/spec/features/javascript/blocks/featured_browse_categories_block_spec.rb +11 -12
  219. data/spec/features/javascript/blocks/featured_pages_block_spec.rb +12 -13
  220. data/spec/features/javascript/blocks/search_result_block_spec.rb +17 -17
  221. data/spec/features/javascript/blocks/solr_documents_block_spec.rb +67 -65
  222. data/spec/features/javascript/edit_in_place_spec.rb +30 -56
  223. data/spec/features/javascript/feature_page_admin_spec.rb +73 -59
  224. data/spec/features/javascript/home_page_edit_spec.rb +6 -6
  225. data/spec/features/javascript/metadata_admin_spec.rb +15 -15
  226. data/spec/features/javascript/multi_image_select_spec.rb +17 -18
  227. data/spec/features/javascript/preview_block_spec.rb +11 -12
  228. data/spec/features/javascript/rule_block_spec.rb +7 -7
  229. data/spec/features/javascript/search_config_admin_spec.rb +144 -0
  230. data/spec/features/javascript/search_context_spec.rb +41 -42
  231. data/spec/features/main_navigation_spec.rb +22 -22
  232. data/spec/features/metadata_admin_spec.rb +8 -8
  233. data/spec/features/multiple_exhibits_spec.rb +15 -17
  234. data/spec/features/report_a_problem_spec.rb +23 -17
  235. data/spec/features/site_masthead_spec.rb +46 -46
  236. data/spec/features/slideshow_spec.rb +8 -9
  237. data/spec/features/tags_admin_spec.rb +11 -11
  238. data/spec/features/upload_non_repository_item_spec.rb +32 -32
  239. data/spec/features/user_admin_spec.rb +7 -7
  240. data/spec/helpers/spotlight/application_helper_spec.rb +63 -56
  241. data/spec/helpers/spotlight/browse_helper_spec.rb +6 -6
  242. data/spec/helpers/spotlight/crud_link_helpers_spec.rb +58 -52
  243. data/spec/helpers/spotlight/main_app_helpers_spec.rb +44 -24
  244. data/spec/helpers/spotlight/navbar_helper_spec.rb +4 -4
  245. data/spec/helpers/spotlight/pages_helper_spec.rb +56 -37
  246. data/spec/helpers/spotlight/roles_helper_spec.rb +3 -3
  247. data/spec/helpers/spotlight/search_configurations_helper_spec.rb +24 -0
  248. data/spec/helpers/spotlight/title_helper_spec.rb +33 -35
  249. data/spec/jobs/spotlight/reindex_job_spec.rb +6 -6
  250. data/spec/jobs/spotlight/rename_sidecar_field_job_spec.rb +7 -7
  251. data/spec/lib/spotlight/catalog/access_controls_enforcement_spec.rb +41 -26
  252. data/spec/lib/spotlight/controller_spec.rb +10 -10
  253. data/spec/lib/spotlight/routes_spec.rb +4 -4
  254. data/spec/mailers/spotlight/indexing_complete_mailer_spec.rb +13 -13
  255. data/spec/models/sir_trevor_rails/blocks/solr_documents_block_spec.rb +8 -8
  256. data/spec/models/{spotlight/sir_trevor_blocks → sir_trevor_rails/blocks}/textable_spec.rb +7 -8
  257. data/spec/models/solr_document_spec.rb +49 -50
  258. data/spec/models/spotlight/ability_spec.rb +17 -20
  259. data/spec/models/spotlight/about_page_spec.rb +6 -6
  260. data/spec/models/spotlight/analytics/ga_spec.rb +2 -2
  261. data/spec/models/spotlight/blacklight_configuration_spec.rb +196 -133
  262. data/spec/models/spotlight/contact_email_spec.rb +28 -24
  263. data/spec/models/spotlight/contact_spec.rb +6 -7
  264. data/spec/models/spotlight/custom_field_spec.rb +51 -52
  265. data/spec/models/spotlight/exhibit_spec.rb +102 -60
  266. data/spec/models/spotlight/feature_page_spec.rb +32 -32
  267. data/spec/models/spotlight/featured_image_spec.rb +5 -5
  268. data/spec/models/spotlight/field_metadata_spec.rb +78 -0
  269. data/spec/models/spotlight/home_page_spec.rb +11 -20
  270. data/spec/models/spotlight/{spotlight_image_derivatives_spec.rb → image_derivatives_spec.rb} +2 -2
  271. data/spec/models/spotlight/main_navigation_spec.rb +7 -9
  272. data/spec/models/spotlight/masthead_spec.rb +6 -6
  273. data/spec/models/spotlight/page_spec.rb +26 -29
  274. data/spec/models/spotlight/resource_spec.rb +56 -26
  275. data/spec/models/spotlight/resources/open_graph_spec.rb +16 -18
  276. data/spec/models/spotlight/resources/upload_spec.rb +32 -35
  277. data/spec/models/spotlight/resources/web_spec.rb +9 -11
  278. data/spec/models/spotlight/role_spec.rb +20 -20
  279. data/spec/models/spotlight/search_spec.rb +32 -15
  280. data/spec/models/spotlight/solr_document/atomic_updates_spec.rb +34 -0
  281. data/spec/models/spotlight/{solr_document_images_spec.rb → solr_document/spotlight_images_spec.rb} +18 -10
  282. data/spec/models/spotlight/solr_document/uploaded_resource_spec.rb +52 -0
  283. data/spec/models/spotlight/solr_document_sidecar_spec.rb +3 -4
  284. data/spec/routing/spotlight/exhibit_catalog_spec.rb +5 -5
  285. data/spec/routing/spotlight/pages_routing_spec.rb +24 -25
  286. data/spec/serializers/spotlight/exhibit_export_serializer_spec.rb +88 -68
  287. data/spec/spec_helper.rb +13 -22
  288. data/spec/support/features/test_features_helpers.rb +50 -46
  289. data/spec/support/views/test_view_helpers.rb +1 -1
  290. data/spec/test_app_templates/Gemfile.extra +0 -1
  291. data/spec/test_app_templates/carrierwave.rb +2 -2
  292. data/spec/test_app_templates/catalog_controller.rb +42 -42
  293. data/spec/test_app_templates/lib/generators/test_app_generator.rb +20 -11
  294. data/spec/test_app_templates/spotlight_test.rake +3 -3
  295. data/spec/uploaders/spotlight/item_uploader_spec.rb +68 -0
  296. data/spec/views/_user_util_links.html.erb_spec.rb +14 -14
  297. data/spec/views/shared/_analytics.html.erb_spec.rb +4 -6
  298. data/spec/views/shared/_exhibit_masthead.html.erb_spec.rb +19 -20
  299. data/spec/views/shared/_exhibit_navbar.html.erb_spec.rb +129 -131
  300. data/spec/views/shared/_footer.html.erb_spec.rb +6 -7
  301. data/spec/views/shared/_header_navbar.html.erb_spec.rb +5 -5
  302. data/spec/views/spotlight/about_pages/_empty.html.erb_spec.rb +4 -4
  303. data/spec/views/spotlight/about_pages/_sidebar.html.erb_spec.rb +9 -11
  304. data/spec/views/spotlight/about_pages/index.html.erb_spec.rb +31 -28
  305. data/spec/views/spotlight/browse/_search.html.erb_spec.rb +6 -6
  306. data/spec/views/spotlight/browse/_sort_and_per_page.html.erb_spec.rb +10 -12
  307. data/spec/views/spotlight/browse/index.html.erb_spec.rb +6 -6
  308. data/spec/views/spotlight/browse/show.html.erb_spec.rb +19 -20
  309. data/spec/views/spotlight/catalog/_edit_default.html.erb_spec.rb +7 -7
  310. data/spec/views/spotlight/catalog/admin.html.erb_spec.rb +7 -7
  311. data/spec/views/spotlight/catalog/edit.html.erb_spec.rb +3 -6
  312. data/spec/views/spotlight/catalog/new.html.erb_spec.rb +8 -10
  313. data/spec/views/spotlight/contacts/edit.html.erb_spec.rb +8 -8
  314. data/spec/views/spotlight/dashboards/_analytics.html.erb_spec.rb +22 -22
  315. data/spec/views/spotlight/exhibits/edit.html.erb_spec.rb +7 -8
  316. data/spec/views/spotlight/feature_pages/_empty.html.erb_spec.rb +5 -5
  317. data/spec/views/spotlight/feature_pages/_sidebar.html.erb_spec.rb +24 -26
  318. data/spec/views/spotlight/home_pages/_empty.html.erb_spec.rb +13 -9
  319. data/spec/views/spotlight/home_pages/_sidebar.html.erb_spec.rb +6 -6
  320. data/spec/views/spotlight/metadata_configurations/_metadata_field.html.erb_spec.rb +26 -0
  321. data/spec/views/spotlight/metadata_configurations/edit.html.erb_spec.rb +22 -0
  322. data/spec/views/spotlight/pages/edit.html.erb_spec.rb +16 -16
  323. data/spec/views/spotlight/pages/index.html.erb_spec.rb +19 -17
  324. data/spec/views/spotlight/pages/new.html.erb_spec.rb +6 -6
  325. data/spec/views/spotlight/pages/show.html.erb_spec.rb +27 -28
  326. data/spec/views/spotlight/roles/index.html.erb_spec.rb +6 -6
  327. data/spec/views/spotlight/search_configurations/_search_fields.html.erb_spec.rb +54 -0
  328. data/spec/views/spotlight/search_configurations/_sort.html.erb_spec.rb +28 -0
  329. data/spec/views/spotlight/searches/_search.html.erb_spec.rb +20 -10
  330. data/spec/views/spotlight/searches/edit.html.erb_spec.rb +12 -11
  331. data/spec/views/spotlight/searches/index.html.erb_spec.rb +12 -7
  332. data/spec/views/spotlight/sir_trevor/blocks/_iframe_block.html.erb_spec.rb +7 -8
  333. data/spec/views/spotlight/sir_trevor/blocks/_rule_block.html.erb_spec.rb +4 -4
  334. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb_spec.rb +38 -0
  335. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb_spec.rb +7 -8
  336. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_embed_block.html.erb_spec.rb +18 -13
  337. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb_spec.rb +14 -12
  338. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_grid_block.html.erb_spec.rb +11 -12
  339. data/spec/views/spotlight/tags/index.html.erb_spec.rb +9 -9
  340. metadata +167 -83
  341. data/app/controllers/spotlight/blacklight_configurations_controller.rb +0 -101
  342. data/app/controllers/spotlight/resources/csv_controller.rb +0 -23
  343. data/app/forms/spotlight/appearance.rb +0 -86
  344. data/app/helpers/spotlight/attachments_helper.rb +0 -4
  345. data/app/helpers/spotlight/blacklight_configurations_helper.rb +0 -15
  346. data/app/jobs/spotlight/set_default_thumbnail_job.rb +0 -16
  347. data/app/models/spotlight/resources/csv.rb +0 -80
  348. data/app/uploaders/spotlight/csv_uploader.rb +0 -15
  349. data/app/views/spotlight/blacklight_configurations/edit_facet_fields.html.erb +0 -47
  350. data/app/views/spotlight/blacklight_configurations/edit_sort_fields.html.erb +0 -65
  351. data/app/views/spotlight/resources/csv/_form.html.erb +0 -17
  352. data/app/views/spotlight/resources/csv/new.html.erb +0 -3
  353. data/spec/controllers/spotlight/blacklight_configurations_controller_spec.rb +0 -167
  354. data/spec/features/edit_sort_fields_spec.rb +0 -42
  355. data/spec/features/exhibits/edit_facet_fields_spec.rb +0 -37
  356. data/spec/features/javascript/facet_admin_spec.rb +0 -36
  357. data/spec/features/search_facets_admin_spec.rb +0 -19
  358. data/spec/features/update_appearance_spec.rb +0 -58
  359. data/spec/helpers/spotlight/blacklight_configurations_helper_spec.rb +0 -12
  360. data/spec/models/spotlight/appearance_spec.rb +0 -33
  361. data/spec/models/spotlight/resources/csv_spec.rb +0 -101
  362. data/spec/models/spotlight/solr_document_atomic_updates_spec.rb +0 -29
  363. data/spec/models/spotlight/solr_document_uploaded_resource_spec.rb +0 -45
  364. data/spec/uploaders/item_uploader_spec.rb +0 -62
  365. data/spec/views/spotlight/blacklight_configuration/_metadata_field.html.erb_spec.rb +0 -27
  366. data/spec/views/spotlight/blacklight_configuration/edit_metadata_fields.html.erb_spec.rb +0 -23
  367. data/spec/views/spotlight/blacklight_configuration/edit_sort_fields.html.erb_spec.rb +0 -19
@@ -1,66 +1,96 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Resource, :type => :model do
3
+ describe Spotlight::Resource, type: :model do
4
4
  before do
5
- allow_any_instance_of(Spotlight::Resource).to receive(:update_index)
5
+ allow_any_instance_of(described_class).to receive(:update_index)
6
6
  end
7
- let(:exhibit) { double(solr_data: { }) }
8
-
9
- describe ".class_for_resource" do
7
+ let(:exhibit) { FactoryGirl.create(:exhibit) }
8
+
9
+ describe '.class_for_resource' do
10
10
  let(:thing) { double }
11
- let(:type_a) { double("TypeA", weight: 10) }
12
- let(:type_b) { double("TypeB", weight: 5) }
11
+ let(:type_a) { double('TypeA', weight: 10) }
12
+ let(:type_b) { double('TypeB', weight: 5) }
13
13
  let(:providers) { [type_a, type_b] }
14
- subject { Spotlight::Resource.class_for_resource(thing) }
14
+ subject { described_class.class_for_resource(thing) }
15
15
 
16
16
  before do
17
- allow(Spotlight::Resource).to receive_messages(providers: providers)
17
+ allow(described_class).to receive_messages(providers: providers)
18
18
  end
19
19
 
20
- it "should return a class that can provide indexing for the resource" do
20
+ it 'returns a class that can provide indexing for the resource' do
21
21
  expect(type_a).to receive(:can_provide?).with(thing).and_return(true)
22
22
  expect(type_b).to receive(:can_provide?).with(thing).and_return(false)
23
23
  expect(subject).to eq type_a
24
24
  end
25
25
 
26
- it "should return the lowest weighted class that can provide indexing for the resource" do
26
+ it 'returns the lowest weighted class that can provide indexing for the resource' do
27
27
  expect(type_a).to receive(:can_provide?).with(thing).and_return(true)
28
28
  expect(type_b).to receive(:can_provide?).with(thing).and_return(true)
29
29
  expect(subject).to eq type_b
30
30
  end
31
31
  end
32
32
 
33
- describe "#to_solr" do
33
+ describe '#to_solr' do
34
34
  before do
35
35
  allow(subject).to receive(:exhibit).and_return(exhibit)
36
- allow(subject).to receive_messages(type: "Spotlight::Resource::Something", id: 15)
36
+ allow(subject).to receive_messages(type: 'Spotlight::Resource::Something', id: 15, persisted?: true)
37
37
  end
38
- it "should include a reference to the resource" do
38
+ it 'includes a reference to the resource' do
39
39
  expect(subject.to_solr).to include spotlight_resource_id_ssim: subject.to_global_id.to_s
40
40
  end
41
41
 
42
- it "should include exhibit-specific data" do
42
+ it 'includes exhibit-specific data' do
43
43
  allow(exhibit).to receive(:solr_data).and_return(exhibit_data: true)
44
44
  expect(subject.to_solr).to include exhibit_data: true
45
45
  end
46
46
  end
47
47
 
48
- describe "#becomes_provider" do
49
- it "should convert the resource to a provider-specific resource" do
50
- SomeClass = Class.new(Spotlight::Resource)
51
- allow(Spotlight::Resource).to receive_messages(class_for_resource: SomeClass)
48
+ describe '#reindex' do
49
+ context 'with a provider that generates ids' do
50
+ subject do
51
+ Class.new(described_class) do
52
+ def to_solr
53
+ super.merge(id: 123)
54
+ end
55
+ end.new(exhibit: exhibit)
56
+ end
57
+
58
+ before do
59
+ SolrDocument.new(id: 123).sidecars.create!(exhibit: exhibit, data: { document_data: true })
60
+ allow(subject).to receive_messages(to_global_id: '', update_index_time!: nil)
61
+ end
62
+
63
+ it 'includes exhibit document-specific data' do
64
+ expect(subject.send(:blacklight_solr)).to receive(:update) do |options|
65
+ data = JSON.parse(options[:data], symbolize_names: true)
66
+
67
+ expect(data.length).to eq 1
68
+ doc = data.first
69
+
70
+ expect(doc).to include document_data: true
71
+ end
72
+
73
+ subject.reindex
74
+ end
75
+ end
76
+ end
77
+
78
+ describe '#becomes_provider' do
79
+ it 'converts the resource to a provider-specific resource' do
80
+ SomeClass = Class.new(described_class)
81
+ allow(described_class).to receive_messages(class_for_resource: SomeClass)
52
82
  expect(subject.becomes_provider).to be_a_kind_of(SomeClass)
53
- expect(subject.becomes_provider.type).to eq "SomeClass"
83
+ expect(subject.becomes_provider.type).to eq 'SomeClass'
54
84
  end
55
85
  end
56
86
 
57
- it "should reindex after save" do
87
+ it 'reindexs after save' do
58
88
  expect(subject).to receive(:reindex)
59
89
  subject.data_will_change!
60
90
  subject.save!
61
91
  end
62
92
 
63
- it "should store arbitrary data" do
93
+ it 'stores arbitrary data' do
64
94
  subject.data[:a] = 1
65
95
  subject.data[:b] = 2
66
96
 
@@ -68,15 +98,15 @@ describe Spotlight::Resource, :type => :model do
68
98
  expect(subject.data[:b]).to eq 2
69
99
  end
70
100
 
71
- describe "#update_index_time!" do
72
- it "should update the index_time column" do
101
+ describe '#update_index_time!' do
102
+ it 'updates the index_time column' do
73
103
  expect(subject).to receive(:update_columns).with(hash_including(:indexed_at))
74
104
  subject.update_index_time!
75
105
  end
76
106
  end
77
107
 
78
- describe "#save_and_commit" do
79
- it "should save the object and commit to solr" do
108
+ describe '#save_and_commit' do
109
+ it 'saves the object and commit to solr' do
80
110
  expect(subject).to receive(:save)
81
111
  expect(subject.send(:blacklight_solr)).to receive(:commit)
82
112
  subject.save_and_commit
@@ -1,43 +1,41 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Resources::OpenGraph, :type => :model do
3
+ describe Spotlight::Resources::OpenGraph, type: :model do
4
4
  class TestResource < Spotlight::Resource
5
5
  include Spotlight::Resources::Web
6
6
  include Spotlight::Resources::OpenGraph
7
7
  end
8
-
9
- let(:exhibit) { double(solr_data: { }) }
10
8
 
11
- subject { TestResource.new url: "info:url" }
9
+ let(:exhibit) { double(solr_data: {}) }
12
10
 
13
- describe "#to_solr" do
11
+ subject { TestResource.new url: 'info:url' }
14
12
 
13
+ describe '#to_solr' do
15
14
  before do
16
- allow(subject).to receive_messages id: 15, opengraph_properties: {}, exhibit: exhibit
15
+ allow(subject).to receive_messages id: 15, opengraph_properties: {}, exhibit: exhibit, persisted?: true
17
16
  end
18
17
 
19
18
  let(:solr_doc) { subject.to_solr }
20
19
 
21
- it "should include this record id" do
20
+ it 'includes this record id' do
22
21
  expect(solr_doc).to include spotlight_resource_id_ssim: subject.to_global_id.to_s
23
22
  end
24
23
 
25
- it "should include opengraph properties" do
26
- allow(subject).to receive_messages opengraph_properties: { a: 1, b: 2}
24
+ it 'includes opengraph properties' do
25
+ allow(subject).to receive_messages opengraph_properties: { a: 1, b: 2 }
27
26
 
28
27
  expect(solr_doc).to include a: 1, b: 2
29
28
  end
30
-
31
29
  end
32
30
 
33
- describe "#opengraph_properties" do
34
- it "should map opengraph properties to solr fields" do
35
- allow(subject).to receive_messages opengraph: { "og_title" => "title", "og_description" => "description"}
36
- expect(subject.opengraph_properties).to include "og_title_tesim" => "title", "og_description_tesim" => "description"
31
+ describe '#opengraph_properties' do
32
+ it 'maps opengraph properties to solr fields' do
33
+ allow(subject).to receive_messages opengraph: { 'og_title' => 'title', 'og_description' => 'description' }
34
+ expect(subject.opengraph_properties).to include 'og_title_tesim' => 'title', 'og_description_tesim' => 'description'
37
35
  end
38
36
  end
39
37
 
40
- describe "#opengraph" do
38
+ describe '#opengraph' do
41
39
  let(:body) do
42
40
  Nokogiri::HTML.parse <<-EOF
43
41
  <html><head>
@@ -51,10 +49,10 @@ describe Spotlight::Resources::OpenGraph, :type => :model do
51
49
  </head></html>
52
50
  EOF
53
51
  end
54
- it "should extract opengraph <meta> tags" do
52
+ it 'extracts opengraph <meta> tags' do
55
53
  allow(subject).to receive_messages(body: body)
56
- expect(subject.opengraph).to include "og:title", "og:description", "og:type", "og:type", "og:site_name", "og:video", "og:video:width", "og:video:height"
57
- expect(subject.opengraph["og:title"]).to eq "The Ground Truth: The Human Cost of War"
54
+ expect(subject.opengraph).to include 'og:title', 'og:description', 'og:type', 'og:type', 'og:site_name', 'og:video', 'og:video:width', 'og:video:height'
55
+ expect(subject.opengraph['og:title']).to eq 'The Ground Truth: The Human Cost of War'
58
56
  end
59
57
  end
60
58
  end
@@ -1,60 +1,58 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Resources::Upload, :type => :model do
3
+ describe Spotlight::Resources::Upload, type: :model do
4
4
  let!(:exhibit) { FactoryGirl.create :exhibit }
5
5
  let!(:custom_field) { FactoryGirl.create :custom_field, exhibit: exhibit }
6
6
  before do
7
7
  subject.exhibit = exhibit
8
8
  end
9
9
 
10
- let(:configured_fields) { [title_field] + Spotlight::Resources::Upload.fields(exhibit) }
11
- let(:title_field) { OpenStruct.new(field_name: "configured_title_field") }
10
+ let(:configured_fields) { [title_field] + described_class.fields(exhibit) }
11
+ let(:title_field) { OpenStruct.new(field_name: 'configured_title_field') }
12
12
  let(:upload_data) do
13
13
  {
14
- title_field.field_name => "Title Data",
15
- "spotlight_upload_description_tesim" => "Description Data",
16
- "spotlight_upload_attribution_tesim" => "Attribution Data",
17
- "spotlight_upload_date_tesim" => "Date Data",
18
- custom_field.field => "Custom Field Data"
14
+ title_field.field_name => 'Title Data',
15
+ 'spotlight_upload_description_tesim' => 'Description Data',
16
+ 'spotlight_upload_attribution_tesim' => 'Attribution Data',
17
+ 'spotlight_upload_date_tesim' => 'Date Data',
18
+ custom_field.field => 'Custom Field Data'
19
19
  }
20
20
  end
21
21
 
22
22
  before do
23
-
24
23
  allow(subject).to receive(:configured_fields).and_return configured_fields
25
24
  allow(described_class).to receive(:fields).and_return configured_fields
26
25
 
27
- allow(subject.send(:blacklight_solr)).to receive(:update)
26
+ allow(subject.send(:blacklight_solr)).to receive(:update)
28
27
  allow(Spotlight::Engine.config).to receive(:upload_title_field).and_return(title_field)
29
28
  subject.data = upload_data
30
29
  subject.url = File.open(File.join(FIXTURES_PATH, '800x600.png'))
31
30
  subject.save
32
31
  end
33
-
34
- context "with a custom upload title field" do
35
- let(:title_field) { OpenStruct.new(field_name: "configured_title_field", solr_field: :some_other_field) }
36
32
 
37
- describe "#to_solr" do
38
- it "should store the title field in the provided solr field" do
39
- expect(subject.to_solr[:some_other_field]).to eq "Title Data"
33
+ context 'with a custom upload title field' do
34
+ let(:title_field) { OpenStruct.new(field_name: 'configured_title_field', solr_field: :some_other_field) }
35
+
36
+ describe '#to_solr' do
37
+ it 'stores the title field in the provided solr field' do
38
+ expect(subject.to_solr[:some_other_field]).to eq 'Title Data'
40
39
  end
41
40
  end
42
41
  end
43
-
44
- context "multiple solr field mappings" do
45
42
 
43
+ context 'multiple solr field mappings' do
46
44
  let :configured_fields do
47
45
  [
48
- OpenStruct.new(field_name: 'some_field', solr_field: ['a', 'b'])
46
+ OpenStruct.new(field_name: 'some_field', solr_field: %w(a b))
49
47
  ]
50
48
  end
51
49
 
52
50
  let :upload_data do
53
- { 'some_field' => 'value'}
51
+ { 'some_field' => 'value' }
54
52
  end
55
53
 
56
- describe "#to_solr" do
57
- it "should map a single uploaded field to multiple solr fields" do
54
+ describe '#to_solr' do
55
+ it 'maps a single uploaded field to multiple solr fields' do
58
56
  expect(subject.to_solr['a']).to eq 'value'
59
57
  expect(subject.to_solr['b']).to eq 'value'
60
58
  end
@@ -62,35 +60,34 @@ describe Spotlight::Resources::Upload, :type => :model do
62
60
  end
63
61
 
64
62
  describe '#to_solr' do
65
-
66
- it 'should have the exhibit id and the upload id as the solr id' do
63
+ it 'has the exhibit id and the upload id as the solr id' do
67
64
  expect(subject.to_solr[:id]).to eq "#{subject.exhibit.id}-#{subject.id}"
68
65
  end
69
66
 
70
- it 'should have a title field using the exhibit specific blacklight_config' do
71
- expect(subject.to_solr["configured_title_field"]).to eq 'Title Data'
67
+ it 'has a title field using the exhibit specific blacklight_config' do
68
+ expect(subject.to_solr['configured_title_field']).to eq 'Title Data'
72
69
  end
73
70
 
74
- it 'should have the other additional configured fields' do
75
- expect(subject.to_solr[:spotlight_upload_description_tesim]).to eq "Description Data"
76
- expect(subject.to_solr[:spotlight_upload_attribution_tesim]).to eq "Attribution Data"
77
- expect(subject.to_solr[:spotlight_upload_date_tesim]).to eq "Date Data"
71
+ it 'has the other additional configured fields' do
72
+ expect(subject.to_solr[:spotlight_upload_description_tesim]).to eq 'Description Data'
73
+ expect(subject.to_solr[:spotlight_upload_attribution_tesim]).to eq 'Attribution Data'
74
+ expect(subject.to_solr[:spotlight_upload_date_tesim]).to eq 'Date Data'
78
75
  end
79
76
 
80
- it 'should have a spotlight_resource_type field' do
77
+ it 'has a spotlight_resource_type field' do
81
78
  expect(subject.to_solr[:spotlight_resource_type_ssim]).to eq 'spotlight/resources/uploads'
82
79
  end
83
- it 'should have the various image fields' do
80
+ it 'has the various image fields' do
84
81
  expect(subject.to_solr).to have_key Spotlight::Engine.config.full_image_field
85
82
  expect(subject.to_solr).to have_key Spotlight::Engine.config.thumbnail_field
86
83
  expect(subject.to_solr).to have_key Spotlight::Engine.config.square_image_field
87
84
  end
88
- it 'should have the full image dimensions fields' do
85
+ it 'has the full image dimensions fields' do
89
86
  expect(subject.to_solr[:spotlight_full_image_height_ssm]).to eq 600
90
87
  expect(subject.to_solr[:spotlight_full_image_width_ssm]).to eq 800
91
88
  end
92
- it 'should have fields representing exhibit specific custom fields' do
93
- expect(subject.to_solr[custom_field.field]).to eq "Custom Field Data"
89
+ it 'has fields representing exhibit specific custom fields' do
90
+ expect(subject.to_solr[custom_field.field]).to eq 'Custom Field Data'
94
91
  end
95
92
  end
96
93
  end
@@ -1,28 +1,26 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Resources::Web, :type => :model do
4
-
3
+ describe Spotlight::Resources::Web, type: :model do
5
4
  class TestResource < Spotlight::Resource
6
5
  include Spotlight::Resources::Web
7
6
  end
8
7
 
9
8
  subject { TestResource.new }
10
- describe ".fetch" do
11
-
9
+ describe '.fetch' do
12
10
  end
13
11
 
14
- describe "#harvest!" do
15
- it "should cache the body and headers in the data" do
16
- allow(Spotlight::Resources::Web).to receive_messages(fetch: double(body: "xyz", headers: {a: 1}))
12
+ describe '#harvest!' do
13
+ it 'caches the body and headers in the data' do
14
+ allow(described_class).to receive_messages(fetch: double(body: 'xyz', headers: { a: 1 }))
17
15
  subject.harvest!
18
- expect(subject.data[:body]).to eq "xyz"
16
+ expect(subject.data[:body]).to eq 'xyz'
19
17
  expect(subject.data[:headers]).to eq a: 1
20
18
  end
21
19
  end
22
20
 
23
- describe "#body" do
24
- it "should return the body DOM" do
25
- allow(Spotlight::Resources::Web).to receive_messages(fetch: double(body: "<html />", headers: {a: 1}))
21
+ describe '#body' do
22
+ it 'returns the body DOM' do
23
+ allow(described_class).to receive_messages(fetch: double(body: '<html />', headers: { a: 1 }))
26
24
  expect(subject.body).to be_a_kind_of(Nokogiri::HTML::Document)
27
25
  end
28
26
  end
@@ -1,37 +1,37 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Role, :type => :model do
4
- describe "validations" do
5
- subject { Spotlight::Role.new(args) }
6
- describe "with nothing" do
7
- let(:args) { {user_key: ''} }
8
- it "should not be valid" do
3
+ describe Spotlight::Role, type: :model do
4
+ describe 'validations' do
5
+ subject { described_class.new(args) }
6
+ describe 'with nothing' do
7
+ let(:args) { { user_key: '' } }
8
+ it 'does not be valid' do
9
9
  expect(subject).not_to be_valid
10
- expect(subject.errors.messages).to eq({:role=>["is not included in the list"], :user_key=>["can't be blank"]})
10
+ expect(subject.errors.messages).to eq(role: ['is not included in the list'], user_key: ["can't be blank"])
11
11
  end
12
12
  end
13
- describe "with user_key" do
14
- let (:user) { FactoryGirl.create(:user)}
13
+ describe 'with user_key' do
14
+ let(:user) { FactoryGirl.create(:user) }
15
15
  describe "that doesn't point at a user" do
16
- let(:args) { {role: 'curator', user_key: 'bob'} }
17
- it "should not be valid" do
16
+ let(:args) { { role: 'curator', user_key: 'bob' } }
17
+ it 'does not be valid' do
18
18
  expect(subject).not_to be_valid
19
- expect(subject.errors.messages).to eq({:user_key=>["User must sign up first."]})
19
+ expect(subject.errors.messages).to eq(user_key: ['User must sign up first.'])
20
20
  end
21
21
  end
22
- describe "that points at a user" do
23
- let(:args) { {role: 'curator', user_key: user.email} }
24
- it "should be valid" do
22
+ describe 'that points at a user' do
23
+ let(:args) { { role: 'curator', user_key: user.email } }
24
+ it 'is valid' do
25
25
  expect(subject).to be_valid
26
26
  expect(subject.errors.messages).to be_empty
27
27
  end
28
28
  end
29
- describe "that points at a user with an existing role" do
30
- before { Spotlight::Role.create!(role: 'curator', user: user) }
31
- let(:args) { {role: 'curator', user_key: user.email} }
32
- it "should be valid" do
29
+ describe 'that points at a user with an existing role' do
30
+ before { described_class.create!(role: 'curator', user: user) }
31
+ let(:args) { { role: 'curator', user_key: user.email } }
32
+ it 'is valid' do
33
33
  expect(subject).not_to be_valid
34
- expect(subject.errors.messages).to eq({:user_key => ["already a member of this exhibit"]})
34
+ expect(subject.errors.messages).to eq(user_key: ['already a member of this exhibit'])
35
35
  end
36
36
  end
37
37
  end
@@ -1,35 +1,52 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::Search, :type => :model do
4
- let(:query_params) { {"f"=>{"genre_sim"=>["map"]}} }
5
- subject { FactoryGirl.build(:search, query_params: query_params )}
3
+ describe Spotlight::Search, type: :model do
4
+ let(:query_params) { { 'f' => { 'genre_sim' => ['map'] } } }
5
+ subject { FactoryGirl.create(:exhibit).searches.build(title: 'Search', query_params: query_params) }
6
6
 
7
7
  let(:blacklight_config) { ::CatalogController.blacklight_config }
8
+ let(:document) do
9
+ SolrDocument.new(id: 'dq287tq6352',
10
+ blacklight_config.index.title_field => 'title',
11
+ Spotlight::Engine.config.full_image_field => 'https://stacks.stanford.edu/image/iiif/dq287tq6352%2Fdq287tq6352_05_0001/full/!400,400/0/default.jpg')
12
+ end
13
+ let(:document_without_an_image) do
14
+ SolrDocument.new(id: 'ab123fd9876',
15
+ blacklight_config.index.title_field => 'title')
16
+ end
8
17
 
9
18
  it { is_expected.to be_a Spotlight::Catalog::AccessControlsEnforcement }
10
19
 
11
- it "should have a default feature image" do
12
- allow(subject).to receive_messages(documents: [SolrDocument.new(id: 'dq287tq6352', blacklight_config.index.title_field => 'title', Spotlight::Engine.config.full_image_field => "https://stacks.stanford.edu/image/dq287tq6352/dq287tq6352_05_0001_thumb")])
20
+ it 'has a default feature image' do
21
+ allow(subject).to receive_messages(documents: [document])
22
+ subject.save!
23
+ expect(subject.thumbnail).not_to be_nil
24
+ expect(subject.thumbnail.image.path).to end_with 'default.jpg'
25
+ end
26
+
27
+ it 'uses a document with an image for the default feature image' do
28
+ allow(subject).to receive_messages(documents: [document_without_an_image, document])
13
29
  subject.save!
14
30
  expect(subject.thumbnail).not_to be_nil
15
- expect(subject.thumbnail.image.path).to end_with "dq287tq6352_05_0001_thumb.jpeg"
31
+ expect(subject.thumbnail.image.path).to end_with 'default.jpg'
16
32
  end
17
33
 
18
- it "should have items" do
34
+ it 'has items' do
19
35
  expect(subject.count).to eq 55
20
36
  end
21
37
 
22
- it "should have images" do
38
+ it 'has images' do
23
39
  expect(subject.images.size).to eq(55)
24
- expect(subject.images.map(&:last)).to include "https://stacks.stanford.edu/image/dq287tq6352/dq287tq6352_05_0001_thumb", "https://stacks.stanford.edu/image/jp266yb7109/jp266yb7109_05_0001_thumb"
40
+ expect(subject.images.map(&:last)).to include 'https://stacks.stanford.edu/image/dq287tq6352/dq287tq6352_05_0001_thumb',
41
+ 'https://stacks.stanford.edu/image/jp266yb7109/jp266yb7109_05_0001_thumb'
25
42
  end
26
43
 
27
- describe "default_scope" do
28
- let!(:page1) { FactoryGirl.create(:search, weight: 5, on_landing_page: true) }
29
- let!(:page2) { FactoryGirl.create(:search, weight: 1, on_landing_page: true) }
30
- let!(:page3) { FactoryGirl.create(:search, weight: 10, on_landing_page: true) }
31
- it "should order by weight" do
32
- expect(Spotlight::Search.published.map(&:weight)).to eq [1, 5, 10]
44
+ describe 'default_scope' do
45
+ let!(:page1) { FactoryGirl.create(:search, weight: 5, published: true) }
46
+ let!(:page2) { FactoryGirl.create(:search, weight: 1, published: true) }
47
+ let!(:page3) { FactoryGirl.create(:search, weight: 10, published: true) }
48
+ it 'orders by weight' do
49
+ expect(described_class.published.map(&:weight)).to eq [1, 5, 10]
33
50
  end
34
51
  end
35
52
  end