blacklight-spotlight 0.18.0 → 0.19.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (159) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -9
  3. data/app/assets/javascripts/spotlight/blocks/browse_block.js +1 -0
  4. data/app/assets/stylesheets/spotlight/_bootstrap_overrides.scss +1 -1
  5. data/app/assets/stylesheets/spotlight/_multi_up_item_grid.scss +2 -0
  6. data/app/assets/stylesheets/spotlight/_pages.scss +7 -1
  7. data/app/controllers/spotlight/contact_forms_controller.rb +1 -5
  8. data/app/controllers/spotlight/searches_controller.rb +7 -1
  9. data/app/helpers/spotlight/browse_helper.rb +16 -1
  10. data/app/helpers/spotlight/searches_helper.rb +8 -0
  11. data/app/mailers/spotlight/contact_mailer.rb +9 -0
  12. data/app/models/spotlight/analytics/ga.rb +14 -16
  13. data/app/models/spotlight/blacklight_configuration.rb +6 -6
  14. data/app/models/spotlight/contact_form.rb +12 -10
  15. data/app/services/spotlight/carrierwave_file_resolver.rb +8 -0
  16. data/app/views/spotlight/browse/show.html.erb +5 -1
  17. data/app/views/spotlight/contact_mailer/report_problem.html.erb +14 -0
  18. data/app/views/spotlight/dashboards/analytics.html.erb +1 -3
  19. data/app/views/spotlight/searches/_form.html.erb +5 -0
  20. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb +4 -3
  21. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb +3 -2
  22. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb +3 -2
  23. data/config/locales/spotlight.en.yml +1 -0
  24. data/db/migrate/20160711121314_add_default_view_to_spotlight_searches.rb +5 -0
  25. data/lib/generators/spotlight/install_generator.rb +6 -0
  26. data/lib/generators/spotlight/templates/config/initializers/riiif.rb +7 -0
  27. data/lib/spotlight/version.rb +1 -1
  28. data/spec/controllers/application_controller_spec.rb +0 -2
  29. data/spec/controllers/spotlight/about_pages_controller_spec.rb +0 -2
  30. data/spec/controllers/spotlight/admin_users_controller_spec.rb +0 -2
  31. data/spec/controllers/spotlight/appearances_controller_spec.rb +0 -1
  32. data/spec/controllers/spotlight/application_controller_spec.rb +0 -2
  33. data/spec/controllers/spotlight/attachments_controller_spec.rb +0 -2
  34. data/spec/controllers/spotlight/browse_controller_spec.rb +0 -2
  35. data/spec/controllers/spotlight/catalog_controller_spec.rb +0 -2
  36. data/spec/controllers/spotlight/confirmations_controller_spec.rb +0 -2
  37. data/spec/controllers/spotlight/contact_forms_controller_spec.rb +5 -2
  38. data/spec/controllers/spotlight/contacts_controller_spec.rb +0 -2
  39. data/spec/controllers/spotlight/custom_fields_controller_spec.rb +0 -1
  40. data/spec/controllers/spotlight/dashboards_controller_spec.rb +0 -1
  41. data/spec/controllers/spotlight/exhibits_controller_spec.rb +1 -1
  42. data/spec/controllers/spotlight/feature_pages_controller_spec.rb +0 -1
  43. data/spec/controllers/spotlight/filters_controller_spec.rb +0 -2
  44. data/spec/controllers/spotlight/home_pages_controller_spec.rb +0 -2
  45. data/spec/controllers/spotlight/metadata_configurations_controller_spec.rb +0 -1
  46. data/spec/controllers/spotlight/resources_controller_spec.rb +0 -2
  47. data/spec/controllers/spotlight/roles_controller_spec.rb +0 -2
  48. data/spec/controllers/spotlight/search_configurations_controller_spec.rb +0 -1
  49. data/spec/controllers/spotlight/searches_controller_spec.rb +0 -2
  50. data/spec/controllers/spotlight/sites_controller_spec.rb +0 -2
  51. data/spec/controllers/spotlight/solr_controller_spec.rb +0 -2
  52. data/spec/controllers/spotlight/tags_controller_spec.rb +0 -2
  53. data/spec/controllers/spotlight/versions_controller_spec.rb +0 -2
  54. data/spec/controllers/spotlight/view_configurations_controller_spec.rb +0 -1
  55. data/spec/features/about_page_spec.rb +0 -2
  56. data/spec/features/add_contacts_spec.rb +0 -2
  57. data/spec/features/add_custom_field_metadata_spec.rb +0 -2
  58. data/spec/features/add_items_spec.rb +0 -2
  59. data/spec/features/browse_category_admin_spec.rb +13 -2
  60. data/spec/features/browse_category_spec.rb +27 -2
  61. data/spec/features/catalog_spec.rb +0 -2
  62. data/spec/features/confirm_email_spec.rb +0 -2
  63. data/spec/features/create_exhibit_spec.rb +0 -2
  64. data/spec/features/create_page_spec.rb +0 -2
  65. data/spec/features/curator_items.rb +0 -3
  66. data/spec/features/dashboard_spec.rb +0 -2
  67. data/spec/features/edit_contact_spec.rb +0 -3
  68. data/spec/features/edit_search_fields_spec.rb +0 -2
  69. data/spec/features/exhibit_masthead_spec.rb +0 -2
  70. data/spec/features/exhibits/add_tags_spec.rb +0 -1
  71. data/spec/features/exhibits/administration_spec.rb +0 -1
  72. data/spec/features/exhibits/custom_metadata_fields_spec.rb +0 -1
  73. data/spec/features/exhibits/edit_metadata_fields_spec.rb +0 -1
  74. data/spec/features/exhibits_index_spec.rb +0 -2
  75. data/spec/features/feature_page_spec.rb +0 -2
  76. data/spec/features/home_page_spec.rb +0 -1
  77. data/spec/features/import_exhibit_spec.rb +0 -1
  78. data/spec/features/item_admin_spec.rb +0 -2
  79. data/spec/features/javascript/about_page_admin_spec.rb +0 -2
  80. data/spec/features/javascript/block_controls_spec.rb +0 -2
  81. data/spec/features/javascript/blocks/featured_browse_categories_block_spec.rb +8 -0
  82. data/spec/features/javascript/edit_in_place_spec.rb +0 -2
  83. data/spec/features/javascript/feature_page_admin_spec.rb +0 -2
  84. data/spec/features/javascript/home_page_edit_spec.rb +0 -2
  85. data/spec/features/javascript/metadata_admin_spec.rb +0 -2
  86. data/spec/features/javascript/multi_image_select_spec.rb +0 -2
  87. data/spec/features/javascript/preview_block_spec.rb +0 -2
  88. data/spec/features/javascript/reindex_monitor_spec.rb +0 -2
  89. data/spec/features/javascript/roles_admin_spec.rb +0 -2
  90. data/spec/features/javascript/rule_block_spec.rb +0 -2
  91. data/spec/features/javascript/search_config_admin_spec.rb +0 -2
  92. data/spec/features/javascript/search_context_spec.rb +0 -2
  93. data/spec/features/main_navigation_spec.rb +0 -2
  94. data/spec/features/metadata_admin_spec.rb +0 -2
  95. data/spec/features/report_a_problem_spec.rb +0 -2
  96. data/spec/features/site_admin_management_spec.rb +0 -2
  97. data/spec/features/site_masthead_spec.rb +0 -6
  98. data/spec/features/slideshow_spec.rb +0 -2
  99. data/spec/features/tags_admin_spec.rb +0 -2
  100. data/spec/features/user_admin_spec.rb +0 -2
  101. data/spec/helpers/spotlight/application_helper_spec.rb +0 -1
  102. data/spec/helpers/spotlight/browse_helper_spec.rb +0 -1
  103. data/spec/helpers/spotlight/crud_link_helpers_spec.rb +0 -1
  104. data/spec/helpers/spotlight/jcrop_helper_spec.rb +0 -1
  105. data/spec/helpers/spotlight/main_app_helpers_spec.rb +0 -1
  106. data/spec/helpers/spotlight/navbar_helper_spec.rb +0 -1
  107. data/spec/helpers/spotlight/pages_helper_spec.rb +0 -1
  108. data/spec/helpers/spotlight/roles_helper_spec.rb +0 -1
  109. data/spec/helpers/spotlight/search_configurations_helper_spec.rb +0 -1
  110. data/spec/helpers/spotlight/title_helper_spec.rb +0 -1
  111. data/spec/jobs/spotlight/default_thumbnail_job_spec.rb +0 -1
  112. data/spec/jobs/spotlight/reindex_job_spec.rb +0 -1
  113. data/spec/jobs/spotlight/rename_sidecar_field_job_spec.rb +0 -1
  114. data/spec/lib/spotlight/controller_spec.rb +0 -1
  115. data/spec/mailers/spotlight/indexing_complete_mailer_spec.rb +0 -1
  116. data/spec/models/solr_document_spec.rb +0 -2
  117. data/spec/models/spotlight/ability_spec.rb +0 -1
  118. data/spec/models/spotlight/about_page_spec.rb +0 -2
  119. data/spec/models/spotlight/access_controls_enforcement_search_builder_spec.rb +0 -2
  120. data/spec/models/spotlight/blacklight_configuration_spec.rb +10 -2
  121. data/spec/models/spotlight/contact_email_spec.rb +0 -8
  122. data/spec/models/spotlight/contact_form_spec.rb +0 -2
  123. data/spec/models/spotlight/contact_spec.rb +0 -2
  124. data/spec/models/spotlight/custom_field_spec.rb +0 -1
  125. data/spec/models/spotlight/default_thumbnailable_concern_spec.rb +0 -2
  126. data/spec/models/spotlight/exhibit_spec.rb +0 -2
  127. data/spec/models/spotlight/feature_page_spec.rb +0 -2
  128. data/spec/models/spotlight/featured_image_spec.rb +0 -2
  129. data/spec/models/spotlight/field_metadata_spec.rb +0 -2
  130. data/spec/models/spotlight/filter_spec.rb +0 -2
  131. data/spec/models/spotlight/home_page_spec.rb +0 -2
  132. data/spec/models/spotlight/image_derivatives_spec.rb +0 -2
  133. data/spec/models/spotlight/main_navigation_spec.rb +0 -2
  134. data/spec/models/spotlight/masthead_spec.rb +0 -2
  135. data/spec/models/spotlight/page_spec.rb +0 -2
  136. data/spec/models/spotlight/reindex_progress_spec.rb +0 -2
  137. data/spec/models/spotlight/resource_spec.rb +0 -2
  138. data/spec/models/spotlight/role_spec.rb +0 -2
  139. data/spec/models/spotlight/search_spec.rb +0 -2
  140. data/spec/models/spotlight/site_spec.rb +0 -2
  141. data/spec/models/spotlight/sitemap_spec.rb +0 -1
  142. data/spec/models/spotlight/solr_document_sidecar_spec.rb +0 -2
  143. data/spec/models/spotlight/user_spec.rb +0 -2
  144. data/spec/routing/spotlight/exhibit_catalog_spec.rb +0 -1
  145. data/spec/routing/spotlight/pages_routing_spec.rb +30 -34
  146. data/spec/serializers/spotlight/exhibit_export_serializer_spec.rb +0 -2
  147. data/spec/services/spotlight/carrierwave_file_resolver_spec.rb +14 -0
  148. data/spec/spec_helper.rb +8 -2
  149. data/spec/uploaders/spotlight/item_uploader_spec.rb +0 -1
  150. data/spec/views/_user_util_links.html.erb_spec.rb +70 -74
  151. data/spec/views/shared/_analytics.html.erb_spec.rb +10 -15
  152. data/spec/views/shared/_exhibit_navbar.html.erb_spec.rb +0 -2
  153. data/spec/views/shared/_footer.html.erb_spec.rb +15 -19
  154. data/spec/views/shared/_header_navbar.html.erb_spec.rb +7 -12
  155. data/spec/views/shared/_masthead.html.erb_spec.rb +0 -13
  156. data/spec/views/spotlight/roles/index.html.erb_spec.rb +6 -5
  157. data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb_spec.rb +1 -1
  158. metadata +37 -30
  159. data/app/views/spotlight/contact_forms/show.html.erb +0 -4
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::DefaultThumbnailable do
4
2
  let(:test_class) { Class.new }
