sufia 3.7.2 → 4.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (275) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +1 -1
  3. data/Gemfile +3 -0
  4. data/README.md +88 -11
  5. data/SUFIA_VERSION +1 -1
  6. data/app/assets/images/old_main_tulips.jpg +0 -0
  7. data/app/assets/javascripts/contact_form.js +0 -16
  8. data/app/assets/javascripts/jquery.blacklightTagCloud.js +44 -0
  9. data/app/assets/javascripts/jquery.tagcloud.js +116 -0
  10. data/app/assets/javascripts/jquery.tinysort.min.js +7 -0
  11. data/app/assets/javascripts/sufia.js +41 -44
  12. data/app/assets/javascripts/sufia/edit_metadata.js +1 -1
  13. data/app/assets/javascripts/sufia/editor.js +12 -0
  14. data/app/assets/javascripts/sufia/featured_works.js +64 -0
  15. data/app/assets/javascripts/sufia/fileupload.js +1 -1
  16. data/app/assets/javascripts/sufia/multiForm.js +1 -1
  17. data/app/assets/javascripts/sufia/permissions.js +4 -8
  18. data/app/assets/javascripts/sufia/single_use_link.js +1 -2
  19. data/app/assets/javascripts/sufia/trophy.js +42 -27
  20. data/app/assets/javascripts/terms_of_service.js +1 -1
  21. data/app/assets/stylesheets/dashboard.css.scss +81 -40
  22. data/app/assets/stylesheets/featured.css.scss +16 -0
  23. data/app/assets/stylesheets/fileupload/{jquery.fileupload-ui.css → jquery.fileupload-ui.css.erb} +2 -2
  24. data/app/assets/stylesheets/{generic_files.css → generic_files.css.erb} +6 -7
  25. data/app/assets/stylesheets/header.css.scss +93 -0
  26. data/app/assets/stylesheets/home-page.css.scss +50 -0
  27. data/app/assets/stylesheets/nestable.css.scss +111 -0
  28. data/app/assets/stylesheets/styles.css.scss +106 -0
  29. data/app/assets/stylesheets/sufia.css.scss +13 -8
  30. data/app/assets/stylesheets/tagcloud.css +83 -0
  31. data/app/assets/stylesheets/usage-stats.css +30 -0
  32. data/app/controllers/batch_controller.rb +0 -1
  33. data/app/controllers/concerns/sufia/catalog.rb +64 -0
  34. data/app/controllers/concerns/sufia/dashboard_controller_behavior.rb +16 -13
  35. data/app/controllers/content_blocks_controller.rb +8 -0
  36. data/app/controllers/featured_work_lists_controller.rb +16 -0
  37. data/app/controllers/featured_works_controller.rb +26 -0
  38. data/app/controllers/mailbox_controller.rb +1 -1
  39. data/app/controllers/pages_controller.rb +7 -0
  40. data/app/controllers/single_use_links_viewer_controller.rb +2 -5
  41. data/app/controllers/tinymce_assets_controller.rb +12 -0
  42. data/app/helpers/content_block_helper.rb +21 -0
  43. data/app/helpers/generic_file_helper.rb +2 -2
  44. data/app/helpers/sufia_helper.rb +8 -4
  45. data/app/helpers/trophy_helper.rb +15 -7
  46. data/app/models/content_block.rb +2 -0
  47. data/app/models/featured_work_list.rb +42 -0
  48. data/app/models/tinymce_asset.rb +3 -0
  49. data/app/uploaders/tinymce_asset_uploader.rb +51 -0
  50. data/app/views/_add_assets_links.html.erb +0 -16
  51. data/app/views/_controls.html.erb +17 -0
  52. data/app/views/_flash_msg.html.erb +2 -18
  53. data/app/views/_footer.html.erb +10 -15
  54. data/app/views/_ga.html.erb +0 -16
  55. data/app/views/_logo.html.erb +2 -2
  56. data/app/views/_masthead.html.erb +9 -36
  57. data/app/views/_user_util_links.html.erb +16 -11
  58. data/app/views/advanced/_advanced_search_facets.html.erb +0 -16
  59. data/app/views/advanced/_advanced_search_fields.html.erb +0 -16
  60. data/app/views/advanced/_advanced_search_help.html.erb +0 -16
  61. data/app/views/advanced/_facet_layout.html.erb +0 -16
  62. data/app/views/advanced/_facet_limit.html.erb +0 -16
  63. data/app/views/advanced/index.html.erb +2 -18
  64. data/app/views/batch/_metadata.html.erb +3 -3
  65. data/app/views/batch/edit.html.erb +4 -21
  66. data/app/views/catalog/_facet_limit.html.erb +11 -12
  67. data/app/views/catalog/_featured_researcher.html.erb +2 -0
  68. data/app/views/catalog/_home.html.erb +6 -2
  69. data/app/views/catalog/_home_content.html.erb +36 -0
  70. data/app/views/catalog/_home_header.html.erb +15 -0
  71. data/app/views/catalog/_recent_document.html.erb +1 -1
  72. data/app/views/catalog/_recents.html.erb +3 -4
  73. data/app/views/catalog/_search_form.html.erb +13 -9
  74. data/app/views/catalog/_tagcloud.html.erb +7 -0
  75. data/app/views/catalog/index.html.erb +4 -10
  76. data/app/views/contact_form/create.html.erb +0 -16
  77. data/app/views/contact_form/new.html.erb +0 -16
  78. data/app/views/dashboard/_constraints.html.erb +3 -19
  79. data/app/views/dashboard/_did_you_mean.html.erb +0 -16
  80. data/app/views/dashboard/_document_list.html.erb +0 -16
  81. data/app/views/dashboard/_facet_layout.html.erb +1 -17
  82. data/app/views/dashboard/_facet_limit.html.erb +5 -5
  83. data/app/views/dashboard/_facet_selected.html.erb +1 -17
  84. data/app/views/dashboard/_facets.html.erb +0 -18
  85. data/app/views/dashboard/_heading.html.erb +1 -1
  86. data/app/views/dashboard/_index_partials/_default_group.html.erb +7 -23
  87. data/app/views/dashboard/_index_partials/_list_files.html.erb +62 -57
  88. data/app/views/dashboard/_search_form.html.erb +10 -7
  89. data/app/views/dashboard/_show_partials/_default.html.erb +0 -18
  90. data/app/views/dashboard/_show_partials/_default_details.html.erb +0 -16
  91. data/app/views/dashboard/_show_partials/_facets.html.erb +0 -16
  92. data/app/views/dashboard/_sort_and_per_page.html.erb +10 -9
  93. data/app/views/dashboard/facet.html.erb +4 -19
  94. data/app/views/dashboard/index.html.erb +27 -49
  95. data/app/views/error/401.html.erb +1 -17
  96. data/app/views/error/404.html.erb +0 -16
  97. data/app/views/error/500.html.erb +0 -16
  98. data/app/views/error/single_use_error.html.erb +1 -17
  99. data/app/views/generic_files/_asset_deleted_flash.html.erb +0 -16
  100. data/app/views/generic_files/_asset_permissions_denial_flash.html.erb +0 -16
  101. data/app/views/generic_files/_asset_saved_flash.html.erb +0 -16
  102. data/app/views/generic_files/_asset_updated_flash.html.erb +0 -16
  103. data/app/views/generic_files/_breadcrumbs.html.erb +0 -16
  104. data/app/views/generic_files/_browse_everything.html.erb +24 -0
  105. data/app/views/generic_files/_descriptions.html.erb +1 -1
  106. data/app/views/generic_files/_field_form.html.erb +5 -5
  107. data/app/views/generic_files/_media_display.html.erb +3 -3
  108. data/app/views/generic_files/_permission_form.html.erb +5 -5
  109. data/app/views/generic_files/_rights_modal.html.erb +13 -29
  110. data/app/views/generic_files/_show_actions.html.erb +13 -1
  111. data/app/views/generic_files/_versioning.html.erb +14 -10
  112. data/app/views/generic_files/citation.html.erb +0 -16
  113. data/app/views/generic_files/edit.html.erb +10 -12
  114. data/app/views/generic_files/edit_fields/_default.html.erb +1 -1
  115. data/app/views/generic_files/edit_fields/_description.html.erb +1 -1
  116. data/app/views/generic_files/edit_fields/_resource_type.html.erb +2 -3
  117. data/app/views/generic_files/edit_fields/_rights.html.erb +1 -1
  118. data/app/views/generic_files/new.html.erb +11 -26
  119. data/app/views/generic_files/show.html.erb +7 -25
  120. data/app/views/generic_files/stats.html.erb +141 -0
  121. data/app/views/homepage/_featured.html.erb +11 -0
  122. data/app/views/homepage/_featured_fields.html.erb +18 -0
  123. data/app/views/homepage/_featured_works.html.erb +17 -0
  124. data/app/views/homepage/_sortable_featured.html.erb +26 -0
  125. data/app/views/layouts/_head_tag_content.html.erb +1 -1
  126. data/app/views/layouts/_homepage_sidebar2.html.erb +14 -0
  127. data/app/views/layouts/error.html.erb +3 -21
  128. data/app/views/layouts/homepage.html.erb +8 -37
  129. data/app/views/layouts/sufia-dashboard.html.erb +46 -0
  130. data/app/views/layouts/sufia-one-column.html.erb +8 -24
  131. data/app/views/layouts/sufia-two-column.html.erb +9 -8
  132. data/app/views/pages/show.html.erb +4 -0
  133. data/app/views/single_use_links_viewer/show.html.erb +2 -2
  134. data/app/views/static/agreement.html.erb +0 -17
  135. data/app/views/static/help.html.erb +0 -17
  136. data/app/views/static/mendeley.html.erb +0 -16
  137. data/app/views/static/subject_libraries.html.erb +0 -17
  138. data/app/views/static/terms.html.erb +0 -16
  139. data/app/views/static/zotero.html.erb +0 -16
  140. data/app/views/users/_activity_log.html.erb +2 -2
  141. data/app/views/users/_contributions.html.erb +6 -2
  142. data/app/views/users/_follower_modal.html.erb +2 -2
  143. data/app/views/users/_following_modal.html.erb +2 -2
  144. data/app/views/users/_left_sidebar.html.erb +1 -1
  145. data/app/views/users/_notify_link.html.erb +1 -1
  146. data/app/views/users/_notify_number.html.erb +1 -1
  147. data/app/views/users/_profile_actions.html.erb +3 -3
  148. data/app/views/users/_profile_tabs.html.erb +1 -1
  149. data/app/views/users/_search_form.html.erb +3 -2
  150. data/app/views/users/_social_media_info.html.erb +3 -3
  151. data/app/views/users/_trophy_edit.html.erb +2 -2
  152. data/app/views/users/_user_info.html.erb +27 -27
  153. data/app/views/users/_vitals.html.erb +2 -2
  154. data/app/views/users/edit.html.erb +39 -39
  155. data/app/views/users/index.html.erb +3 -3
  156. data/app/views/users/show.html.erb +7 -9
  157. data/config/locales/sufia.en.yml +15 -7
  158. data/config/routes.rb +12 -9
  159. data/lib/generators/sufia/sufia_generator.rb +18 -15
  160. data/lib/generators/sufia/templates/catalog_controller.rb +11 -73
  161. data/lib/generators/sufia/templates/config/tinymce.yml +7 -0
  162. data/lib/sufia.rb +7 -0
  163. data/lib/sufia/downloads_controller_behavior.rb +3 -4
  164. data/lib/sufia/files_controller_behavior.rb +38 -27
  165. data/lib/sufia/version.rb +1 -1
  166. data/spec/controllers/batch_controller_spec.rb +1 -1
  167. data/spec/controllers/batch_edits_controller_spec.rb +5 -5
  168. data/spec/controllers/catalog_controller_spec.rb +37 -58
  169. data/spec/controllers/content_blocks_controller_spec.rb +37 -0
  170. data/spec/controllers/downloads_controller_spec.rb +3 -11
  171. data/spec/controllers/featured_work_lists_controller_spec.rb +20 -0
  172. data/spec/controllers/featured_works_controller_spec.rb +50 -0
  173. data/spec/controllers/generic_files_controller_spec.rb +74 -9
  174. data/spec/controllers/mailbox_controller_spec.rb +1 -1
  175. data/spec/controllers/pages_controller_spec.rb +25 -0
  176. data/spec/controllers/single_use_links_controller_spec.rb +1 -1
  177. data/spec/controllers/single_use_links_viewer_controller_spec.rb +1 -1
  178. data/spec/controllers/tinymce_assets_controller_spec.rb +39 -0
  179. data/spec/controllers/users_controller_spec.rb +3 -8
  180. data/spec/factories/content_blocks.rb +4 -0
  181. data/spec/factories/featured_works.rb +4 -0
  182. data/spec/factories/generic_files.rb +46 -39
  183. data/spec/factories/users.rb +18 -18
  184. data/spec/features/browse_dashboard_files_spec.rb +6 -7
  185. data/spec/features/browse_files_spec.rb +9 -6
  186. data/spec/features/cloud_upload_spec.rb +18 -0
  187. data/spec/features/single_use_links_spec.rb +2 -3
  188. data/spec/helpers/content_block_helper_spec.rb +31 -0
  189. data/spec/helpers/generic_file_helper_spec.rb +3 -3
  190. data/spec/helpers/sufia_helper_spec.rb +13 -81
  191. data/spec/helpers/trophy_helper_spec.rb +39 -0
  192. data/spec/jobs/import_url_job_spec.rb +1 -1
  193. data/spec/jobs/ingest_local_file_job_spec.rb +1 -1
  194. data/spec/lib/sufia/usage_statistics_spec.rb +75 -0
  195. data/spec/models/ability_spec.rb +31 -0
  196. data/spec/models/active_fedora_pid_based_job_spec.rb +1 -1
  197. data/spec/models/audit_job_spec.rb +1 -1
  198. data/spec/models/batch_spec.rb +1 -1
  199. data/spec/models/batch_update_job_spec.rb +1 -1
  200. data/spec/models/event_jobs_spec.rb +1 -1
  201. data/spec/models/featured_work_list_spec.rb +23 -0
  202. data/spec/models/featured_work_spec.rb +42 -0
  203. data/spec/models/fits_datastream_spec.rb +2 -2
  204. data/spec/models/generic_file/reload_on_save_spec.rb +1 -1
  205. data/spec/models/generic_file/web_form_spec.rb +4 -4
  206. data/spec/models/generic_file_spec.rb +41 -40
  207. data/spec/models/pageview.rb +19 -0
  208. data/spec/models/properties_datastream_spec.rb +2 -2
  209. data/spec/models/solr_document_spec.rb +9 -0
  210. data/spec/models/user_spec.rb +2 -2
  211. data/spec/routing/featured_works_route_spec.rb +16 -0
  212. data/spec/routing/route_spec.rb +10 -15
  213. data/spec/spec_helper.rb +3 -0
  214. data/spec/support/lib/generators/test_app_generator.rb +19 -8
  215. data/spec/views/dashboard/facet_limit.html.erb_spec.rb +2 -2
  216. data/spec/views/generic_file/show.html.erb_spec.rb +44 -0
  217. data/spec/views/generic_file/stats.html.erb_spec.rb +47 -0
  218. data/spec/views/users/_follower_modal.html.erb_spec.rb +18 -0
  219. data/spec/views/users/_following_modal.html.erb_spec.rb +18 -0
  220. data/spec/views/users/index.html.erb_spec.rb +1 -1
  221. data/sufia-models/app/models/batch.rb +1 -1
  222. data/sufia-models/app/models/concerns/sufia/properties_datastream_behavior.rb +30 -0
  223. data/sufia-models/app/models/concerns/sufia/user.rb +1 -1
  224. data/sufia-models/app/models/datastreams/batch_rdf_datastream.rb +4 -7
  225. data/sufia-models/app/models/datastreams/fits_datastream.rb +3 -0
  226. data/sufia-models/app/models/datastreams/generic_file_rdf_datastream.rb +53 -51
  227. data/sufia-models/app/models/datastreams/properties_datastream.rb +1 -15
  228. data/sufia-models/app/models/featured_work.rb +22 -0
  229. data/sufia-models/app/models/sufia/pageview.rb +9 -0
  230. data/sufia-models/{lib/sufia/models → app/services/sufia}/id_service.rb +0 -0
  231. data/sufia-models/{lib/sufia/models → app/services/sufia}/noid.rb +0 -0
  232. data/sufia-models/app/services/sufia/usage_statistics.rb +73 -0
  233. data/sufia-models/config/locales/sufia.en.yml +3 -4
  234. data/sufia-models/lib/generators/sufia/models/install_generator.rb +23 -8
  235. data/sufia-models/lib/generators/sufia/models/templates/config/analytics.yml +9 -0
  236. data/sufia-models/lib/generators/sufia/models/templates/config/mime_types.rb +6 -0
  237. data/sufia-models/lib/generators/sufia/models/templates/config/sufia.rb +11 -2
  238. data/sufia-models/lib/generators/sufia/models/templates/migrations/create_content_blocks.rb +10 -0
  239. data/sufia-models/lib/generators/sufia/models/templates/migrations/create_featured_works.rb +12 -0
  240. data/sufia-models/lib/generators/sufia/models/templates/migrations/create_tinymce_assets.rb +8 -0
  241. data/sufia-models/lib/generators/sufia/models/usagestats_generator.rb +19 -0
  242. data/sufia-models/lib/sufia/ability.rb +34 -0
  243. data/sufia-models/lib/sufia/models/engine.rb +5 -3
  244. data/sufia-models/lib/sufia/models/generic_file.rb +4 -2
  245. data/sufia-models/lib/sufia/models/generic_file/export.rb +3 -3
  246. data/sufia-models/lib/sufia/models/generic_file/featured.rb +14 -0
  247. data/sufia-models/lib/sufia/models/solr_document_behavior.rb +11 -4
  248. data/sufia-models/lib/sufia/models/version.rb +1 -1
  249. data/sufia-models/sufia-models.gemspec +6 -5
  250. data/sufia.gemspec +6 -4
  251. data/tasks/release.rake +1 -0
  252. data/tasks/sufia-dev.rake +5 -1
  253. data/vendor/assets/javascripts/flot/excanvas.js +1428 -0
  254. data/vendor/assets/javascripts/flot/jquery.flot.js +3137 -0
  255. data/vendor/assets/javascripts/flot/jquery.flot.selection.js +360 -0
  256. data/vendor/assets/javascripts/flot/jquery.flot.time.js +431 -0
  257. data/vendor/assets/javascripts/nestable.js +647 -0
  258. data/vendor/assets/javascripts/video.js +135 -126
  259. data/{app → vendor}/assets/stylesheets/video-js.css.erb +7 -6
  260. metadata +155 -33
  261. data/app/assets/stylesheets/application-bootstrap.css.erb +0 -295
  262. data/app/assets/stylesheets/audio-js.css +0 -3
  263. data/app/assets/stylesheets/blacklight_more_facets.css +0 -427
  264. data/app/assets/stylesheets/bootstrap.min.css.erb +0 -1433
  265. data/app/assets/stylesheets/contact_form.css +0 -4
  266. data/app/assets/stylesheets/reset_body.css +0 -4
  267. data/app/assets/stylesheets/trophy.css +0 -7
  268. data/app/helpers/blacklight/render_constraints_helper_behavior.rb +0 -84
  269. data/app/helpers/facets_helper.rb +0 -3
  270. data/app/helpers/sufia/facets_helper_behavior.rb +0 -23
  271. data/app/views/catalog/_home_text.html.erb +0 -10
  272. data/app/views/generic_files/_dropbox_import.html.erb +0 -3
  273. data/app/views/generic_files/upload/_dropbox_chooser.html.erb +0 -39
  274. data/app/views/static/about.html.erb +0 -21
  275. data/spec/helpers/render_constraints_helper_behavior_spec.rb +0 -42
