enju_library 0.2.0.beta.1 → 0.2.0.beta.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/controllers/concerns/enju_library/controller.rb +218 -0
- data/app/controllers/user_export_files_controller.rb +116 -0
- data/app/controllers/user_groups_controller.rb +118 -0
- data/app/controllers/user_import_files_controller.rb +129 -0
- data/app/controllers/user_import_results_controller.rb +57 -0
- data/app/mailers/notifier.rb +30 -0
- data/app/models/user_export_file.rb +67 -0
- data/app/models/user_export_file_state_machine.rb +15 -0
- data/app/models/user_export_file_transition.rb +20 -0
- data/app/models/user_group.rb +29 -0
- data/app/models/user_import_file.rb +352 -0
- data/app/models/user_import_file_state_machine.rb +19 -0
- data/app/models/user_import_file_transition.rb +20 -0
- data/app/models/user_import_result.rb +20 -0
- data/app/policies/user_export_file_policy.rb +21 -0
- data/app/policies/user_group_policy.rb +22 -0
- data/app/policies/user_import_file_policy.rb +21 -0
- data/app/policies/user_import_result_policy.rb +21 -0
- data/app/views/accepts/index.js.slim +3 -0
- data/app/views/libraries/_map.html+phone.slim +4 -0
- data/app/views/libraries/show.html+phone.slim +32 -0
- data/app/views/libraries/show.js.slim +3 -0
- data/app/views/shelves/show.html+phone.slim +33 -0
- data/app/views/user_export_files/_form.html.erb +12 -0
- data/app/views/user_export_files/edit.html.erb +6 -0
- data/app/views/user_export_files/index.html.erb +44 -0
- data/app/views/user_export_files/new.html.erb +16 -0
- data/app/views/user_export_files/show.html.erb +36 -0
- data/app/views/user_groups/_form.html.erb +40 -0
- data/app/views/user_groups/edit.html.erb +13 -0
- data/app/views/user_groups/index.html.erb +51 -0
- data/app/views/user_groups/new.html.erb +12 -0
- data/app/views/user_groups/show.html.erb +68 -0
- data/app/views/user_import_files/_form.html.erb +61 -0
- data/app/views/user_import_files/_results.html.erb +22 -0
- data/app/views/user_import_files/edit.html.erb +6 -0
- data/app/views/user_import_files/index.html.erb +45 -0
- data/app/views/user_import_files/new.html.erb +60 -0
- data/app/views/user_import_files/show.html.erb +85 -0
- data/app/views/user_import_results/_form.html.erb +29 -0
- data/app/views/user_import_results/_list.html.erb +22 -0
- data/app/views/user_import_results/_list_lines.html.erb +24 -0
- data/app/views/user_import_results/index.html.erb +25 -0
- data/app/views/user_import_results/index.txt.erb +3 -0
- data/app/views/user_import_results/show.html.erb +33 -0
- data/{spec/dummy/db → db}/migrate/077_create_user_groups.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20110318183304_add_valid_period_for_new_user_to_user_group.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140110122216_create_user_import_files.rb +1 -1
- data/{spec/dummy/db → db}/migrate/20140110131010_create_user_import_results.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140524074813_create_user_import_file_transitions.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140628072217_add_user_encoding_to_user_import_file.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140709113413_create_user_export_files.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140709113905_create_user_export_file_transitions.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140720170714_add_default_library_id_to_user_import_file.rb +0 -0
- data/{spec/dummy/db → db}/migrate/20140720170735_add_default_user_group_id_to_user_import_file.rb +0 -0
- data/db/migrate/20150506105356_add_error_message_to_user_import_result.rb +5 -0
- data/db/migrate/20160610093229_add_html_snippet_to_library_group.rb +5 -0
- data/db/migrate/20160627232219_add_most_recent_to_user_import_file_transitions.rb +9 -0
- data/db/migrate/20160627232316_add_most_recent_to_user_export_file_transitions.rb +9 -0
- data/lib/enju_library/engine.rb +3 -1
- data/lib/enju_library/version.rb +1 -1
- data/spec/controllers/user_export_files_controller_spec.rb +296 -0
- data/spec/controllers/user_groups_controller_spec.rb +443 -0
- data/spec/controllers/user_import_files_controller_spec.rb +305 -0
- data/spec/controllers/user_import_results_controller_spec.rb +154 -0
- data/spec/dummy/app/controllers/application_controller.rb +2 -2
- data/spec/dummy/config/application.rb +0 -2
- data/spec/dummy/db/migrate/055_create_bookmarks.rb +22 -0
- data/spec/dummy/db/migrate/090_create_search_histories.rb +31 -0
- data/spec/dummy/db/migrate/20081212151614_create_bookmark_stats.rb +13 -0
- data/spec/dummy/db/migrate/20081212151820_create_bookmark_stat_has_manifestations.rb +13 -0
- data/spec/dummy/db/migrate/20100222124420_add_allow_bookmark_external_url_to_library_group.rb +9 -0
- data/spec/dummy/db/migrate/20100525171356_acts_as_taggable_on_migration.rb +30 -0
- data/spec/dummy/db/migrate/20100623173800_rename_search_history_version_to_sru_version.rb +9 -0
- data/spec/dummy/db/migrate/20111129044509_add_pickup_location_to_reserve.rb +6 -0
- data/spec/dummy/db/migrate/20120418121539_add_save_search_history_to_user.rb +5 -0
- data/spec/dummy/db/migrate/20140524135607_create_bookmark_stat_transitions.rb +18 -0
- data/spec/dummy/db/migrate/20140811132912_add_save_search_history_to_profile.rb +5 -0
- data/spec/dummy/db/migrate/20140812093836_add_share_bookmarks_to_profile.rb +5 -0
- data/spec/dummy/db/migrate/20150106001709_create_demands.rb +14 -0
- data/spec/dummy/db/migrate/20150421023923_create_identities.rb +15 -0
- data/spec/dummy/db/migrate/20151126005552_add_provider_to_identity.rb +5 -0
- data/spec/dummy/db/migrate/20160703184619_add_most_recent_to_reserve_transitions.rb +9 -0
- data/spec/dummy/db/migrate/20160703184650_add_most_recent_to_manifestation_checkout_stat_transitions.rb +9 -0
- data/spec/dummy/db/migrate/20160703184723_add_most_recent_to_manifestation_reserve_stat_transitions.rb +9 -0
- data/spec/dummy/db/migrate/20160703184747_add_most_recent_to_user_checkout_stat_transitions.rb +9 -0
- data/spec/dummy/db/migrate/20160703184805_add_most_recent_to_user_reserve_stat_transitions.rb +9 -0
- data/spec/dummy/db/migrate/20160703190209_add_foreign_key_on_manifestation_id_to_reserve.rb +5 -0
- data/spec/dummy/db/schema.rb +141 -6
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8463-13fk7qo.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8463-y41sj6.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8517-1tzre93.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8517-qait5x.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8605-17zb3sz.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/001/original/user_export_file_20160808-8605-1bpp9w8.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-10113-ycu8m8.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-10296-1w0qa4q.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-10532-3gf0e4.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-10743-1986tss.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-10850-131ca5h.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-11057-lrwhh.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-11201-1j3f8z4.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-8698-1cv7l1l.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-8788-1j021tn.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-8964-10it3ay.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9184-ramwb2.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9381-1ltvlr5.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9568-1xno5kz.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9694-1xvbn9r.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9796-1s8wttm.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/003/original/user_export_file_20160808-9976-os18dm.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10113-i50cx9.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10113-yfyk1q.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10296-mwlqee.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10296-q7cj81.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10532-11e6ke6.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10532-19zrpc6.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10743-126qknn.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10743-1yr9gk3.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10850-1h0ufaw.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-10850-1j6rz0a.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-11057-4u0q76.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-11057-xkxnw0.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-11201-1pbhweq.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-11201-oe7c58.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8698-becrga.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8698-n6a7dl.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8788-kcq4ud.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8788-pk5u5w.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8964-1it6ent.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-8964-sevvj9.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9184-1wya34t.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9184-53qr2e.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9381-18m5cay.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9381-1o6dbyx.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9568-1rg8mif.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9568-p2ibx2.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9694-1lpp5g6.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9694-1vbkp9i.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9796-4auzfe.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9796-is0c1e.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9976-1n5tevc.txt +8 -0
- data/spec/dummy/private/system/user_export_files/user_exports/000/000/004/original/user_export_file_20160808-9976-1ygxnz1.txt +8 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_import_file_sample.tsv +10 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_import_file_sample_long.tsv +15 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_update_file.tsv +4 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_update_file2.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_update_file3.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/001/original/user_update_file4.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_import_file_sample.tsv +10 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_import_file_sample_long.tsv +15 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_update_file.tsv +4 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_update_file2.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_update_file3.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/003/original/user_update_file4.tsv +2 -0
- data/spec/dummy/private/system/user_import_files/user_imports/000/000/004/original/user_delete_file.tsv +4 -0
- data/spec/factories/checkout.rb +9 -0
- data/spec/factories/user_group.rb +5 -0
- data/spec/fixtures/message_templates.yml +41 -20
- data/spec/fixtures/user_export_files.yml +25 -0
- data/spec/fixtures/user_groups.yml +19 -0
- data/spec/fixtures/user_import_files.yml +51 -0
- data/spec/fixtures/user_import_results.yml +26 -0
- data/spec/fixtures/user_reserve_stats.yml +2 -3
- data/spec/models/user_export_file_spec.rb +30 -0
- data/spec/models/user_group_spec.rb +37 -0
- data/spec/models/user_import_file_spec.rb +220 -0
- data/spec/models/user_import_result_spec.rb +20 -0
- data/spec/support/devise.rb +2 -2
- data/spec/views/user_export_files/new.html.erb_spec.rb +19 -0
- data/spec/views/user_import_results/index.html.erb_spec.rb +29 -0
- metadata +358 -30
- data/spec/dummy/tmp/cache/4AD/470/country_all +0 -0
@@ -0,0 +1,305 @@
|
|
1
|
+
require 'rails_helper'
|
2
|
+
|
3
|
+
describe UserImportFilesController do
|
4
|
+
fixtures :all
|
5
|
+
|
6
|
+
describe "GET index" do
|
7
|
+
describe "When logged in as Administrator" do
|
8
|
+
login_fixture_admin
|
9
|
+
|
10
|
+
it "assigns all user_import_files as @user_import_files" do
|
11
|
+
get :index
|
12
|
+
assigns(:user_import_files).should eq(UserImportFile.order('id DESC').page(1))
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
describe "When logged in as Librarian" do
|
17
|
+
login_fixture_librarian
|
18
|
+
|
19
|
+
it "assigns all user_import_files as @user_import_files" do
|
20
|
+
get :index
|
21
|
+
assigns(:user_import_files).should eq(UserImportFile.order('id DESC').page(1))
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
describe "When logged in as User" do
|
26
|
+
login_fixture_user
|
27
|
+
|
28
|
+
it "assigns empty as @user_import_files" do
|
29
|
+
get :index
|
30
|
+
assigns(:user_import_files).should be_nil
|
31
|
+
expect(response).to be_forbidden
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
describe "When not logged in" do
|
36
|
+
it "assigns empty as @user_import_files" do
|
37
|
+
get :index
|
38
|
+
assigns(:user_import_files).should be_nil
|
39
|
+
expect(response).to redirect_to(new_user_session_url)
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
describe "GET show" do
|
45
|
+
describe "When logged in as Administrator" do
|
46
|
+
login_fixture_admin
|
47
|
+
|
48
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
49
|
+
get :show, id: user_import_files(:two).id
|
50
|
+
assigns(:user_import_file).should eq(user_import_files(:two))
|
51
|
+
expect(response).to be_success
|
52
|
+
end
|
53
|
+
|
54
|
+
it "assigns user_import_results" do
|
55
|
+
get :show, id: user_import_files(:one).id
|
56
|
+
expect(response).to be_success
|
57
|
+
expect(assigns(:user_import_file)).to eq user_import_files(:one)
|
58
|
+
expect(assigns(:user_import_results)).to include user_import_results(:one)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
describe "When logged in as Librarian" do
|
63
|
+
login_fixture_librarian
|
64
|
+
|
65
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
66
|
+
get :show, id: user_import_files(:two).id
|
67
|
+
assigns(:user_import_file).should eq(user_import_files(:two))
|
68
|
+
expect(response).to be_success
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
describe "When logged in as User" do
|
73
|
+
login_fixture_user
|
74
|
+
|
75
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
76
|
+
get :show, id: user_import_files(:two).id
|
77
|
+
assigns(:user_import_file).should eq(user_import_files(:two))
|
78
|
+
expect(response).to be_forbidden
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
describe "When not logged in" do
|
83
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
84
|
+
get :show, id: user_import_files(:two).id
|
85
|
+
assigns(:user_import_file).should eq(user_import_files(:two))
|
86
|
+
expect(response).to redirect_to(new_user_session_url)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
describe "GET new" do
|
92
|
+
describe "When logged in as Administrator" do
|
93
|
+
login_fixture_admin
|
94
|
+
|
95
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
96
|
+
get :new
|
97
|
+
assigns(:user_import_file).should_not be_valid
|
98
|
+
expect(response).to be_success
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
describe "When logged in as Librarian" do
|
103
|
+
login_fixture_librarian
|
104
|
+
|
105
|
+
it "should not assign the requested user_import_file as @user_import_file" do
|
106
|
+
get :new
|
107
|
+
assigns(:user_import_file).should_not be_valid
|
108
|
+
expect(response).to be_success
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
describe "When logged in as User" do
|
113
|
+
login_fixture_user
|
114
|
+
|
115
|
+
it "should not assign the requested user_import_file as @user_import_file" do
|
116
|
+
get :new
|
117
|
+
assigns(:user_import_file).should be_nil
|
118
|
+
expect(response).to be_forbidden
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
122
|
+
describe "When not logged in" do
|
123
|
+
it "should not assign the requested user_import_file as @user_import_file" do
|
124
|
+
get :new
|
125
|
+
assigns(:user_import_file).should be_nil
|
126
|
+
expect(response).to redirect_to(new_user_session_url)
|
127
|
+
end
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
describe "POST create" do
|
132
|
+
describe "When logged in as Librarian" do
|
133
|
+
before(:each) do
|
134
|
+
profile = FactoryGirl.create(:profile)
|
135
|
+
@user = FactoryGirl.create(:librarian)
|
136
|
+
@user.profile = profile
|
137
|
+
sign_in @user
|
138
|
+
end
|
139
|
+
|
140
|
+
it "should create agent_import_file" do
|
141
|
+
post :create, user_import_file: {user_import: fixture_file_upload("/../../examples/user_import_file_sample.tsv", 'text/csv') }
|
142
|
+
assigns(:user_import_file).should be_valid
|
143
|
+
assigns(:user_import_file).user.username.should eq @user.username
|
144
|
+
expect(response).to redirect_to user_import_file_url(assigns(:user_import_file))
|
145
|
+
end
|
146
|
+
end
|
147
|
+
|
148
|
+
describe "When logged in as User" do
|
149
|
+
before(:each) do
|
150
|
+
profile = FactoryGirl.create(:profile)
|
151
|
+
@user = FactoryGirl.create(:user)
|
152
|
+
@user.profile = profile
|
153
|
+
sign_in @user
|
154
|
+
end
|
155
|
+
|
156
|
+
it "should be forbidden" do
|
157
|
+
post :create, user_import_file: {user_import: fixture_file_upload("/../../examples/user_import_file_sample.tsv", 'text/csv') }
|
158
|
+
assigns(:user_import_file).should be_nil
|
159
|
+
expect(response).to be_forbidden
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
163
|
+
describe "When not logged in" do
|
164
|
+
it "should be redirected to new session url" do
|
165
|
+
post :create, user_import_file: {user_import: fixture_file_upload("/../../examples/user_import_file_sample.tsv", 'text/csv') }
|
166
|
+
assigns(:user_import_file).should be_nil
|
167
|
+
expect(response).to redirect_to new_user_session_url
|
168
|
+
end
|
169
|
+
end
|
170
|
+
end
|
171
|
+
|
172
|
+
describe "GET edit" do
|
173
|
+
describe "When logged in as Administrator" do
|
174
|
+
login_fixture_admin
|
175
|
+
|
176
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
177
|
+
user_import_file = user_import_files(:one)
|
178
|
+
get :edit, id: user_import_file.id
|
179
|
+
assigns(:user_import_file).should eq(user_import_file)
|
180
|
+
end
|
181
|
+
end
|
182
|
+
|
183
|
+
describe "When logged in as Librarian" do
|
184
|
+
login_fixture_librarian
|
185
|
+
|
186
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
187
|
+
user_import_file = user_import_files(:one)
|
188
|
+
get :edit, id: user_import_file.id
|
189
|
+
assigns(:user_import_file).should eq(user_import_file)
|
190
|
+
end
|
191
|
+
end
|
192
|
+
|
193
|
+
describe "When logged in as User" do
|
194
|
+
login_fixture_user
|
195
|
+
|
196
|
+
it "assigns the requested user_import_file as @user_import_file" do
|
197
|
+
user_import_file = user_import_files(:one)
|
198
|
+
get :edit, id: user_import_file.id
|
199
|
+
expect(response).to be_forbidden
|
200
|
+
end
|
201
|
+
end
|
202
|
+
|
203
|
+
describe "When not logged in" do
|
204
|
+
it "should not assign the requested user_import_file as @user_import_file" do
|
205
|
+
user_import_file = user_import_files(:one)
|
206
|
+
get :edit, id: user_import_file.id
|
207
|
+
expect(response).to redirect_to(new_user_session_url)
|
208
|
+
end
|
209
|
+
end
|
210
|
+
end
|
211
|
+
|
212
|
+
describe "PUT update" do
|
213
|
+
describe "When logged in as Administrator" do
|
214
|
+
login_fixture_admin
|
215
|
+
|
216
|
+
it "should update user_import_file" do
|
217
|
+
post :create, user_import_file: {user_import: fixture_file_upload("/../../examples/user_import_file_sample.tsv", 'text/csv') }
|
218
|
+
put :update, id: assigns(:user_import_file).id, user_import_file: { note: 'test' }
|
219
|
+
expect(response).to redirect_to user_import_file_url(assigns(:user_import_file))
|
220
|
+
end
|
221
|
+
end
|
222
|
+
|
223
|
+
describe "When logged in as Librarian" do
|
224
|
+
login_fixture_librarian
|
225
|
+
|
226
|
+
it "should update user_import_file" do
|
227
|
+
post :create, user_import_file: {user_import: fixture_file_upload("/../../examples/user_import_file_sample.tsv", 'text/csv') }
|
228
|
+
put :update, id: assigns(:user_import_file).id, user_import_file: { note: 'test' }
|
229
|
+
expect(response).to redirect_to user_import_file_url(assigns(:user_import_file))
|
230
|
+
end
|
231
|
+
end
|
232
|
+
|
233
|
+
describe "When logged in as User" do
|
234
|
+
login_fixture_user
|
235
|
+
|
236
|
+
it "should not update user_import_file" do
|
237
|
+
put :update, id: user_import_files(:two).id, user_import_file: { }
|
238
|
+
expect(response).to be_forbidden
|
239
|
+
end
|
240
|
+
end
|
241
|
+
|
242
|
+
describe "When not logged in" do
|
243
|
+
it "should not update user_import_file" do
|
244
|
+
put :update, id: user_import_files(:two).id, user_import_file: { }
|
245
|
+
expect(response).to redirect_to new_user_session_url
|
246
|
+
end
|
247
|
+
end
|
248
|
+
end
|
249
|
+
|
250
|
+
describe "DELETE destroy" do
|
251
|
+
before(:each) do
|
252
|
+
@user_import_file = user_import_files(:one)
|
253
|
+
end
|
254
|
+
|
255
|
+
describe "When logged in as Administrator" do
|
256
|
+
login_fixture_admin
|
257
|
+
|
258
|
+
it "destroys the requested user_import_file" do
|
259
|
+
delete :destroy, id: @user_import_file.id
|
260
|
+
end
|
261
|
+
|
262
|
+
it "redirects to the user_import_files list" do
|
263
|
+
delete :destroy, id: @user_import_file.id
|
264
|
+
expect(response).to redirect_to(user_import_files_url)
|
265
|
+
end
|
266
|
+
end
|
267
|
+
|
268
|
+
describe "When logged in as Librarian" do
|
269
|
+
login_fixture_librarian
|
270
|
+
|
271
|
+
it "destroys the requested user_import_file" do
|
272
|
+
delete :destroy, id: @user_import_file.id
|
273
|
+
end
|
274
|
+
|
275
|
+
it "redirects to the user_import_files list" do
|
276
|
+
delete :destroy, id: @user_import_file.id
|
277
|
+
expect(response).to redirect_to(user_import_files_url)
|
278
|
+
end
|
279
|
+
end
|
280
|
+
|
281
|
+
describe "When logged in as User" do
|
282
|
+
login_fixture_user
|
283
|
+
|
284
|
+
it "destroys the requested user_import_file" do
|
285
|
+
delete :destroy, id: @user_import_file.id
|
286
|
+
end
|
287
|
+
|
288
|
+
it "should be forbidden" do
|
289
|
+
delete :destroy, id: @user_import_file.id
|
290
|
+
expect(response).to be_forbidden
|
291
|
+
end
|
292
|
+
end
|
293
|
+
|
294
|
+
describe "When not logged in" do
|
295
|
+
it "destroys the requested user_import_file" do
|
296
|
+
delete :destroy, id: @user_import_file.id
|
297
|
+
end
|
298
|
+
|
299
|
+
it "should be forbidden" do
|
300
|
+
delete :destroy, id: @user_import_file.id
|
301
|
+
expect(response).to redirect_to(new_user_session_url)
|
302
|
+
end
|
303
|
+
end
|
304
|
+
end
|
305
|
+
end
|
@@ -0,0 +1,154 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
require 'rails_helper'
|
3
|
+
|
4
|
+
describe UserImportResultsController do
|
5
|
+
fixtures :all
|
6
|
+
|
7
|
+
describe "GET index" do
|
8
|
+
describe "When logged in as Administrator" do
|
9
|
+
login_fixture_admin
|
10
|
+
|
11
|
+
it "assigns all user_import_results as @user_import_results" do
|
12
|
+
get :index
|
13
|
+
assigns(:user_import_results).should eq(UserImportResult.page(1))
|
14
|
+
end
|
15
|
+
|
16
|
+
describe "With @user_import_file parameter" do
|
17
|
+
before(:each) do
|
18
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_import_file_sample_long.tsv"), user: users(:admin)
|
19
|
+
@file.default_user_group = UserGroup.find(2)
|
20
|
+
@file.default_library = Library.find(3)
|
21
|
+
@file.save
|
22
|
+
@file.import_start
|
23
|
+
end
|
24
|
+
render_views
|
25
|
+
it "should assign all user_import_results for the user_import_file with a page parameter" do
|
26
|
+
get :index, user_import_file_id: @file.id
|
27
|
+
results = assigns(:user_import_results)
|
28
|
+
results.should_not be_empty
|
29
|
+
response.body.should match /<td>11<\/td>/
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
describe "When logged in as Librarian" do
|
35
|
+
login_fixture_librarian
|
36
|
+
|
37
|
+
it "assigns all user_import_results as @user_import_results" do
|
38
|
+
get :index
|
39
|
+
assigns(:user_import_results).should eq(UserImportResult.page(1))
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
describe "When logged in as User" do
|
44
|
+
login_fixture_user
|
45
|
+
|
46
|
+
it "assigns empty as @user_import_results" do
|
47
|
+
get :index
|
48
|
+
assigns(:user_import_results).should be_nil
|
49
|
+
response.should be_forbidden
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
describe "When not logged in" do
|
54
|
+
it "assigns empty as @user_import_results" do
|
55
|
+
get :index
|
56
|
+
assigns(:user_import_results).should be_nil
|
57
|
+
response.should redirect_to(new_user_session_url)
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
describe "GET show" do
|
63
|
+
describe "When logged in as Administrator" do
|
64
|
+
login_fixture_admin
|
65
|
+
|
66
|
+
it "assigns the requested user_import_result as @user_import_result" do
|
67
|
+
get :show, id: 1
|
68
|
+
assigns(:user_import_result).should eq(UserImportResult.find(1))
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
describe "When logged in as Librarian" do
|
73
|
+
login_fixture_librarian
|
74
|
+
|
75
|
+
it "assigns the requested user_import_result as @user_import_result" do
|
76
|
+
get :show, id: 1
|
77
|
+
assigns(:user_import_result).should eq(UserImportResult.find(1))
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
describe "When logged in as User" do
|
82
|
+
login_fixture_user
|
83
|
+
|
84
|
+
it "assigns the requested user_import_result as @user_import_result" do
|
85
|
+
get :show, id: 1
|
86
|
+
assigns(:user_import_result).should eq(UserImportResult.find(1))
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
describe "When not logged in" do
|
91
|
+
it "assigns the requested user_import_result as @user_import_result" do
|
92
|
+
get :show, id: 1
|
93
|
+
assigns(:user_import_result).should eq(UserImportResult.find(1))
|
94
|
+
response.should redirect_to(new_user_session_url)
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
98
|
+
|
99
|
+
describe "DELETE destroy" do
|
100
|
+
before(:each) do
|
101
|
+
@user_import_result = user_import_results(:one)
|
102
|
+
end
|
103
|
+
|
104
|
+
describe "When logged in as Administrator" do
|
105
|
+
login_fixture_admin
|
106
|
+
|
107
|
+
it "destroys the requested user_import_result" do
|
108
|
+
delete :destroy, id: @user_import_result.id
|
109
|
+
end
|
110
|
+
|
111
|
+
it "should be forbidden" do
|
112
|
+
delete :destroy, id: @user_import_result.id
|
113
|
+
response.should be_forbidden
|
114
|
+
end
|
115
|
+
end
|
116
|
+
|
117
|
+
describe "When logged in as Librarian" do
|
118
|
+
login_fixture_librarian
|
119
|
+
|
120
|
+
it "destroys the requested user_import_result" do
|
121
|
+
delete :destroy, id: @user_import_result.id
|
122
|
+
end
|
123
|
+
|
124
|
+
it "should be forbidden" do
|
125
|
+
delete :destroy, id: @user_import_result.id
|
126
|
+
response.should be_forbidden
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
describe "When logged in as User" do
|
131
|
+
login_fixture_user
|
132
|
+
|
133
|
+
it "destroys the requested user_import_result" do
|
134
|
+
delete :destroy, id: @user_import_result.id
|
135
|
+
end
|
136
|
+
|
137
|
+
it "should be forbidden" do
|
138
|
+
delete :destroy, id: @user_import_result.id
|
139
|
+
response.should be_forbidden
|
140
|
+
end
|
141
|
+
end
|
142
|
+
|
143
|
+
describe "When not logged in" do
|
144
|
+
it "destroys the requested user_import_result" do
|
145
|
+
delete :destroy, id: @user_import_result.id
|
146
|
+
end
|
147
|
+
|
148
|
+
it "should be forbidden" do
|
149
|
+
delete :destroy, id: @user_import_result.id
|
150
|
+
response.should redirect_to(new_user_session_url)
|
151
|
+
end
|
152
|
+
end
|
153
|
+
end
|
154
|
+
end
|
@@ -1,8 +1,8 @@
|
|
1
1
|
class ApplicationController < ActionController::Base
|
2
2
|
protect_from_forgery
|
3
|
-
include EnjuLeaf::Controller
|
4
|
-
include EnjuBiblio::Controller
|
5
3
|
include EnjuLibrary::Controller
|
4
|
+
include EnjuBiblio::Controller
|
5
|
+
before_action :set_paper_trail_whodunnit
|
6
6
|
after_action :verify_authorized
|
7
7
|
|
8
8
|
include Pundit
|
@@ -0,0 +1,22 @@
|
|
1
|
+
class CreateBookmarks < ActiveRecord::Migration
|
2
|
+
def self.up
|
3
|
+
create_table :bookmarks, :force => true do |t|
|
4
|
+
t.integer :user_id, :null => false
|
5
|
+
t.integer :manifestation_id
|
6
|
+
t.text :title
|
7
|
+
t.string :url
|
8
|
+
t.text :note
|
9
|
+
t.boolean :shared
|
10
|
+
|
11
|
+
t.timestamps
|
12
|
+
end
|
13
|
+
|
14
|
+
add_index :bookmarks, :user_id
|
15
|
+
add_index :bookmarks, :manifestation_id
|
16
|
+
add_index :bookmarks, :url
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.down
|
20
|
+
drop_table :bookmarks
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
class CreateSearchHistories < ActiveRecord::Migration
|
2
|
+
def self.up
|
3
|
+
create_table :search_histories do |t|
|
4
|
+
t.integer :user_id
|
5
|
+
t.string :operation, :default => 'searchRetrieve'
|
6
|
+
t.float :version, :default => 1.2
|
7
|
+
t.string :query
|
8
|
+
t.integer :start_record
|
9
|
+
t.integer :maximum_records
|
10
|
+
t.string :record_packing
|
11
|
+
t.string :record_schema
|
12
|
+
t.integer :result_set_ttl
|
13
|
+
t.string :stylesheet
|
14
|
+
t.string :extra_request_data
|
15
|
+
t.integer :number_of_records, :default => 0
|
16
|
+
t.string :result_set_id
|
17
|
+
t.integer :result_set_idle_time
|
18
|
+
t.text :records
|
19
|
+
t.integer :next_record_position
|
20
|
+
t.text :diagnostics
|
21
|
+
t.text :extra_response_data
|
22
|
+
t.text :echoed_search_retrieve_request
|
23
|
+
t.timestamps
|
24
|
+
end
|
25
|
+
add_index :search_histories, :user_id
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.down
|
29
|
+
drop_table :search_histories
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
class CreateBookmarkStats < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :bookmark_stats do |t|
|
4
|
+
t.datetime :start_date
|
5
|
+
t.datetime :end_date
|
6
|
+
t.datetime :started_at
|
7
|
+
t.datetime :completed_at
|
8
|
+
t.text :note
|
9
|
+
|
10
|
+
t.timestamps
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
class CreateBookmarkStatHasManifestations < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :bookmark_stat_has_manifestations do |t|
|
4
|
+
t.integer :bookmark_stat_id, :null => false
|
5
|
+
t.integer :manifestation_id, :null => false
|
6
|
+
t.integer :bookmarks_count
|
7
|
+
|
8
|
+
t.timestamps
|
9
|
+
end
|
10
|
+
add_index :bookmark_stat_has_manifestations, :bookmark_stat_id
|
11
|
+
add_index :bookmark_stat_has_manifestations, :manifestation_id
|
12
|
+
end
|
13
|
+
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
class AddAllowBookmarkExternalUrlToLibraryGroup < ActiveRecord::Migration
|
2
|
+
def self.up
|
3
|
+
add_column :library_groups, :allow_bookmark_external_url, :boolean, :null => false, :default => false
|
4
|
+
end
|
5
|
+
|
6
|
+
def self.down
|
7
|
+
remove_column :library_groups, :allow_bookmark_external_url
|
8
|
+
end
|
9
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
class ActsAsTaggableOnMigration < ActiveRecord::Migration
|
2
|
+
def self.up
|
3
|
+
create_table :tags do |t|
|
4
|
+
t.string :name
|
5
|
+
t.string :name_transcription
|
6
|
+
t.timestamps
|
7
|
+
end
|
8
|
+
|
9
|
+
create_table :taggings do |t|
|
10
|
+
t.references :tag
|
11
|
+
|
12
|
+
# You should make sure that the column created is
|
13
|
+
# long enough to store the required class names.
|
14
|
+
t.references :taggable, :polymorphic => true
|
15
|
+
t.references :tagger, :polymorphic => true
|
16
|
+
|
17
|
+
t.string :context
|
18
|
+
|
19
|
+
t.datetime :created_at
|
20
|
+
end
|
21
|
+
|
22
|
+
add_index :taggings, :tag_id
|
23
|
+
add_index :taggings, [:taggable_id, :taggable_type, :context]
|
24
|
+
end
|
25
|
+
|
26
|
+
def self.down
|
27
|
+
drop_table :taggings
|
28
|
+
drop_table :tags
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
class CreateBookmarkStatTransitions < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :bookmark_stat_transitions do |t|
|
4
|
+
t.string :to_state
|
5
|
+
if ActiveRecord::Base.configurations[Rails.env]["adapter"].try(:match, /mysql/)
|
6
|
+
t.text :metadata
|
7
|
+
else
|
8
|
+
t.text :metadata, default: "{}"
|
9
|
+
end
|
10
|
+
t.integer :sort_key
|
11
|
+
t.integer :bookmark_stat_id
|
12
|
+
t.timestamps
|
13
|
+
end
|
14
|
+
|
15
|
+
add_index :bookmark_stat_transitions, :bookmark_stat_id
|
16
|
+
add_index :bookmark_stat_transitions, [:sort_key, :bookmark_stat_id], unique: true, name: "index_bookmark_stat_transitions_on_sort_key_and_stat_id"
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
class CreateDemands < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :demands do |t|
|
4
|
+
t.integer :user_id
|
5
|
+
t.integer :item_id
|
6
|
+
t.integer :message_id
|
7
|
+
|
8
|
+
t.timestamps null: false
|
9
|
+
end
|
10
|
+
add_index :demands, :user_id
|
11
|
+
add_index :demands, :item_id
|
12
|
+
add_index :demands, :message_id
|
13
|
+
end
|
14
|
+
end
|