5
3
  subject { test_class.new }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Exhibit, type: :model do
4
2
  subject { FactoryGirl.build(:exhibit, title: 'Sample') }
5
3
 
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::FeaturePage, type: :model do
4
2
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
3
  describe 'default_scope' do
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::FeaturedImage do
4
2
  context 'with an uploaded resource' do
5
3
  subject { described_class.new }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::FieldMetadata do
4
2
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
3
  let(:repository) { double }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Filter do
4
2
  context 'with a simple string field' do
5
3
  subject { described_class.new(field: 'x', value: 'y') }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::HomePage, type: :model do
4
2
  let(:home_page) { FactoryGirl.create(:home_page) }
5
3
  it { is_expected.not_to be_feature_page }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  class TestSpotlightImageDerivatives
4
2
  include Spotlight::ImageDerivatives
5
3
  end
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::MainNavigation, type: :model do
4
2
  before do
5
3
  subject.exhibit = FactoryGirl.create(:exhibit)
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Masthead, type: :model do
4
2
  describe '#masthead_exists?' do
5
3
  let(:masthead) { stub_model(described_class) }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Page, type: :model do
4
2
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
3
  let!(:parent_page) { Spotlight::FeaturePage.create! exhibit: exhibit, published: true }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::ReindexProgress, type: :model do