@@ -0,0 +1,19 @@
1
+ require 'spec_helper'
2
+
3
+ describe Sufia::Pageview do
4
+ before do
5
+ @pageview = Sufia::Pageview
6
+ end
7
+
8
+ it 'has a pageviews metric' do
9
+ expect(@pageview.metrics).to be == Legato::ListParameter.new(:metrics, [:pageviews])
10
+ end
11
+
12
+ it 'has a date dimension' do
13
+ expect(@pageview.dimensions).to be == Legato::ListParameter.new(:dimensions, [:date])
14
+ end
15
+
16
+ it 'responds to :for_path' do
17
+ expect(@pageview).to respond_to(:for_path)
18
+ end
19
+ end
@@ -10,9 +10,9 @@ describe PropertiesDatastream do
10
10
 
11
11
  describe "to_solr" do
12
12
  before do
13
- @doc = PropertiesDatastream.new.tap do |ds|
13
+ @doc = PropertiesDatastream.new(nil, 'properties').tap do |ds|
14
14
  ds.import_url = 'http://example.com/somefile.txt'
15
- end
15
+ end
16
16
  end
17
17
  subject { @doc.to_solr}
18
18
  it "should have import_url" do
@@ -18,4 +18,13 @@ describe SolrDocument do
18
18
  subject.date_uploaded.should == '03/14/2013'
