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,7 +1,7 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::RolesHelper, :type => :helper do
4
- it "should be a list of options" do
5
- expect(helper.roles_for_select).to eq({"Admin"=>"admin", "Curator"=>"curator"})
3
+ describe Spotlight::RolesHelper, type: :helper do
4
+ it 'is a list of options' do
5
+ expect(helper.roles_for_select).to eq('Admin' => 'admin', 'Curator' => 'curator')
6
6
  end
7
7
  end
@@ -0,0 +1,24 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spotlight::SearchConfigurationsHelper, type: :helper do
4
+ describe '#translate_sort_fields' do
5
+ let(:sort_config) do
6
+ Blacklight::OpenStructWithHashAccess.new(sort: 'score asc, sort_title_ssi desc')
7
+ end
8
+
9
+ it 'translates sort fields' do
10
+ expect(translate_sort_fields(sort_config)).to eq 'relevancy score ascending and title descending'
11
+ end
12
+
13
+ it 'humanizes untranslatable sort fields' do
14
+ sort_config.sort = 'some_other_field desc'
15
+
16
+ expect(translate_sort_fields(sort_config)).to eq 'some other field descending'
17
+ end
18
+
19
+ it 'supports explicit sort descriptions' do
20
+ sort_config.sort_description = 'xyz'
21
+ expect(translate_sort_fields(sort_config)).to eq 'xyz'
22
+ end
23
+ end
24
+ end
@@ -1,60 +1,58 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spotlight::TitleHelper, :type => :helper do
3
+ describe Spotlight::TitleHelper, type: :helper do
4
4
  before do
5
- allow(helper).to receive_messages(application_name: "Application")
5
+ allow(helper).to receive_messages(application_name: 'Application')
6
6
  end
7
7
 
8
- describe "#page_title" do
9
- it "should set the @page_title ivar" do
10
- helper.page_title("Section", "Title")
8
+ describe '#page_title' do
9
+ it 'sets the @page_title ivar' do
10
+ helper.page_title('Section', 'Title')
11
11
  title = helper.instance_variable_get(:@page_title)
12
- expect(title).to eq "Section - Title | Application"
12
+ expect(title).to eq 'Section - Title | Application'
13
13
  end
14
14
 
15
- it "should render the section title and the page title" do
16
- title = helper.page_title("Section", "Title")
17
- expect(title).to have_selector "h1", text: "Section"
18
- expect(title).to have_selector "h1 small", text: "Title"
19
-
15
+ it 'renders the section title and the page title' do
16
+ title = helper.page_title('Section', 'Title')
17
+ expect(title).to have_selector 'h1', text: 'Section'
18
+ expect(title).to have_selector 'h1 small', text: 'Title'
20
19
  end
21
20
  end
22
21
 
23
- describe "#set_html_page_title" do
24
- it "should assign the @page_title ivar" do
25
- allow(helper).to receive_messages(application_name: "B")
26
- helper.set_html_page_title "A"
22
+ describe '#set_html_page_title' do
23
+ it 'assigns the @page_title ivar' do
24
+ allow(helper).to receive_messages(application_name: 'B')
25
+ helper.set_html_page_title 'A'
27
26
  title = helper.instance_variable_get(:@page_title)
28
- expect(title).to eq "A | B"
27
+ expect(title).to eq 'A | B'
29
28
  end
30
- it 'should strip out any HTML tags' do
31
- allow(helper).to receive_messages(application_name: "B")
32
- expect(helper.set_html_page_title("<b>text</b> should not include HTML")).to eq "text should not include HTML | B"
29
+ it 'strips out any HTML tags' do
30
+ allow(helper).to receive_messages(application_name: 'B')
31
+ expect(helper.set_html_page_title('<b>text</b> should not include HTML')).to eq 'text should not include HTML | B'
33
32
  end
34
33
  end
35
34
 
36
- describe "#curation_page_title" do
37
- it "should render a page title in the curation section" do
38
- title = helper.curation_page_title "Some title"
39
- expect(title).to have_selector "h1", text: "Curation"
40
- expect(title).to have_selector "h1 small", text: "Some title"
35
+ describe '#curation_page_title' do
36
+ it 'renders a page title in the curation section' do
37
+ title = helper.curation_page_title 'Some title'
38
+ expect(title).to have_selector 'h1', text: 'Curation'
39
+ expect(title).to have_selector 'h1 small', text: 'Some title'
41
40
  end