4
2
  let(:start_time) { 20.minutes.ago }
5
3
  let(:finish_time) { 5.minutes.ago }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Resource, type: :model do
4
2
  before do
5
3
  allow_any_instance_of(described_class).to receive(:update_index)
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Role, type: :model do
4
2
  describe 'validations' do
5
3
  subject { described_class.new(args) }
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Search, type: :model do
4
2
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
3
 
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::Site do
4
2
  describe '.instance' do
5
3
  it 'is a singleton' do
@@ -1,4 +1,3 @@
1
- require 'spec_helper'
2
1
  require 'sitemap_generator'
3
2
 
4
3
  describe Spotlight::Sitemap do
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::SolrDocumentSidecar, type: :model do
4
2
  let(:exhibit) { FactoryGirl.create(:exhibit) }
5
3
  before do
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::User do
4
2
  subject { Class.new }
5
3
  before { subject.extend described_class }
@@ -1,4 +1,3 @@
1
- require 'spec_helper'
2
1
 
3
2
  module Spotlight
4
3
  describe 'Catalog controller', type: :routing do
@@ -1,44 +1,40 @@
1
- require 'spec_helper'
1
+ describe 'FeaturePagesController and AboutPagesController', type: :routing do
2
+ describe 'routing' do
3
+ routes { Spotlight::Engine.routes }
2
4
 