19
19
  end
20
20
  end
21
+
22
+ describe "to_param" do
23
+ before do
24
+ subject['noid_tsi'] = '1v53kn56d'
25
+ end
26
+ it "should be noid" do
27
+ expect(subject.to_param).to eq '1v53kn56d'
28
+ end
29
+ end
21
30
  end
@@ -2,7 +2,7 @@ require 'spec_helper'
2
2
 
3
3
  describe User do
4
4
  before(:all) do
5
- @user = FactoryGirl.find_or_create(:user)
5
+ @user = FactoryGirl.find_or_create(:jill)
6
6
  @another_user = FactoryGirl.find_or_create(:archivist)
7
7
  end
8
8
  after(:all) do
@@ -38,7 +38,7 @@ describe User do
38
38
  end
39
39
  describe "follow/unfollow" do
40
40
  before(:all) do
41
- @user = FactoryGirl.find_or_create(:user)
41
+ @user = FactoryGirl.find_or_create(:jill)
42
42
  @another_user = FactoryGirl.find_or_create(:archivist)
43
43
  @user.follow(@another_user)
44
44
  end
@@ -0,0 +1,16 @@
1
+ require 'spec_helper'
2
+
3
+ describe "file routes" do
4
+ routes { Sufia::Engine.routes }
5
+ it 'should create a featured_work' do
6
+ expect(post: '/files/1/featured_work').to route_to(controller: 'featured_works', action: 'create', id: '1')
7
+ end
8
+ it 'should remove a featured_work' do
9
+ expect(delete: '/files/1/featured_work').to route_to(controller: 'featured_works', action: 'destroy', id: '1')
10
+ end
11
+
12
+ it 'should update a collection of featured works' do
13
+ expect(featured_work_lists_path).to eq '/featured_works'
14
+ expect(post: '/featured_works').to route_to(controller: 'featured_work_lists', action: 'create')
15
+ end
16
+ end
@@ -1,21 +1,12 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe 'Routes' do
4
- before(:each) do
5
- @routes = Sufia::Engine.routes
6
- # so we have to do this instead:
7
- # engine routes broke in rspec rails 2.12.1, so we had to add this:
8
- assertion_instance.instance_variable_set(:@routes, @routes)
9
- end
4
+ routes { Sufia::Engine.routes }
5
+
10
6
  describe 'Catalog' do
