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.
- checksums.yaml +4 -4
- data/.travis.yml +1 -1
- data/Gemfile +3 -0
- data/README.md +88 -11
- data/SUFIA_VERSION +1 -1
- data/app/assets/images/old_main_tulips.jpg +0 -0
- data/app/assets/javascripts/contact_form.js +0 -16
- data/app/assets/javascripts/jquery.blacklightTagCloud.js +44 -0
- data/app/assets/javascripts/jquery.tagcloud.js +116 -0
- data/app/assets/javascripts/jquery.tinysort.min.js +7 -0
- data/app/assets/javascripts/sufia.js +41 -44
- data/app/assets/javascripts/sufia/edit_metadata.js +1 -1
- data/app/assets/javascripts/sufia/editor.js +12 -0
- data/app/assets/javascripts/sufia/featured_works.js +64 -0
- data/app/assets/javascripts/sufia/fileupload.js +1 -1
- data/app/assets/javascripts/sufia/multiForm.js +1 -1
- data/app/assets/javascripts/sufia/permissions.js +4 -8
- data/app/assets/javascripts/sufia/single_use_link.js +1 -2
- data/app/assets/javascripts/sufia/trophy.js +42 -27
- data/app/assets/javascripts/terms_of_service.js +1 -1
- data/app/assets/stylesheets/dashboard.css.scss +81 -40
- data/app/assets/stylesheets/featured.css.scss +16 -0
- data/app/assets/stylesheets/fileupload/{jquery.fileupload-ui.css → jquery.fileupload-ui.css.erb} +2 -2
- data/app/assets/stylesheets/{generic_files.css → generic_files.css.erb} +6 -7
- data/app/assets/stylesheets/header.css.scss +93 -0
- data/app/assets/stylesheets/home-page.css.scss +50 -0
- data/app/assets/stylesheets/nestable.css.scss +111 -0
- data/app/assets/stylesheets/styles.css.scss +106 -0
- data/app/assets/stylesheets/sufia.css.scss +13 -8
- data/app/assets/stylesheets/tagcloud.css +83 -0
- data/app/assets/stylesheets/usage-stats.css +30 -0
- data/app/controllers/batch_controller.rb +0 -1
- data/app/controllers/concerns/sufia/catalog.rb +64 -0
- data/app/controllers/concerns/sufia/dashboard_controller_behavior.rb +16 -13
- data/app/controllers/content_blocks_controller.rb +8 -0
- data/app/controllers/featured_work_lists_controller.rb +16 -0
- data/app/controllers/featured_works_controller.rb +26 -0
- data/app/controllers/mailbox_controller.rb +1 -1
- data/app/controllers/pages_controller.rb +7 -0
- data/app/controllers/single_use_links_viewer_controller.rb +2 -5
- data/app/controllers/tinymce_assets_controller.rb +12 -0
- data/app/helpers/content_block_helper.rb +21 -0
- data/app/helpers/generic_file_helper.rb +2 -2
- data/app/helpers/sufia_helper.rb +8 -4
- data/app/helpers/trophy_helper.rb +15 -7
- data/app/models/content_block.rb +2 -0
- data/app/models/featured_work_list.rb +42 -0
- data/app/models/tinymce_asset.rb +3 -0
- data/app/uploaders/tinymce_asset_uploader.rb +51 -0
- data/app/views/_add_assets_links.html.erb +0 -16
- data/app/views/_controls.html.erb +17 -0
- data/app/views/_flash_msg.html.erb +2 -18
- data/app/views/_footer.html.erb +10 -15
- data/app/views/_ga.html.erb +0 -16
- data/app/views/_logo.html.erb +2 -2
- data/app/views/_masthead.html.erb +9 -36
- data/app/views/_user_util_links.html.erb +16 -11
- data/app/views/advanced/_advanced_search_facets.html.erb +0 -16
- data/app/views/advanced/_advanced_search_fields.html.erb +0 -16
- data/app/views/advanced/_advanced_search_help.html.erb +0 -16
- data/app/views/advanced/_facet_layout.html.erb +0 -16
- data/app/views/advanced/_facet_limit.html.erb +0 -16
- data/app/views/advanced/index.html.erb +2 -18
- data/app/views/batch/_metadata.html.erb +3 -3
- data/app/views/batch/edit.html.erb +4 -21
- data/app/views/catalog/_facet_limit.html.erb +11 -12
- data/app/views/catalog/_featured_researcher.html.erb +2 -0
- data/app/views/catalog/_home.html.erb +6 -2
- data/app/views/catalog/_home_content.html.erb +36 -0
- data/app/views/catalog/_home_header.html.erb +15 -0
- data/app/views/catalog/_recent_document.html.erb +1 -1
- data/app/views/catalog/_recents.html.erb +3 -4
- data/app/views/catalog/_search_form.html.erb +13 -9
- data/app/views/catalog/_tagcloud.html.erb +7 -0
- data/app/views/catalog/index.html.erb +4 -10
- data/app/views/contact_form/create.html.erb +0 -16
- data/app/views/contact_form/new.html.erb +0 -16
- data/app/views/dashboard/_constraints.html.erb +3 -19
- data/app/views/dashboard/_did_you_mean.html.erb +0 -16
- data/app/views/dashboard/_document_list.html.erb +0 -16
- data/app/views/dashboard/_facet_layout.html.erb +1 -17
- data/app/views/dashboard/_facet_limit.html.erb +5 -5
- data/app/views/dashboard/_facet_selected.html.erb +1 -17
- data/app/views/dashboard/_facets.html.erb +0 -18
- data/app/views/dashboard/_heading.html.erb +1 -1
- data/app/views/dashboard/_index_partials/_default_group.html.erb +7 -23
- data/app/views/dashboard/_index_partials/_list_files.html.erb +62 -57
- data/app/views/dashboard/_search_form.html.erb +10 -7
- data/app/views/dashboard/_show_partials/_default.html.erb +0 -18
- data/app/views/dashboard/_show_partials/_default_details.html.erb +0 -16
- data/app/views/dashboard/_show_partials/_facets.html.erb +0 -16
- data/app/views/dashboard/_sort_and_per_page.html.erb +10 -9
- data/app/views/dashboard/facet.html.erb +4 -19
- data/app/views/dashboard/index.html.erb +27 -49
- data/app/views/error/401.html.erb +1 -17
- data/app/views/error/404.html.erb +0 -16
- data/app/views/error/500.html.erb +0 -16
- data/app/views/error/single_use_error.html.erb +1 -17
- data/app/views/generic_files/_asset_deleted_flash.html.erb +0 -16
- data/app/views/generic_files/_asset_permissions_denial_flash.html.erb +0 -16
- data/app/views/generic_files/_asset_saved_flash.html.erb +0 -16
- data/app/views/generic_files/_asset_updated_flash.html.erb +0 -16
- data/app/views/generic_files/_breadcrumbs.html.erb +0 -16
- data/app/views/generic_files/_browse_everything.html.erb +24 -0
- data/app/views/generic_files/_descriptions.html.erb +1 -1
- data/app/views/generic_files/_field_form.html.erb +5 -5
- data/app/views/generic_files/_media_display.html.erb +3 -3
- data/app/views/generic_files/_permission_form.html.erb +5 -5
- data/app/views/generic_files/_rights_modal.html.erb +13 -29
- data/app/views/generic_files/_show_actions.html.erb +13 -1
- data/app/views/generic_files/_versioning.html.erb +14 -10
- data/app/views/generic_files/citation.html.erb +0 -16
- data/app/views/generic_files/edit.html.erb +10 -12
- data/app/views/generic_files/edit_fields/_default.html.erb +1 -1
- data/app/views/generic_files/edit_fields/_description.html.erb +1 -1
- data/app/views/generic_files/edit_fields/_resource_type.html.erb +2 -3
- data/app/views/generic_files/edit_fields/_rights.html.erb +1 -1
- data/app/views/generic_files/new.html.erb +11 -26
- data/app/views/generic_files/show.html.erb +7 -25
- data/app/views/generic_files/stats.html.erb +141 -0
- data/app/views/homepage/_featured.html.erb +11 -0
- data/app/views/homepage/_featured_fields.html.erb +18 -0
- data/app/views/homepage/_featured_works.html.erb +17 -0
- data/app/views/homepage/_sortable_featured.html.erb +26 -0
- data/app/views/layouts/_head_tag_content.html.erb +1 -1
- data/app/views/layouts/_homepage_sidebar2.html.erb +14 -0
- data/app/views/layouts/error.html.erb +3 -21
- data/app/views/layouts/homepage.html.erb +8 -37
- data/app/views/layouts/sufia-dashboard.html.erb +46 -0
- data/app/views/layouts/sufia-one-column.html.erb +8 -24
- data/app/views/layouts/sufia-two-column.html.erb +9 -8
- data/app/views/pages/show.html.erb +4 -0
- data/app/views/single_use_links_viewer/show.html.erb +2 -2
- data/app/views/static/agreement.html.erb +0 -17
- data/app/views/static/help.html.erb +0 -17
- data/app/views/static/mendeley.html.erb +0 -16
- data/app/views/static/subject_libraries.html.erb +0 -17
- data/app/views/static/terms.html.erb +0 -16
- data/app/views/static/zotero.html.erb +0 -16
- data/app/views/users/_activity_log.html.erb +2 -2
- data/app/views/users/_contributions.html.erb +6 -2
- data/app/views/users/_follower_modal.html.erb +2 -2
- data/app/views/users/_following_modal.html.erb +2 -2
- data/app/views/users/_left_sidebar.html.erb +1 -1
- data/app/views/users/_notify_link.html.erb +1 -1
- data/app/views/users/_notify_number.html.erb +1 -1
- data/app/views/users/_profile_actions.html.erb +3 -3
- data/app/views/users/_profile_tabs.html.erb +1 -1
- data/app/views/users/_search_form.html.erb +3 -2
- data/app/views/users/_social_media_info.html.erb +3 -3
- data/app/views/users/_trophy_edit.html.erb +2 -2
- data/app/views/users/_user_info.html.erb +27 -27
- data/app/views/users/_vitals.html.erb +2 -2
- data/app/views/users/edit.html.erb +39 -39
- data/app/views/users/index.html.erb +3 -3
- data/app/views/users/show.html.erb +7 -9
- data/config/locales/sufia.en.yml +15 -7
- data/config/routes.rb +12 -9
- data/lib/generators/sufia/sufia_generator.rb +18 -15
- data/lib/generators/sufia/templates/catalog_controller.rb +11 -73
- data/lib/generators/sufia/templates/config/tinymce.yml +7 -0
- data/lib/sufia.rb +7 -0
- data/lib/sufia/downloads_controller_behavior.rb +3 -4
- data/lib/sufia/files_controller_behavior.rb +38 -27
- data/lib/sufia/version.rb +1 -1
- data/spec/controllers/batch_controller_spec.rb +1 -1
- data/spec/controllers/batch_edits_controller_spec.rb +5 -5
- data/spec/controllers/catalog_controller_spec.rb +37 -58
- data/spec/controllers/content_blocks_controller_spec.rb +37 -0
- data/spec/controllers/downloads_controller_spec.rb +3 -11
- data/spec/controllers/featured_work_lists_controller_spec.rb +20 -0
- data/spec/controllers/featured_works_controller_spec.rb +50 -0
- data/spec/controllers/generic_files_controller_spec.rb +74 -9
- data/spec/controllers/mailbox_controller_spec.rb +1 -1
- data/spec/controllers/pages_controller_spec.rb +25 -0
- data/spec/controllers/single_use_links_controller_spec.rb +1 -1
- data/spec/controllers/single_use_links_viewer_controller_spec.rb +1 -1
- data/spec/controllers/tinymce_assets_controller_spec.rb +39 -0
- data/spec/controllers/users_controller_spec.rb +3 -8
- data/spec/factories/content_blocks.rb +4 -0
- data/spec/factories/featured_works.rb +4 -0
- data/spec/factories/generic_files.rb +46 -39
- data/spec/factories/users.rb +18 -18
- data/spec/features/browse_dashboard_files_spec.rb +6 -7
- data/spec/features/browse_files_spec.rb +9 -6
- data/spec/features/cloud_upload_spec.rb +18 -0
- data/spec/features/single_use_links_spec.rb +2 -3
- data/spec/helpers/content_block_helper_spec.rb +31 -0
- data/spec/helpers/generic_file_helper_spec.rb +3 -3
- data/spec/helpers/sufia_helper_spec.rb +13 -81
- data/spec/helpers/trophy_helper_spec.rb +39 -0
- data/spec/jobs/import_url_job_spec.rb +1 -1
- data/spec/jobs/ingest_local_file_job_spec.rb +1 -1
- data/spec/lib/sufia/usage_statistics_spec.rb +75 -0
- data/spec/models/ability_spec.rb +31 -0
- data/spec/models/active_fedora_pid_based_job_spec.rb +1 -1
- data/spec/models/audit_job_spec.rb +1 -1
- data/spec/models/batch_spec.rb +1 -1
- data/spec/models/batch_update_job_spec.rb +1 -1
- data/spec/models/event_jobs_spec.rb +1 -1
- data/spec/models/featured_work_list_spec.rb +23 -0
- data/spec/models/featured_work_spec.rb +42 -0
- data/spec/models/fits_datastream_spec.rb +2 -2
- data/spec/models/generic_file/reload_on_save_spec.rb +1 -1
- data/spec/models/generic_file/web_form_spec.rb +4 -4
- data/spec/models/generic_file_spec.rb +41 -40
- data/spec/models/pageview.rb +19 -0
- data/spec/models/properties_datastream_spec.rb +2 -2
- data/spec/models/solr_document_spec.rb +9 -0
- data/spec/models/user_spec.rb +2 -2
- data/spec/routing/featured_works_route_spec.rb +16 -0
- data/spec/routing/route_spec.rb +10 -15
- data/spec/spec_helper.rb +3 -0
- data/spec/support/lib/generators/test_app_generator.rb +19 -8
- data/spec/views/dashboard/facet_limit.html.erb_spec.rb +2 -2
- data/spec/views/generic_file/show.html.erb_spec.rb +44 -0
- data/spec/views/generic_file/stats.html.erb_spec.rb +47 -0
- data/spec/views/users/_follower_modal.html.erb_spec.rb +18 -0
- data/spec/views/users/_following_modal.html.erb_spec.rb +18 -0
- data/spec/views/users/index.html.erb_spec.rb +1 -1
- data/sufia-models/app/models/batch.rb +1 -1
- data/sufia-models/app/models/concerns/sufia/properties_datastream_behavior.rb +30 -0
- data/sufia-models/app/models/concerns/sufia/user.rb +1 -1
- data/sufia-models/app/models/datastreams/batch_rdf_datastream.rb +4 -7
- data/sufia-models/app/models/datastreams/fits_datastream.rb +3 -0
- data/sufia-models/app/models/datastreams/generic_file_rdf_datastream.rb +53 -51
- data/sufia-models/app/models/datastreams/properties_datastream.rb +1 -15
- data/sufia-models/app/models/featured_work.rb +22 -0
- data/sufia-models/app/models/sufia/pageview.rb +9 -0
- data/sufia-models/{lib/sufia/models → app/services/sufia}/id_service.rb +0 -0
- data/sufia-models/{lib/sufia/models → app/services/sufia}/noid.rb +0 -0
- data/sufia-models/app/services/sufia/usage_statistics.rb +73 -0
- data/sufia-models/config/locales/sufia.en.yml +3 -4
- data/sufia-models/lib/generators/sufia/models/install_generator.rb +23 -8
- data/sufia-models/lib/generators/sufia/models/templates/config/analytics.yml +9 -0
- data/sufia-models/lib/generators/sufia/models/templates/config/mime_types.rb +6 -0
- data/sufia-models/lib/generators/sufia/models/templates/config/sufia.rb +11 -2
- data/sufia-models/lib/generators/sufia/models/templates/migrations/create_content_blocks.rb +10 -0
- data/sufia-models/lib/generators/sufia/models/templates/migrations/create_featured_works.rb +12 -0
- data/sufia-models/lib/generators/sufia/models/templates/migrations/create_tinymce_assets.rb +8 -0
- data/sufia-models/lib/generators/sufia/models/usagestats_generator.rb +19 -0
- data/sufia-models/lib/sufia/ability.rb +34 -0
- data/sufia-models/lib/sufia/models/engine.rb +5 -3
- data/sufia-models/lib/sufia/models/generic_file.rb +4 -2
- data/sufia-models/lib/sufia/models/generic_file/export.rb +3 -3
- data/sufia-models/lib/sufia/models/generic_file/featured.rb +14 -0
- data/sufia-models/lib/sufia/models/solr_document_behavior.rb +11 -4
- data/sufia-models/lib/sufia/models/version.rb +1 -1
- data/sufia-models/sufia-models.gemspec +6 -5
- data/sufia.gemspec +6 -4
- data/tasks/release.rake +1 -0
- data/tasks/sufia-dev.rake +5 -1
- data/vendor/assets/javascripts/flot/excanvas.js +1428 -0
- data/vendor/assets/javascripts/flot/jquery.flot.js +3137 -0
- data/vendor/assets/javascripts/flot/jquery.flot.selection.js +360 -0
- data/vendor/assets/javascripts/flot/jquery.flot.time.js +431 -0
- data/vendor/assets/javascripts/nestable.js +647 -0
- data/vendor/assets/javascripts/video.js +135 -126
- data/{app → vendor}/assets/stylesheets/video-js.css.erb +7 -6
- metadata +155 -33
- data/app/assets/stylesheets/application-bootstrap.css.erb +0 -295
- data/app/assets/stylesheets/audio-js.css +0 -3
- data/app/assets/stylesheets/blacklight_more_facets.css +0 -427
- data/app/assets/stylesheets/bootstrap.min.css.erb +0 -1433
- data/app/assets/stylesheets/contact_form.css +0 -4
- data/app/assets/stylesheets/reset_body.css +0 -4
- data/app/assets/stylesheets/trophy.css +0 -7
- data/app/helpers/blacklight/render_constraints_helper_behavior.rb +0 -84
- data/app/helpers/facets_helper.rb +0 -3
- data/app/helpers/sufia/facets_helper_behavior.rb +0 -23
- data/app/views/catalog/_home_text.html.erb +0 -10
- data/app/views/generic_files/_dropbox_import.html.erb +0 -3
- data/app/views/generic_files/upload/_dropbox_chooser.html.erb +0 -39
- data/app/views/static/about.html.erb +0 -21
- 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
|
data/spec/models/user_spec.rb
CHANGED
@@ -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(:
|
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(:
|
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
|
data/spec/routing/route_spec.rb
CHANGED
@@ -1,21 +1,12 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe 'Routes' do
|
4
|
-
|
5
|
-
|
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 "
|
160
|
+
describe "Dynamically edited pages" do
|
168
161
|
it "should route to about" do
|
169
|
-
{ get: '/about' }.should route_to(controller: '
|
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
@@ -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
|
15
|
-
|
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
|
19
|
-
|
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
|
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("
|
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
|
@@ -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
|
@@ -1,9 +1,6 @@
|
|
1
1
|
class BatchRdfDatastream < ActiveFedora::NtriplesRDFDatastream
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
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,56 +1,58 @@
|
|
1
1
|
class GenericFileRdfDatastream < ActiveFedora::NtriplesRDFDatastream
|
2
|
-
|
3
|
-
|
4
|
-
|
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")
|