3
- module Spotlight
4
- describe 'FeaturePagesController and AboutPagesController', type: :routing do
5
- describe 'routing' do
6
- routes { Spotlight::Engine.routes }
7
-
8
- it 'routes to #index' do
9
- expect(get('/1/feature')).to route_to('spotlight/feature_pages#index', exhibit_id: '1')
10
- expect(get('/1/about')).to route_to('spotlight/about_pages#index', exhibit_id: '1')
11
- end
5
+ it 'routes to #index' do
6
+ expect(get('/1/feature')).to route_to('spotlight/feature_pages#index', exhibit_id: '1')
7
+ expect(get('/1/about')).to route_to('spotlight/about_pages#index', exhibit_id: '1')
8
+ end
12
9
 
13
- it 'routes to #new' do
14
- expect(get('/1/feature/new')).to route_to('spotlight/feature_pages#new', exhibit_id: '1')
15
- expect(get('/1/about/new')).to route_to('spotlight/about_pages#new', exhibit_id: '1')
16
- end
10
+ it 'routes to #new' do
11
+ expect(get('/1/feature/new')).to route_to('spotlight/feature_pages#new', exhibit_id: '1')
12
+ expect(get('/1/about/new')).to route_to('spotlight/about_pages#new', exhibit_id: '1')
13
+ end
17
14
 