42
41
  end
43
42
 
44
- describe "#administration_page_title" do
45
- it "should render a page title in the administration section" do
46
- title = helper.administration_page_title "Some title"
47
- expect(title).to have_selector "h1", text: "Administration"
48
- expect(title).to have_selector "h1 small", text: "Some title"
43
+ describe '#administration_page_title' do
44
+ it 'renders a page title in the administration section' do
45
+ title = helper.administration_page_title 'Some title'
46
+ expect(title).to have_selector 'h1', text: 'Administration'
47
+ expect(title).to have_selector 'h1 small', text: 'Some title'
49
48
  end
50
49
  end
51
50
 
52
- describe "#header_with_count" do
53
- it "should merge the title with a count label" do
54
- val = helper.header_with_count "some title", 5
55
- expect(val).to match /some title /
56
- expect(val).to have_selector "span.label", text: 5
51
+ describe '#header_with_count' do
52
+ it 'merges the title with a count label' do
53
+ val = helper.header_with_count 'some title', 5
54
+ expect(val).to include 'some title'
55
+ expect(val).to have_selector 'span.label', text: 5
57
56
  end
58
57
  end
59
-
60
58
  end
@@ -8,14 +8,14 @@ describe Spotlight::ReindexJob do
8
8
  allow_any_instance_of(Spotlight::Resource).to receive(:reindex)
9
9
  end
10
10
 
11
- context "with an exhibit" do
11
+ context 'with an exhibit' do
12
12
  subject { described_class.new(exhibit) }
13
13
 
14
14
  before do
15
15
  exhibit.resources << resource
16
16
  exhibit.save
17
17
  end
18
- it "should attempt to reindex every resource in the exhibit" do
18
+ it 'attempts to reindex every resource in the exhibit' do
19
19
  # ActiveJob will reload the collection, so we go through a little trouble:
20
20
  expect_any_instance_of(Spotlight::Resource).to receive(:reindex) do |thingy|
21
21
  expect(exhibit.resources).to include thingy
@@ -25,12 +25,12 @@ describe Spotlight::ReindexJob do
25
25
  end
26
26
  end
27
27
 
28
- context "with a resource" do
28
+ context 'with a resource' do
29
29
  subject { described_class.new(resource) }
30
-
31
- it "should attempt to reindex every resource in the exhibit" do
30
+
31
+ it 'attempts to reindex every resource in the exhibit' do
32
32
  expect(resource).to receive(:reindex)
33
33
  subject.perform_now
34
34
  end
35
35
  end
36
- end
36
+ end
@@ -2,26 +2,26 @@ require 'spec_helper'
2
2
 
3
3
  describe Spotlight::RenameSidecarFieldJob do
4
4
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
- let(:sidecar) { SolrDocument.new(id: 'test').sidecar(exhibit).tap { |x| x.save! } }
5
+ let(:sidecar) { SolrDocument.new(id: 'test').sidecar(exhibit).tap(&:save!) }
6
6
 
7
- it "should update the sidecar data and reindex affected documents" do
7
+ it 'updates the sidecar data and reindex affected documents' do
8
8
  expect_any_instance_of(::SolrDocument).to receive(:reindex)
9
9
 
10
10
  sidecar.data['old_field'] = 'some value'
11
11
  sidecar.save!
12
12
 
13
- described_class.perform_later(exhibit, "old_field", "new_field")
14
-
13
+ described_class.perform_later(exhibit, 'old_field', 'new_field')
14
+
15
15
  sidecar.reload
16
16
  expect(sidecar.data['new_field']).to eq 'some value'
17
17
  end
18
18
 
19
- it "shouldn't touch unaffected documents" do
19
+ it 'does not touch unaffected documents' do
20
20
  expect_any_instance_of(::SolrDocument).not_to receive(:reindex)
21
21
 
22
22
  sidecar.data['other_field'] = 'some value'
23
23
  sidecar.save!
24
24
 
25
- described_class.perform_later(exhibit, "old_field", "new_field")
25
+ described_class.perform_later(exhibit, 'old_field', 'new_field')
26
26
  end