11
-
12
7
  it 'should route the root url to the catalog controller' do
13
8
  { get: '/' }.should route_to(controller: 'catalog', action: 'index')
14
9
  end
15
-
16
- it 'should route to recently added files' do
17
- { get: '/catalog/recent' }.should route_to(controller: 'catalog', action: 'recent')
18
- end
19
10
  end
20
11
 
21
12
  describe 'GenericFile' do
@@ -23,6 +14,10 @@ describe 'Routes' do
23
14
  { get: '/files/1/citation' }.should route_to(controller: 'generic_files', action: 'citation', id: '1')
24
15
  end
25
16
 
17
+ it 'should route to stats' do
18
+ { get: '/files/1/stats' }.should route_to(controller: 'generic_files', action: 'stats', id: '1')
19
+ end
20
+
26
21
  it 'should route to audit' do
27
22
  { post: '/files/7/audit' }.should route_to(controller: 'generic_files', action: 'audit', id: '7')
28
23
  end
@@ -81,8 +76,6 @@ describe 'Routes' do
81
76
  { get: '/dashboard/facet/1' }.should route_to(controller: 'dashboard', action: 'facet', id: '1')
82
77
  end
83
78
 
84
-
85
-
86
79
  it "should route to dashboard activity" do
87
80
  { get: '/dashboard/activity' }.should route_to(controller: 'dashboard', action: 'activity')