18
- it 'routes to #show' do
19
- expect(get('/1/feature/2')).to route_to('spotlight/feature_pages#show', id: '2', exhibit_id: '1')
20
- expect(get('/1/about/2')).to route_to('spotlight/about_pages#show', id: '2', exhibit_id: '1')
21
- end
15
+ it 'routes to #show' do
16
+ expect(get('/1/feature/2')).to route_to('spotlight/feature_pages#show', id: '2', exhibit_id: '1')
17
+ expect(get('/1/about/2')).to route_to('spotlight/about_pages#show', id: '2', exhibit_id: '1')
18
+ end
22
19
 
23
- it 'routes to #edit' do
24
- expect(get('/1/feature/2/edit')).to route_to('spotlight/feature_pages#edit', id: '2', exhibit_id: '1')
25
- expect(get('/1/about/2/edit')).to route_to('spotlight/about_pages#edit', id: '2', exhibit_id: '1')
26
- end
20
+ it 'routes to #edit' do
21
+ expect(get('/1/feature/2/edit')).to route_to('spotlight/feature_pages#edit', id: '2', exhibit_id: '1')
22
+ expect(get('/1/about/2/edit')).to route_to('spotlight/about_pages#edit', id: '2', exhibit_id: '1')
23
+ end
27
24
 
28
- it 'routes to #create' do
29
- expect(post('/1/feature')).to route_to('spotlight/feature_pages#create', exhibit_id: '1')
30
- expect(post('/1/about')).to route_to('spotlight/about_pages#create', exhibit_id: '1')
31
- end
25
+ it 'routes to #create' do
26
+ expect(post('/1/feature')).to route_to('spotlight/feature_pages#create', exhibit_id: '1')
27
+ expect(post('/1/about')).to route_to('spotlight/about_pages#create', exhibit_id: '1')
28
+ end
32
29
 
33
- it 'routes to #update' do
34
- expect(put('/1/feature/2')).to route_to('spotlight/feature_pages#update', id: '2', exhibit_id: '1')
35
- expect(put('/1/about/2')).to route_to('spotlight/about_pages#update', id: '2', exhibit_id: '1')
36
- end
30
+ it 'routes to #update' do
31
+ expect(put('/1/feature/2')).to route_to('spotlight/feature_pages#update', id: '2', exhibit_id: '1')
32
+ expect(put('/1/about/2')).to route_to('spotlight/about_pages#update', id: '2', exhibit_id: '1')
33
+ end
37
34
 
38
- it 'routes to #destroy' do
39
- expect(delete('/1/feature/2')).to route_to('spotlight/feature_pages#destroy', id: '2', exhibit_id: '1')
40
- expect(delete('/1/about/2')).to route_to('spotlight/about_pages#destroy', id: '2', exhibit_id: '1')
41
- end
35
+ it 'routes to #destroy' do
36
+ expect(delete('/1/feature/2')).to route_to('spotlight/feature_pages#destroy', id: '2', exhibit_id: '1')
37
+ expect(delete('/1/about/2')).to route_to('spotlight/about_pages#destroy', id: '2', exhibit_id: '1')
42
38
  end
43
39
  end
44
40
  end
@@ -1,5 +1,3 @@
1
- require 'spec_helper'
2
-
3
1
  describe Spotlight::ExhibitExportSerializer do
4
2
  let!(:source_exhibit) { FactoryGirl.create(:exhibit) }
5
3
 
@@ -0,0 +1,14 @@
1
+ require 'spec_helper'
2
+
3
+ RSpec.describe Spotlight::CarrierwaveFileResolver do
4
+ let(:masthead) { FactoryGirl.create(:masthead) }
5
+ let(:resolver) { described_class.new }
6
+
7
+ describe 'finding the file' do
8
+ subject { Riiif::Image.file_resolver.find(masthead.id) }
9
+
10
+ it 'is found' do
11
+ expect(subject).to be_kind_of Riiif::File
12
+ end
13
+ end
14
+ end
data/spec/spec_helper.rb CHANGED
@@ -68,8 +68,14 @@ RSpec.configure do |config|
68
68
 
69
69
  config.filter_run_excluding js: true if ENV['CI']
70
70
 