27
- end
27
+ end
@@ -1,57 +1,72 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe Spotlight::Catalog::AccessControlsEnforcement do
4
- class MockCatalogController
5
- include Blacklight::SearchHelper
6
- include Spotlight::Catalog::AccessControlsEnforcement
4
+ class MockSearchBuilder < Blacklight::SearchBuilder
5
+ attr_reader :blacklight_params, :scope
6
+ def initialize(blacklight_params, scope)
7
+ @blacklight_params = blacklight_params
8
+ @scope = scope
9
+ end
10
+ include Spotlight::Catalog::AccessControlsEnforcement::SearchBuilder
11
+ include Blacklight::Solr::SearchBuilderBehavior
7
12
 
8
13
  def blacklight_config
9
- @blacklight_config ||= Blacklight::Configuration.new
14
+ scope.current_exhibit.blacklight_config
10
15
  end
11
16
  end
12
17
 
13
- subject { MockCatalogController.new }
14
- let(:solr_request) { Blacklight::Solr::Request.new }
18
+ subject { MockSearchBuilder.new blacklight_params, scope }
15
19
  let(:exhibit) { FactoryGirl.create(:exhibit) }
20
+ let(:scope) { double(current_exhibit: exhibit) }
21
+ let(:solr_request) { Blacklight::Solr::Request.new }
22
+ let(:blacklight_params) { Hash.new }
16
23
 
17
- before do
18
- allow(subject).to receive_messages(current_exhibit: exhibit)
19
- end
24
+ describe '.search_params_logic' do
25
+ class MockCatalogController
26
+ include Blacklight::SearchHelper
27
+ include Spotlight::Catalog::AccessControlsEnforcement
28
+ end
29
+
30
+ subject { MockCatalogController.new }
20
31
 
21
- describe "#apply_permissive_visibility_filter" do
22
- it "should add the filter to the params logic" do
23
- expect(subject.search_params_logic).to include :apply_permissive_visibility_filter
32
+ it 'adds the filter to the params logic' do
33
+ expect(subject.search_params_logic).to include :apply_permissive_visibility_filter
24
34
  end
35
+ end
25
36
 
26
- it "should allow curators to view everything" do
27
- allow(subject).to receive(:can?).and_return(true)
28
- subject.send(:apply_permissive_visibility_filter, solr_request, {})
37
+ describe '#apply_permissive_visibility_filter' do
38
+ it 'allows curators to view everything' do
39
+ allow(scope).to receive(:can?).and_return(true)
40
+ subject.apply_permissive_visibility_filter(solr_request)
29
41
  expect(solr_request.to_hash).to be_empty
30
42
  end
31
43
 
32
- it "should restrict searches to public items" do
33
- allow(subject).to receive(:can?).and_return(false)
44
+ it 'restricts searches to public items' do
45
+ allow(scope).to receive(:can?).and_return(false)
34
46
 
35
- subject.send(:apply_permissive_visibility_filter, solr_request, {})
47
+ subject.apply_permissive_visibility_filter(solr_request)
36
48
  expect(solr_request).to include :fq
37
- expect(solr_request[:fq]).to include "-exhibit_1_public_bsi:false"
49
+ expect(solr_request[:fq]).to include '-exhibit_1_public_bsi:false'
38
50
  end
39
-
40
- it "should not filter resources to just those created by the exhibit" do
51
+
52
+ it 'does not filter resources to just those created by the exhibit' do
41
53
  allow(subject).to receive(:can?).and_return(true)
42
- subject.send(:apply_permissive_visibility_filter, solr_request, {})
54
+ subject.apply_permissive_visibility_filter(solr_request)
43
55
  expect(solr_request).to include :fq
44
56
  expect(solr_request[:fq]).not_to include "spotlight_exhibit_slug_#{exhibit.slug}_bsi:true"
45
57
  end
58
+ end
46
59
 
47
- context "with filter_resources_by_exhibit" do
60
+ describe '#apply_exhibit_resources_filter' do
61
+ context 'with filter_resources_by_exhibit' do
48
62
  before do
49
63
  allow(Spotlight::Engine.config).to receive(:filter_resources_by_exhibit).and_return(true)
50
64
  end
51
65
 
52
- it "should filter resources to just those created by the exhibit" do
53
- allow(subject).to receive(:can?).and_return(true)
54
- subject.send(:apply_permissive_visibility_filter, solr_request, {})
66
+ it 'filters resources to just those created by the exhibit' do
67
+ allow(scope).to receive(:can?).and_return(true)
68
+
69
+ subject.apply_exhibit_resources_filter(solr_request)
55
70
  expect(solr_request).to include :fq