88
81
  end
@@ -164,11 +157,13 @@ describe 'Routes' do
164
157
  end
165
158
  end
166
159
 
167
- describe "Static Pages" do
160
+ describe "Dynamically edited pages" do
168
161
  it "should route to about" do
169
- { get: '/about' }.should route_to(controller: 'static', action: 'about')
162
+ { get: '/about' }.should route_to(controller: 'pages', action: 'show', id: 'about_page')
170
163
  end
164
+ end
171
165
 
166
+ describe "Static Pages" do
172
167
  it "should route to help" do
173
168
  { get: '/help' }.should route_to(controller: 'static', action: 'help')
174
169
  end
data/spec/spec_helper.rb CHANGED
@@ -60,6 +60,9 @@ module EngineRoutes
60
60
  def self.included(base)
61
61
  base.routes { Sufia::Engine.routes }
62
62
  end
63
+ def main_app
64
+ Rails.application.class.routes.url_helpers
65
+ end
63
66
  end
64
67
 
65
68
  RSpec.configure do |config|
@@ -4,19 +4,30 @@ class TestAppGenerator < Rails::Generators::Base
4
4
  source_root File.expand_path("../../../../support", __FILE__)
5
5
 
6
6
  def run_sufia_generator
7
- say_status("warning", "GENERATING SUFIA", :yellow)
8
-
7
+ say_status("warning", "GENERATING SUFIA", :yellow)
9
8
  generate 'sufia', '-f'