71
- config.include Devise::TestHelpers, type: :controller
72
- config.include Devise::TestHelpers, type: :view
71
+ if defined? Devise::Test::ControllerHelpers
72
+ config.include Devise::Test::ControllerHelpers, type: :controller
73
+ config.include Devise::Test::ControllerHelpers, type: :view
74
+ else
75
+ config.include Devise::TestHelpers, type: :controller
76
+ config.include Devise::TestHelpers, type: :view
77
+ end
78
+
73
79
  config.include Spotlight::TestViewHelpers, type: :view
74
80
  config.include Warden::Test::Helpers, type: :feature
75
81
 
@@ -1,4 +1,3 @@
1
- require 'spec_helper'
2
1
  require 'carrierwave/test/matchers'
3
2
 
4
3
  describe Spotlight::ItemUploader do
@@ -1,89 +1,85 @@
1
- require 'spec_helper'
1
+ describe '_user_util_links', type: :view do
2
+ let(:current_exhibit) { FactoryGirl.create(:exhibit) }
3
+ before do
4
+ allow(view).to receive(:blacklight_config).and_return(Blacklight::Configuration.new)
5
+ allow(view).to receive(:current_user).and_return(current_user)
6
+ allow(view).to receive(:current_exhibit).and_return(current_exhibit)
7
+ allow(view).to receive_messages(show_contact_form?: true)
8
+ end
2
9
 
3
- module Spotlight
4
- describe '_user_util_links', type: :view do
5
- let(:current_exhibit) { FactoryGirl.create(:exhibit) }
6
- before do
7
- allow(view).to receive(:blacklight_config).and_return(Blacklight::Configuration.new)
8
- allow(view).to receive(:current_user).and_return(current_user)
9
- allow(view).to receive(:current_exhibit).and_return(current_exhibit)
10
- allow(view).to receive_messages(show_contact_form?: true)
10
+ describe 'when user is not logged in' do
11
+ let(:current_user) { nil }
12
+ it 'renders the links' do
13
+ render
14
+ expect(rendered).to have_link 'Sign in'
15
+ expect(rendered).to have_link 'Feedback'
11
16
  end
17
+ end
12
18
 
13
- describe 'when user is not logged in' do
14
- let(:current_user) { nil }
15
- it 'renders the links' do
16
- render
17
- expect(rendered).to have_link 'Sign in'
18
- expect(rendered).to have_link 'Feedback'
19
- end
19
+ describe 'when show_contact_form is false' do
20
+ let(:current_user) { nil }
21
+ before do
22
+ allow(view).to receive_messages(show_contact_form?: false)
20
23
  end
24
+ it 'does not render the feedback link' do
25
+ render
26
+ expect(rendered).to_not have_link 'Feedback'
27
+ end
28
+ end
21
29
 
22
- describe 'when show_contact_form is false' do
23
- let(:current_user) { nil }
24
- before do
25
- allow(view).to receive_messages(show_contact_form?: false)
26
- end
27
-
28
- it 'does not render the feedback link' do
29
- render
30
- expect(rendered).to_not have_link 'Feedback'
31
- end
30
+ describe 'when user is logged in' do
31
+ let(:current_user) { Spotlight::Engine.user_class.new }
32
+ it 'renders the links' do
33
+ render
34
+ expect(rendered).to have_link 'Feedback'
35
+ expect(rendered).to_not have_link 'Dashboard'
36
+ expect(rendered).to have_link 'Sign out'
32
37
  end
38
+ end
33
39
 
34
- describe 'when user is logged in' do
35
- let(:current_user) { Spotlight::Engine.user_class.new }
36
- it 'renders the links' do
37
- render
38
- expect(rendered).to have_link 'Feedback'
39
- expect(rendered).to_not have_link 'Dashboard'
40
- expect(rendered).to have_link 'Sign out'
41
- end
40
+ describe 'when user is a curator' do
41
+ let(:current_user) { Spotlight::Engine.user_class.new }
42
+ before do
43
+ allow(view).to receive(:can?).with(:update, current_exhibit).and_return(false)
44
+ allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(false)
45
+ allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
46
+ end
47
+ it 'renders the links' do
48
+ render
49
+ expect(rendered).to have_link 'Feedback'
50
+ expect(rendered).to have_link 'Dashboard'
51
+ expect(rendered).to have_link 'Sign out'
42
52
  end