56
71
  expect(solr_request[:fq]).to include "spotlight_exhibit_slug_#{exhibit.slug}_bsi:true"
57
72
  end
@@ -8,11 +8,11 @@ describe Spotlight::Controller do
8
8
  subject { MockController.new }
9
9
 
10
10
  before do
11
- allow(subject).to receive_messages(params: {action: 'show'})
11
+ allow(subject).to receive_messages(params: { action: 'show' })
12
12
  end
13
13
 
14
- describe "#current_exhibit" do
15
- it "should be nil by default" do
14
+ describe '#current_exhibit' do
15
+ it 'is nil by default' do
16
16
  expect(subject.current_exhibit).to be_nil
17
17
  end
18
18
  end
@@ -24,16 +24,16 @@ describe Spotlight::Controller do
24
24
  allow(subject).to receive_messages(current_exhibit: nil, current_masthead: nil)
25
25
  end
26
26
 
27
- it "should be true if there is no exhibit" do
27
+ it 'is true if there is no exhibit' do
28
28
  expect(subject.exhibit_masthead?).to eq true
29
29
  end
30
30
 
31
- it "should be true if there is no custom exhibit masthead" do
31
+ it 'is true if there is no custom exhibit masthead' do
32
32
  allow(subject).to receive_messages(current_exhibit: double, current_masthead: nil)
33
33
  expect(subject.exhibit_masthead?).to eq true
34
34
  end
35
35
 
36
- it "should be false if the current masthead is not the exhibit masthead" do
36
+ it 'is false if the current masthead is not the exhibit masthead' do
37
37
  allow(subject).to receive_messages(current_exhibit: double(masthead: double), current_masthead: masthead)
38
38
  expect(subject.exhibit_masthead?).to eq false
39
39
  end
@@ -44,17 +44,17 @@ describe Spotlight::Controller do
44
44
  let(:exhibit_masthead) { double('exhibit-masthead', display?: true) }
45
45
  let(:exhibit) { FactoryGirl.create(:exhibit) }
46
46
  let(:search) { FactoryGirl.create(:search) }
47
- it 'should be nil by default' do
47
+ it 'is nil by default' do
48
48
  expect(subject.current_masthead).to be_nil
49
49
  end
50
- it 'should return the exhibit masthead if available' do
50
+ it 'returns the exhibit masthead if available' do
51
51
  allow(exhibit).to receive_messages(masthead: exhibit_masthead)
52
52
  subject.instance_variable_set(:@exhibit, exhibit)
53
53
  expect(subject.current_masthead).to eq exhibit_masthead
54
54
  end
55
- it 'should allow the masthead to be set' do
55
+ it 'allows the masthead to be set' do
56
56
  subject.current_masthead = search_masthead
57
57
  expect(subject.current_masthead).to eq search_masthead
58
58
  end
59
59
  end
60
- end
60
+ end
@@ -1,10 +1,10 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe ActionDispatch::Routing::Mapper do
4
- describe "#spotlight_root" do
3
+ describe Spotlight::Routes do
4
+ describe '#spotlight_root' do
5
5
  subject { ActionDispatch::Routing::Mapper.new(ActionDispatch::Routing::RouteSet.new) }
6
- it "should make the root route" do
7
- expect(subject).to receive(:root).with(to: "spotlight/default#index")
6
+ it 'makes the root route' do
7
+ expect(subject).to receive(:root).with(to: 'spotlight/default#index')
8
8
  subject.spotlight_root
9
9
  end
10
10
  end
@@ -1,31 +1,31 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe Spotlight::IndexingCompleteMailer do
4
- let(:user) { double(email: "test@example.com") }
5
- let(:exhibit) { double(title: "Exhibit title") }
6
- subject { Spotlight::IndexingCompleteMailer.documents_indexed [1,2,3], exhibit, user}
7
-
4
+ let(:user) { double(email: 'test@example.com') }
5
+ let(:exhibit) { double(title: 'Exhibit title') }
6
+ subject { described_class.documents_indexed [1, 2, 3], exhibit, user }
7
+
8
8
  it 'renders the receiver email' do
9
9
  expect(subject.to).to eql([user.email])
10
10
  end