10
-
9
+ generate "browse_everything:config"
11
10
  remove_file 'spec/factories/users.rb'
12
11
  end
13
12
 
14
- def remove_index_page
15
- remove_file 'public/index.html'
13
+ def add_analytics_config
14
+ append_file 'config/analytics.yml' do
15
+ "\n" +
16
+ "analytics:\n" +
17
+ " app_name: My App Name\n" +
18
+ " app_version: 0.0.1\n" +
19
+ " privkey_path: /tmp/privkey.p12\n" +
20
+ " privkey_secret: s00pers3kr1t\n" +
21
+ " client_email: oauth@example.org\n"
22
+ end
16
23
  end
17
24
 
18
- def copy_rspec_rake_task
19
- copy_file "lib/tasks/rspec.rake"
25
+ def add_sufia_assets
26
+ insert_into_file 'app/assets/stylesheets/application.css', after: ' *= require_self' do
27
+ "\n *= require sufia"
28
+ end
29
+
30
+ gsub_file 'app/assets/javascripts/application.js',
31
+ '//= require_tree .', '//= require sufia'
20
32
  end
21
-
22
33
  end
@@ -7,9 +7,9 @@ describe 'dashboard/_facet_limit.html.erb' do
7
7
  allow(view).to receive(:solr_field).and_return('desc_metadata__resource_type_sim')
8
8
  allow(view).to receive(:facet_limit_for).and_return(5)
9
9
  allow(view).to receive(:blacklight_config).and_return(DashboardController.blacklight_config)
10
+ allow(view).to receive(:search_action_path).and_return('/search')
10
11
  allow(view).to receive(:params).and_return({controller: 'dashboard'})
11
12
  render
12
- expect(rendered).to match /<a class="facet_select" href="\/dashboard\?f%5Bdesc_metadata__resource_type_sim%5D%5B%5D=Audio">Audio<\/a> <span class="count">3<\/span>/
13
-
13
+ expect(rendered).to include '<span class="facet-label"><a class="facet_select" href="/search">Audio</a></span><span class="facet-count">3</span>'
14
14
  end
15
15
  end