53
+ end
43
54
 
44
- describe 'when user is a curator' do
45
- let(:current_user) { Spotlight::Engine.user_class.new }
46
- before do
47
- allow(view).to receive(:can?).with(:update, current_exhibit).and_return(false)
48
- allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(false)
49
- allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
50
- end
51
- it 'renders the links' do
52
- render
53
- expect(rendered).to have_link 'Feedback'
54
- expect(rendered).to have_link 'Dashboard'
55
- expect(rendered).to have_link 'Sign out'
56
- end
55
+ describe 'when user is an admin' do
56
+ let(:current_user) { Spotlight::Engine.user_class.new }
57
+ before do
58
+ allow(view).to receive(:can?).with(:update, current_exhibit).and_return(true)
59
+ allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(false)
60
+ allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
57
61
  end
58
- describe 'when user is an admin' do
59
- let(:current_user) { Spotlight::Engine.user_class.new }
60
- before do
61
- allow(view).to receive(:can?).with(:update, current_exhibit).and_return(true)
62
- allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(false)
63
- allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
64
- end
65
- it 'renders the links' do
66
- render
67
- expect(rendered).to have_link 'Feedback'
68
- expect(rendered).to have_link 'Dashboard'
69
- expect(rendered).to have_link 'Sign out'
70
- end
62
+ it 'renders the links' do
63
+ render
64
+ expect(rendered).to have_link 'Feedback'
65
+ expect(rendered).to have_link 'Dashboard'
66
+ expect(rendered).to have_link 'Sign out'
71
67
  end
68
+ end
72
69
 
73
- describe 'when user is a site-wide admin' do
74
- let(:current_user) { Spotlight::Engine.user_class.new }
75
- before do
76
- allow(view).to receive(:can?).with(:update, current_exhibit).and_return(true)
77
- allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(true)
78
- allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
79
- end
80
- it 'renders the links' do
81
- render
82
- expect(rendered).to have_link 'Feedback'
83
- expect(rendered).to have_link 'Dashboard'
84
- expect(rendered).to have_link 'Create Exhibit'
85
- expect(rendered).to have_link 'Sign out'
86
- end
70
+ describe 'when user is a site-wide admin' do
71
+ let(:current_user) { Spotlight::Engine.user_class.new }
72
+ before do
73
+ allow(view).to receive(:can?).with(:update, current_exhibit).and_return(true)
74
+ allow(view).to receive(:can?).with(:create, Spotlight::Exhibit).and_return(true)
75
+ allow(view).to receive(:can?).with(:curate, current_exhibit).and_return(true)
76
+ end
77
+ it 'renders the links' do
78
+ render
79
+ expect(rendered).to have_link 'Feedback'
80
+ expect(rendered).to have_link 'Dashboard'
81
+ expect(rendered).to have_link 'Create Exhibit'
82
+ expect(rendered).to have_link 'Sign out'
87
83
  end
88
84
  end
89
85
  end
@@ -1,17 +1,12 @@
1
- require 'spec_helper'
2
-
3
- module Spotlight
4
- describe 'shared/_analytics', type: :view do
5
- it 'is empty without Google Analytics configured' do
6
- render
7
- expect(rendered).to be_empty
8
- end
9
-
10
- it 'renders the GA script tag if the web property id is configured' do
11
- allow(Spotlight::Engine.config).to receive(:ga_web_property_id).and_return('XYZ-234')
12
- render
13
- expect(rendered).to have_selector 'script', visible: false
14
- expect(rendered).to have_content 'XYZ-234'
15
- end
1
+ describe 'shared/_analytics', type: :view do
2
+ it 'is empty without Google Analytics configured' do
3
+ render
4
+ expect(rendered).to be_empty
5
+ end
6
+ it 'renders the GA script tag if the web property id is configured' do
7
+ allow(Spotlight::Engine.config).to receive(:ga_web_property_id).and_return('XYZ-234')
8
+ render
9
+ expect(rendered).to have_selector 'script', visible: false
10
+ expect(rendered).to have_content 'XYZ-234'
16
11
  end
17
12
  end