11
11
 
12
- it "includes a title" do
13
- expect(subject.body.encoded).to match "Your CSV file has just finished being processed"
12
+ it 'includes a title' do
13
+ expect(subject.body.encoded).to match 'Your CSV file has just finished being processed'
14
14
  end
15
-
15
+
16
16
  it 'describes how many documents were indexed' do
17
- expect(subject.body.encoded).to match "3 documents"
17
+ expect(subject.body.encoded).to match '3 documents'
18
18
  end
19
19
 
20
- context "single item" do
21
- subject { Spotlight::IndexingCompleteMailer.documents_indexed [1], exhibit, user}
20
+ context 'single item' do
21
+ subject { described_class.documents_indexed [1], exhibit, user }
22
22
 
23
23
  it 'handles pluralization when only a single item was indexed' do
24
- expect(subject.body.encoded).to match "1 document has"
24
+ expect(subject.body.encoded).to match '1 document has'
25
25
  end
26
26
  end
27
-
27
+
28
28
  it 'includes the exhibit title' do
29
29
  expect(subject.body.encoded).to match exhibit.title
30
30
  end
31
- end
31
+ end
@@ -3,18 +3,18 @@ require 'spec_helper'
3
3
  describe SirTrevorRails::Blocks::SolrDocumentsBlock do
4
4
  let(:page) { FactoryGirl.create(:feature_page) }
5
5
  let(:block_data) { {} }
6
- subject { described_class.new({type: "", data: block_data}, page) }
6
+ subject { described_class.new({ type: '', data: block_data }, page) }
7
7
 
8
- describe "#text" do
9
- it "should be the block's text data" do
10
- block_data[:text] = "abc"
8
+ describe '#text' do
9
+ it "is the block's text data" do
10
+ block_data[:text] = 'abc'
11
11
 
12
- expect(subject.text).to eq "abc"
12
+ expect(subject.text).to eq 'abc'
13
13
  end
14
14
 
15
- it "should squelch sir-trevor's placeholder values" do
16
- block_data[:text] = "<p><br></p>"
15
+ it "squelches sir-trevor's placeholder values" do
16
+ block_data[:text] = '<p><br></p>'
17
17
  expect(subject.text).to be_blank
18
18
  end
19
19
  end
20
- end
20
+ end
@@ -1,4 +1,4 @@
1
- require "spec_helper"
1
+ require 'spec_helper'
2
2
 
3
3
  describe SirTrevorRails::Blocks::Textable do
4
4
  class TextableTestClass
@@ -8,31 +8,30 @@ describe SirTrevorRails::Blocks::Textable do
8
8
  let(:subject) { TextableTestClass.new }
9
9
  let(:st_blank_text) { '<p><br></p>' }
10
10
  describe '#text?' do
11
- it 'should return false when there is no text' do
11
+ it 'returns false when there is no text' do
12
12
  expect(subject.text?).to be_falsey
13
13
  end
14
- it 'should return true false when the text is the default sir-trevor text' do
14
+ it 'returns true false when the text is the default sir-trevor text' do
15
15
  allow(subject).to receive_messages(text: st_blank_text)
16
16
  expect(subject.text?).to be_truthy
17
17
  end
18
18
  end
19
19
  describe '#text_align' do
20
- it 'should proxy the sir-trevor text-align attribute' do
21
- allow(subject).to receive_messages(:'text-align' => 'text-align-value')
20
+ it 'proxies the sir-trevor text-align attribute' do
21
+ allow(subject).to receive_messages('text-align': 'text-align-value')
22
22
  expect(subject.text_align).to eq 'text-align-value'
23
23
  end
24
24
  end
25
25
  describe '#content_align' do
26
- it 'should be the reverse of text-align' do
26
+ it 'is the reverse of text-align' do
27
27
  allow(subject).to receive_messages(text: 'TextContent')
28
28
  allow(subject).to receive_messages(text_align: 'left')
29
29
  expect(subject.content_align).to eq 'right'
30
30
  allow(subject).to receive_messages(text_align: 'right')
31
31
  expect(subject.content_align).to eq 'left'
32
32
  end
33
- it 'should not have any alignment if there is no text' do
33
+ it 'does not have any alignment if there is no text' do
34
34
  expect(subject.content_align).to be_nil
35
35
  end
36
36
  end
37
37
  end
38
-