@@ -0,0 +1,44 @@
1
+ require 'spec_helper'
2
+
3
+ describe 'generic_files/show.html.erb' do
4
+ describe 'usage statistics' do
5
+ let(:generic_file) {
6
+ content = double('content', versions: [])
7
+ stub_model(GenericFile, noid: '123',
8
+ depositor: 'bob',
9
+ audit_stat: 1,
10
+ content: content)
11
+ }
12
+
13
+ before do
14
+ allow(controller).to receive(:current_user).and_return(stub_model(User))
15
+ allow_any_instance_of(Ability).to receive(:can?).and_return(true)
16
+ assign(:generic_file, generic_file)
17
+ assign(:events, [])
18
+ end
19
+
20
+ context 'when enabled' do
21
+ before do
22
+ Sufia.config.usage_statistics = true
23
+ end
24
+
25
+ it 'appears on page' do
26
+ render
27
+ page = Capybara::Node::Simple.new(rendered)
28
+ expect(page).to have_selector('a#stats', count: 1)
29
+ end
30
+ end
31
+
32
+ context 'when disabled' do
33
+ before do
34
+ Sufia.config.usage_statistics = false
35
+ end
36
+
37
+ it 'does not appear on page' do
38
+ render
39
+ page = Capybara::Node::Simple.new(rendered)
40
+ expect(page).to have_no_selector('a#stats')
41
+ end
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,47 @@
1
+ require 'spec_helper'
2
+
3
+ describe 'generic_files/stats.html.erb' do
4
+ describe 'usage statistics' do
5
+ let(:generic_file) {
6
+ stub_model(GenericFile, noid: '123',
7
+ title: 'file1.txt')
8
+ }
9
+
10
+ before do
11
+ assign(:generic_file, generic_file)
12
+ assign(:created, Date.parse('2014-01-01'))
13
+ assign(:stats_json, [].to_json)
14
+ end
15
+
16
+ it 'shows breadcrumbs' do
17
+ render
18
+ page = Capybara::Node::Simple.new(rendered)
19
+ expect(page).to have_selector('span.active', text: 'file1.txt')
20
+ end
21
+
22
+ context 'when no analytics results returned' do
23
+ before do
24
+ assign(:pageviews, 0)
25
+ end
26
+
27
+ it 'shows 0 visits' do
28
+ render
29
+ page = Capybara::Node::Simple.new(rendered)
30
+ expect(page).to have_selector('div.alert-info', text: /0 views since January 1, 2014/i, count: 1)
31
+ end
32
+ end
33
+
34
+ context 'when results are returned' do
35
+ before do
36
+ assign(:stats_json, [[1396422000000,2],[1396508400000,3],[1396594800000,4]].to_json)
37
+ assign(:pageviews, 9)
38
+ end
39
+
40
+ it 'shows visits' do
41
+ render
42
+ page = Capybara::Node::Simple.new(rendered)
43
+ expect(page).to have_selector('div.alert-info', text: /9 views since January 1, 2014/i, count: 1)
44
+ end
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,18 @@
1
+ require 'spec_helper'
2
+
3
+ describe 'users/_follower_modal.html.erb' do
4
+ let(:user) { FactoryGirl.create(:user, display_name: "Frank") }
5
+
6
+ before do
7
+ assign :followers, [user]
8
+ end
9
+
10
+ it "should draw user list" do
11
+ render
12
+ page = Capybara::Node::Simple.new(rendered)
13
+ expect(page).to have_link "Frank", href: "/users/#{user.to_param}"
14
+ end
15
+
16
+ end
17
+
18
+
@@ -0,0 +1,18 @@
1
+ require 'spec_helper'
2
+
3
+ describe 'users/_following_modal.html.erb' do
4
+ let(:user) { FactoryGirl.create(:user, display_name: "Frank") }
5
+
6
+ before do
7
+ assign :following, [user]
8
+ end
9
+
10
+ it "should draw user list" do
11
+ render
12
+ page = Capybara::Node::Simple.new(rendered)
13
+ expect(page).to have_link "Frank", href: "/users/#{user.to_param}"
14
+ end
15
+
16
+ end
17
+
18
+
@@ -17,7 +17,7 @@ describe 'users/index.html.erb' do
17
17
  it "should draw user list" do
18
18
  render
19
19
  page = Capybara::Node::Simple.new(rendered)
20
- expect(page).to have_content("ScholarSphere Users")
20
+ expect(page).to have_content("Sufia Users")
21
21
  (1..10).each do |i|
22
22
  expect(page).to have_content("user#{i}")
23
23
  end
@@ -19,7 +19,7 @@ class Batch < ActiveFedora::Base
19
19
  end
20
20
 
21
21
  def to_solr(solr_doc={}, opts={})
22
- super(solr_doc, opts)
22
+ solr_doc = super(solr_doc, opts)
23
23
  solr_doc[Solrizer.solr_name('noid', Sufia::GenericFile.noid_indexer)] = noid
24
24
  return solr_doc
25
25
  end
@@ -0,0 +1,30 @@
1
+ module Sufia
2
+ module PropertiesDatastreamBehavior
3
+ extend ActiveSupport::Concern
4
+
5
+ included do
6
+ set_terminology do |t|
7
+ t.root(:path=>"fields" )
8
+ # This is where we put the user id of the object depositor -- impacts permissions/access controls
9
+ t.depositor :index_as=>[:stored_searchable]
10
+ # This is where we put the relative path of the file if submitted as a folder
11
+ t.relative_path
12
+ t.import_url path: 'importUrl', :index_as=>:symbol
13
+ end
14
+ end
15
+
16
+ module ClassMethods
17
+ def xml_template
18
+ builder = Nokogiri::XML::Builder.new do |xml|
19
+ xml.fields
20
+ end
21
+ builder.doc
22
+ end
23
+ end
24
+
25
+ def prefix
26
+ ""
27
+ end
28
+
29
+ end
30
+ end
@@ -45,7 +45,7 @@ module Sufia::User
45
45
 
46
46
  def trophy_files
47
47
  trophies.map do |t|
48
- GenericFile.load_instance_from_solr(Sufia::Noid.namespaceize(t.generic_file_id))
48
+ ::GenericFile.load_instance_from_solr(Sufia::Noid.namespaceize(t.generic_file_id))
49
49
  end
50
50
  end
51
51
 
@@ -1,9 +1,6 @@
1
1
  class BatchRdfDatastream < ActiveFedora::NtriplesRDFDatastream
2
- map_predicates do |map|
3
- map.part(:to => "hasPart", :in => RDF::DC)
4
- map.creator(:to => "creator", :in => RDF::DC)
5
- map.title(:to => "title", :in => RDF::DC)
6
- map.status(:to => "type", :in => RDF::DC)
7
- end
2
+ property :part, predicate: RDF::DC.hasPart
3
+ property :creator, predicate: RDF::DC.creator
4
+ property :title, predicate: RDF::DC.title
5
+ property :status, predicate: RDF::DC.type
8
6
  end
9
-
@@ -1,5 +1,8 @@
1
1
  class FitsDatastream < ActiveFedora::OmDatastream
2
2
  include OM::XML::Document
3
+ def prefix
4
+ ""
5
+ end
3
6
 
4
7
  set_terminology do |t|
5
8
  t.root(:path => "fits",
@@ -1,56 +1,58 @@
1
1
  class GenericFileRdfDatastream < ActiveFedora::NtriplesRDFDatastream
2
- map_predicates do |map|
3
- map.part_of(:to => "isPartOf", :in => RDF::DC)
4
- map.resource_type(:to => "type", :in => RDF::DC) do |index|
5
- index.as :stored_searchable, :facetable
6
- end
7
- map.title(:in => RDF::DC) do |index|
8
- index.as :stored_searchable
9
- end
10
- map.creator(:in => RDF::DC) do |index|
11
- index.as :stored_searchable, :facetable
12
- end
13
- map.contributor(:in => RDF::DC) do |index|
14
- index.as :stored_searchable, :facetable
15
- end
16
- map.description(:in => RDF::DC) do |index|
17
- index.type :text
18
- index.as :stored_searchable
19
- end
20
- map.tag(:to => "relation", :in => RDF::DC) do |index|
21
- index.as :stored_searchable, :facetable
22
- end
23
- map.rights(:in => RDF::DC) do |index|
24
- index.as :stored_searchable
25
- end
26
- map.publisher(:in => RDF::DC) do |index|
27
- index.as :stored_searchable, :facetable
28
- end
29
- map.date_created(:to => "created", :in => RDF::DC) do |index|
30
- index.as :stored_searchable
31
- end
32
- map.date_uploaded(:to => "dateSubmitted", :in => RDF::DC) do |index|
33
- index.type :date
34
- index.as :stored_sortable
35
- end
36
- map.date_modified(:to => "modified", :in => RDF::DC) do |index|
37
- index.type :date
38
- index.as :stored_sortable
39
- end
40
- map.subject(:in => RDF::DC) do |index|
41
- index.as :stored_searchable, :facetable
42
- end
43
- map.language(:in => RDF::DC) do |index|
44
- index.as :stored_searchable, :facetable
45
- end
46
- map.identifier(:in => RDF::DC) do |index|
47
- index.as :stored_searchable
48
- end
49
- map.based_near(:in => RDF::FOAF) do |index|
50
- index.as :stored_searchable, :facetable
51
- end
52
- map.related_url(:to => "seeAlso", :in => RDF::RDFS)
2
+ property :part_of, predicate: RDF::DC.isPartOf
3
+ property :resource_type, predicate: RDF::DC.type do |index|
4
+ index.as :stored_searchable, :facetable
53
5
  end
6
+ property :title, predicate: RDF::DC.title do |index|
7
+ index.as :stored_searchable
8
+ end
9
+ property :creator, predicate: RDF::DC.creator do |index|
10
+ index.as :stored_searchable, :facetable
11
+ end
12
+ property :contributor, predicate: RDF::DC.contributor do |index|
13
+ index.as :stored_searchable, :facetable
14
+ end
15
+ property :description, predicate: RDF::DC.description do |index|
16
+ index.type :text
17
+ index.as :stored_searchable
18
+ end
19
+ property :tag, predicate: RDF::DC.relation do |index|
20
+ index.as :stored_searchable, :facetable
21
+ end
22
+ property :rights, predicate: RDF::DC.rights do |index|
23
+ index.as :stored_searchable
24
+ end
25
+ property :publisher, predicate: RDF::DC.publisher do |index|
26
+ index.as :stored_searchable, :facetable
27
+ end
28
+ property :date_created, predicate: RDF::DC.created do |index|
29
+ index.as :stored_searchable
30
+ end
31
+ property :date_uploaded, predicate: RDF::DC.dateSubmitted do |index|
32
+ index.type :date
33
+ index.as :stored_sortable
34
+ end
35
+ property :date_modified, predicate: RDF::DC.modified do |index|
36
+ index.type :date
37
+ index.as :stored_sortable
38
+ end
39
+ property :subject, predicate: RDF::DC.subject do |index|
40
+ index.as :stored_searchable, :facetable
41
+ end
42
+ property :language, predicate: RDF::DC.language do |index|
43
+ index.as :stored_searchable, :facetable
44
+ end
45
+ property :identifier, predicate: RDF::DC.identifier do |index|
46
+ index.as :stored_searchable
47
+ end
48
+ property :based_near, predicate: RDF::FOAF.based_near do |index|
49
+ index.as :stored_searchable, :facetable
50
+ end
51
+ property :related_url, predicate: RDF::RDFS.seeAlso do |index|
52
+ index.as :stored_searchable
53
+ end
54
+
55
+ # TODO: Move this somewhere more appropriate
54
56
  begin
55
57
  LocalAuthority.register_vocabulary(self, "subject", "lc_subjects")
56
58
  LocalAuthority.register_vocabulary(self, "language", "lexvo_languages")