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,25 @@
|
|
1
|
+
# Read about fixtures at http://ar.rubyonrails.org/classes/Fixtures.html
|
2
|
+
|
3
|
+
user_export_file_00001:
|
4
|
+
id: 1
|
5
|
+
user_id: 1
|
6
|
+
user_export_file_00002:
|
7
|
+
id: 2
|
8
|
+
user_id: 1
|
9
|
+
user_export_file_00003:
|
10
|
+
id: 3
|
11
|
+
user_id: 1
|
12
|
+
|
13
|
+
# == Schema Information
|
14
|
+
#
|
15
|
+
# Table name: user_export_files
|
16
|
+
#
|
17
|
+
# id :integer not null, primary key
|
18
|
+
# user_id :integer
|
19
|
+
# executed_at :datetime
|
20
|
+
# created_at :datetime
|
21
|
+
# updated_at :datetime
|
22
|
+
# user_export_id :string
|
23
|
+
# user_export_size :integer
|
24
|
+
# user_import_filename :string
|
25
|
+
#
|
@@ -29,3 +29,22 @@ user_group_00003:
|
|
29
29
|
created_at: 2007-12-23 03:15:05.126457 +09:00
|
30
30
|
position: 3
|
31
31
|
valid_period_for_new_user: 730
|
32
|
+
|
33
|
+
# == Schema Information
|
34
|
+
#
|
35
|
+
# Table name: user_groups
|
36
|
+
#
|
37
|
+
# id :integer not null, primary key
|
38
|
+
# name :string
|
39
|
+
# display_name :text
|
40
|
+
# note :text
|
41
|
+
# position :integer
|
42
|
+
# created_at :datetime
|
43
|
+
# updated_at :datetime
|
44
|
+
# deleted_at :datetime
|
45
|
+
# valid_period_for_new_user :integer default(0), not null
|
46
|
+
# expired_at :datetime
|
47
|
+
# number_of_day_to_notify_overdue :integer default(1), not null
|
48
|
+
# number_of_day_to_notify_due_date :integer default(7), not null
|
49
|
+
# number_of_time_to_notify_overdue :integer default(3), not null
|
50
|
+
#
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
|
2
|
+
|
3
|
+
one:
|
4
|
+
id: 1
|
5
|
+
user_id: 1
|
6
|
+
note: MyText
|
7
|
+
executed_at: 2014-01-10 21:22:16
|
8
|
+
user_import_file_name: MyString
|
9
|
+
user_import_content_type: text/csv
|
10
|
+
user_import_file_size: 1
|
11
|
+
user_import_updated_at: 2014-01-10 21:22:16
|
12
|
+
user_import_fingerprint: MyString
|
13
|
+
edit_mode: MyString
|
14
|
+
error_message: MyText
|
15
|
+
|
16
|
+
two:
|
17
|
+
id: 2
|
18
|
+
user_id: 1
|
19
|
+
note: MyText
|
20
|
+
executed_at: 2014-01-10 21:22:16
|
21
|
+
user_import_file_name: MyString
|
22
|
+
user_import_content_type: text/csv
|
23
|
+
user_import_file_size: 1
|
24
|
+
user_import_updated_at: 2014-01-10 21:22:16
|
25
|
+
user_import_fingerprint: MyString
|
26
|
+
edit_mode: MyString
|
27
|
+
error_message: MyText
|
28
|
+
|
29
|
+
# == Schema Information
|
30
|
+
#
|
31
|
+
# Table name: user_import_files
|
32
|
+
#
|
33
|
+
# id :integer not null, primary key
|
34
|
+
# user_id :integer
|
35
|
+
# note :text
|
36
|
+
# executed_at :datetime
|
37
|
+
# user_import_file_name :string
|
38
|
+
# user_import_content_type :string
|
39
|
+
# user_import_file_size :integer
|
40
|
+
# user_import_updated_at :datetime
|
41
|
+
# user_import_fingerprint :string
|
42
|
+
# edit_mode :string
|
43
|
+
# error_message :text
|
44
|
+
# created_at :datetime
|
45
|
+
# updated_at :datetime
|
46
|
+
# user_encoding :string
|
47
|
+
# default_library_id :integer
|
48
|
+
# default_user_group_id :integer
|
49
|
+
# user_import_id :string
|
50
|
+
# user_import_size :integer
|
51
|
+
#
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
|
2
|
+
|
3
|
+
one:
|
4
|
+
id: 1
|
5
|
+
user_import_file_id: 1
|
6
|
+
user_id: 1
|
7
|
+
body: MyText
|
8
|
+
|
9
|
+
two:
|
10
|
+
id: 2
|
11
|
+
user_import_file_id: 1
|
12
|
+
user_id: 2
|
13
|
+
body: MyText
|
14
|
+
|
15
|
+
# == Schema Information
|
16
|
+
#
|
17
|
+
# Table name: user_import_results
|
18
|
+
#
|
19
|
+
# id :integer not null, primary key
|
20
|
+
# user_import_file_id :integer
|
21
|
+
# user_id :integer
|
22
|
+
# body :text
|
23
|
+
# created_at :datetime
|
24
|
+
# updated_at :datetime
|
25
|
+
# error_message :text
|
26
|
+
#
|
@@ -20,9 +20,8 @@ two:
|
|
20
20
|
# start_date :datetime
|
21
21
|
# end_date :datetime
|
22
22
|
# note :text
|
23
|
-
# created_at :datetime
|
24
|
-
# updated_at :datetime
|
23
|
+
# created_at :datetime
|
24
|
+
# updated_at :datetime
|
25
25
|
# started_at :datetime
|
26
26
|
# completed_at :datetime
|
27
27
|
#
|
28
|
-
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
require 'spec_helper'
|
3
|
+
|
4
|
+
describe UserExportFile do
|
5
|
+
fixtures :all
|
6
|
+
|
7
|
+
it "should export in background" do
|
8
|
+
message_count = Message.count
|
9
|
+
file = UserExportFile.new
|
10
|
+
file.user = users(:admin)
|
11
|
+
file.save
|
12
|
+
UserExportFileJob.perform_later(file).should be_truthy
|
13
|
+
Message.count.should eq message_count + 1
|
14
|
+
Message.order(:id).last.subject.should eq 'エクスポートが完了しました'
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
# == Schema Information
|
19
|
+
#
|
20
|
+
# Table name: user_export_files
|
21
|
+
#
|
22
|
+
# id :integer not null, primary key
|
23
|
+
# user_id :integer
|
24
|
+
# executed_at :datetime
|
25
|
+
# created_at :datetime
|
26
|
+
# updated_at :datetime
|
27
|
+
# user_export_id :string
|
28
|
+
# user_export_size :integer
|
29
|
+
# user_import_filename :string
|
30
|
+
#
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
require 'spec_helper'
|
3
|
+
|
4
|
+
describe UserGroup do
|
5
|
+
fixtures :user_groups
|
6
|
+
|
7
|
+
it "should contain string in its display_name" do
|
8
|
+
user_group = user_groups(:user_group_00001)
|
9
|
+
user_group.display_name = "en:test"
|
10
|
+
user_group.valid?.should be_truthy
|
11
|
+
end
|
12
|
+
|
13
|
+
it "should not contain invalid yaml in its display_name" do
|
14
|
+
user_group = user_groups(:user_group_00001)
|
15
|
+
user_group.display_name = "en:test\r\nja: テスト"
|
16
|
+
user_group.valid?.should be_falsy
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
# == Schema Information
|
21
|
+
#
|
22
|
+
# Table name: user_groups
|
23
|
+
#
|
24
|
+
# id :integer not null, primary key
|
25
|
+
# name :string
|
26
|
+
# display_name :text
|
27
|
+
# note :text
|
28
|
+
# position :integer
|
29
|
+
# created_at :datetime
|
30
|
+
# updated_at :datetime
|
31
|
+
# deleted_at :datetime
|
32
|
+
# valid_period_for_new_user :integer default(0), not null
|
33
|
+
# expired_at :datetime
|
34
|
+
# number_of_day_to_notify_overdue :integer default(1), not null
|
35
|
+
# number_of_day_to_notify_due_date :integer default(7), not null
|
36
|
+
# number_of_time_to_notify_overdue :integer default(3), not null
|
37
|
+
#
|
@@ -0,0 +1,220 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
require 'rails_helper'
|
3
|
+
|
4
|
+
describe UserImportFile do
|
5
|
+
fixtures :all
|
6
|
+
|
7
|
+
describe "when its mode is 'create'" do
|
8
|
+
before(:each) do
|
9
|
+
@file = UserImportFile.new user_import: File.new("#{Rails.root}/../../examples/user_import_file_sample.tsv")
|
10
|
+
@file.default_user_group = UserGroup.find(2)
|
11
|
+
@file.default_library = Library.find(3)
|
12
|
+
@file.user = users(:admin)
|
13
|
+
@file.save
|
14
|
+
end
|
15
|
+
|
16
|
+
it "should be imported" do
|
17
|
+
old_users_count = User.count
|
18
|
+
old_import_results_count = UserImportResult.count
|
19
|
+
@file.current_state.should eq 'pending'
|
20
|
+
@file.import_start.should eq({:user_imported => 5, :user_found => 0, :failed => 0, error: 3})
|
21
|
+
User.order('id DESC')[1].username.should eq 'user005'
|
22
|
+
User.order('id DESC')[2].username.should eq 'user003'
|
23
|
+
User.count.should eq old_users_count + 5
|
24
|
+
|
25
|
+
user001 = User.where(username: 'user001').first
|
26
|
+
user001.profile.keyword_list.should eq "日本史\n地理"
|
27
|
+
user001.profile.full_name.should eq '田辺 浩介'
|
28
|
+
user001.profile.full_name_transcription.should eq 'たなべ こうすけ'
|
29
|
+
user001.profile.required_role.name.should eq 'User'
|
30
|
+
user001.locked_at.should be_truthy
|
31
|
+
|
32
|
+
user002 = User.where(username: 'user002').first
|
33
|
+
user002.profile.user_group.name.should eq 'faculty'
|
34
|
+
user002.profile.expired_at.to_i.should eq Time.zone.parse('2013-12-01').end_of_day.to_i
|
35
|
+
user002.valid_password?('4NsxXPLy')
|
36
|
+
user002.profile.user_number.should eq '001002'
|
37
|
+
user002.profile.library.name.should eq 'hachioji'
|
38
|
+
user002.profile.locale.should eq 'en'
|
39
|
+
user002.profile.required_role.name.should eq 'Librarian'
|
40
|
+
user002.locked_at.should be_nil
|
41
|
+
|
42
|
+
user003 = User.where(username: 'user003').first
|
43
|
+
user003.profile.note.should eq 'テストユーザ'
|
44
|
+
user003.role.name.should eq 'Librarian'
|
45
|
+
user003.profile.user_number.should eq '001003'
|
46
|
+
user003.profile.library.name.should eq 'kamata'
|
47
|
+
user003.profile.locale.should eq 'ja'
|
48
|
+
user003.profile.checkout_icalendar_token.should eq 'secrettoken'
|
49
|
+
user003.profile.save_checkout_history.should be_truthy
|
50
|
+
user003.profile.save_search_history.should be_falsy
|
51
|
+
user003.profile.share_bookmarks.should be_falsy
|
52
|
+
User.where(username: 'user000').first.should be_nil
|
53
|
+
UserImportResult.count.should eq old_import_results_count + 10
|
54
|
+
UserImportResult.order('id DESC')[0].error_message.should eq 'line 10: 利用者番号はすでに存在します。'
|
55
|
+
UserImportResult.order('id DESC')[1].error_message.should eq 'line 9: 利用者番号は不正な値です。'
|
56
|
+
UserImportResult.order('id DESC')[2].error_message.should eq 'line 8: パスワードは6文字以上で入力してください。'
|
57
|
+
|
58
|
+
user005 = User.where(username: 'user005').first
|
59
|
+
user005.role.name.should eq 'User'
|
60
|
+
user005.profile.library.name.should eq 'hachioji'
|
61
|
+
user005.profile.locale.should eq 'en'
|
62
|
+
user005.profile.user_number.should eq '001005'
|
63
|
+
user005.profile.user_group.name.should eq 'faculty'
|
64
|
+
|
65
|
+
user006 = User.where(username: 'user006').first
|
66
|
+
user006.role.name.should eq 'User'
|
67
|
+
user006.profile.library.name.should eq 'hachioji'
|
68
|
+
user006.profile.locale.should eq 'en'
|
69
|
+
user006.profile.user_number.should be_nil
|
70
|
+
user006.profile.user_group.name.should eq UserGroup.find(2).name
|
71
|
+
|
72
|
+
@file.user_import_fingerprint.should be_truthy
|
73
|
+
@file.executed_at.should be_truthy
|
74
|
+
|
75
|
+
@file.reload
|
76
|
+
@file.error_message.should eq "次の列は無視されました。 save_search_history, share_bookmarks, invalid\nline 8: パスワードは6文字以上で入力してください。\nline 9: 利用者番号は不正な値です。\nline 10: 利用者番号はすでに存在します。"
|
77
|
+
@file.current_state.should eq 'failed'
|
78
|
+
end
|
79
|
+
|
80
|
+
it "should send message when import is completed" do
|
81
|
+
old_message_count = Message.count
|
82
|
+
@file.user = User.where(username: 'librarian1').first
|
83
|
+
@file.import_start
|
84
|
+
Message.count.should eq old_message_count + 1
|
85
|
+
Message.order(:id).last.subject.should eq 'インポートが完了しました'
|
86
|
+
end
|
87
|
+
|
88
|
+
it "should not import users that have higher roles than current user's role" do
|
89
|
+
old_users_count = User.count
|
90
|
+
old_import_results_count = UserImportResult.count
|
91
|
+
@file.user = User.where(username: 'librarian1').first
|
92
|
+
@file.import_start.should eq({:user_imported => 4, :user_found => 0, :failed => 1, error: 3})
|
93
|
+
User.order('id DESC')[1].username.should eq 'user005'
|
94
|
+
User.count.should eq old_users_count + 4
|
95
|
+
UserImportResult.count.should eq old_import_results_count + 10
|
96
|
+
end
|
97
|
+
end
|
98
|
+
|
99
|
+
describe "when its mode is 'update'" do
|
100
|
+
before(:each) do
|
101
|
+
FactoryGirl.create(:user,
|
102
|
+
username: 'user001',
|
103
|
+
profile: FactoryGirl.create(:profile)
|
104
|
+
)
|
105
|
+
end
|
106
|
+
it "should update users" do
|
107
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_update_file.tsv"), user: users(:admin)
|
108
|
+
old_message_count = Message.count
|
109
|
+
result = @file.modify
|
110
|
+
result.should have_key(:user_updated)
|
111
|
+
user001 = User.where(username: 'user001').first
|
112
|
+
user001.email.should eq 'user001@example.jp'
|
113
|
+
user001.profile.full_name.should eq '田辺 浩介'
|
114
|
+
user001.profile.full_name_transcription.should eq 'たなべこうすけ'
|
115
|
+
user001.profile.user_number.should eq 'user_number_1'
|
116
|
+
user001.profile.note.should eq 'test'
|
117
|
+
user001.profile.keyword_list.should eq 'keyword1 keyword2'
|
118
|
+
Message.count.should eq old_message_count + 1
|
119
|
+
end
|
120
|
+
|
121
|
+
it "should not overwrite with null value" do
|
122
|
+
user = User.where(username: 'user001').first
|
123
|
+
user.profile = FactoryGirl.create(:profile,
|
124
|
+
user_number: '001',
|
125
|
+
full_name: 'User 001',
|
126
|
+
full_name_transcription: 'User 001',
|
127
|
+
locale: 'ja',
|
128
|
+
note: 'Note',
|
129
|
+
keyword_list: 'keyword1 keyword2',
|
130
|
+
date_of_birth: 10.years.ago)
|
131
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_update_file2.tsv"), user: users(:admin)
|
132
|
+
result = @file.modify
|
133
|
+
result.should have_key(:user_updated)
|
134
|
+
user001 = User.find('user001')
|
135
|
+
user001.email.should eq 'user001@example.jp'
|
136
|
+
user001.profile.user_number.should eq '001'
|
137
|
+
user001.profile.full_name.should eq 'User 001'
|
138
|
+
user001.profile.full_name_transcription.should eq 'User 001'
|
139
|
+
user001.profile.keyword_list.should eq 'keyword1 keyword2'
|
140
|
+
end
|
141
|
+
it "should update user_number" do
|
142
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_update_file3.tsv"), user: users(:admin)
|
143
|
+
result = @file.modify
|
144
|
+
result.should have_key(:user_updated)
|
145
|
+
user001 = User.where(username: 'user001').first
|
146
|
+
user001.profile.user_number.should eq '0001'
|
147
|
+
end
|
148
|
+
it "should update user's lock status" do
|
149
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_update_file4.tsv"), user: users(:admin)
|
150
|
+
result = @file.modify
|
151
|
+
result.should have_key(:user_updated)
|
152
|
+
user001 = User.where(username: 'user001').first
|
153
|
+
user001.access_locked?.should be_truthy
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
describe "when its mode is 'destroy'" do
|
158
|
+
before(:each) do
|
159
|
+
@file = UserImportFile.new user_import: File.new("#{Rails.root}/../../examples/user_import_file_sample.tsv"), user: users(:admin)
|
160
|
+
@file.user = users(:admin)
|
161
|
+
@file.default_user_group = UserGroup.find(2)
|
162
|
+
@file.default_library = Library.find(3)
|
163
|
+
@file.save
|
164
|
+
@file.import_start
|
165
|
+
end
|
166
|
+
|
167
|
+
it "should remove users" do
|
168
|
+
old_count = User.count
|
169
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_delete_file.tsv"), user: users(:admin)
|
170
|
+
@file.user = users(:admin)
|
171
|
+
old_message_count = Message.count
|
172
|
+
@file.remove
|
173
|
+
User.count.should eq old_count - 2
|
174
|
+
Message.count.should eq old_message_count + 1
|
175
|
+
end
|
176
|
+
|
177
|
+
it "should not remove users if there are checkouts" do
|
178
|
+
user001 = User.where(username: 'user001').first
|
179
|
+
FactoryGirl.create(:checkout, user: user001, item: FactoryGirl.create(:item))
|
180
|
+
old_count = User.count
|
181
|
+
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_delete_file.tsv"), user: users(:admin)
|
182
|
+
@file.remove
|
183
|
+
User.where(username: 'user001').should_not be_blank
|
184
|
+
User.count.should eq old_count - 2
|
185
|
+
end
|
186
|
+
end
|
187
|
+
|
188
|
+
it "should import in background" do
|
189
|
+
file = UserImportFile.new user_import: File.new("#{Rails.root}/../../examples/user_import_file_sample.tsv"), user: users(:admin)
|
190
|
+
file.user = users(:admin)
|
191
|
+
file.default_user_group = UserGroup.find(2)
|
192
|
+
file.default_library = Library.find(3)
|
193
|
+
file.save
|
194
|
+
UserImportFileJob.perform_later(file).should be_truthy
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
# == Schema Information
|
199
|
+
#
|
200
|
+
# Table name: user_import_files
|
201
|
+
#
|
202
|
+
# id :integer not null, primary key
|
203
|
+
# user_id :integer
|
204
|
+
# note :text
|
205
|
+
# executed_at :datetime
|
206
|
+
# user_import_file_name :string
|
207
|
+
# user_import_content_type :string
|
208
|
+
# user_import_file_size :integer
|
209
|
+
# user_import_updated_at :datetime
|
210
|
+
# user_import_fingerprint :string
|
211
|
+
# edit_mode :string
|
212
|
+
# error_message :text
|
213
|
+
# created_at :datetime
|
214
|
+
# updated_at :datetime
|
215
|
+
# user_encoding :string
|
216
|
+
# default_library_id :integer
|
217
|
+
# default_user_group_id :integer
|
218
|
+
# user_import_id :string
|
219
|
+
# user_import_size :integer
|
220
|
+
#
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
require 'spec_helper'
|
3
|
+
|
4
|
+
describe UserImportResult do
|
5
|
+
#pending "add some examples to (or delete) #{__FILE__}"
|
6
|
+
|
7
|
+
end
|
8
|
+
|
9
|
+
# == Schema Information
|
10
|
+
#
|
11
|
+
# Table name: user_import_results
|
12
|
+
#
|
13
|
+
# id :integer not null, primary key
|
14
|
+
# user_import_file_id :integer
|
15
|
+
# user_id :integer
|
16
|
+
# body :text
|
17
|
+
# created_at :datetime
|
18
|
+
# updated_at :datetime
|
19
|
+
# error_message :text
|
20
|
+
#
|
data/spec/support/devise.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
1
|
RSpec.configure do |config|
|
2
|
-
config.include Devise::
|
3
|
-
config.include Devise::
|
2
|
+
config.include Devise::Test::ControllerHelpers, type: :controller
|
3
|
+
config.include Devise::Test::ControllerHelpers, type: :view
|
4
4
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe "user_export_files/new" do
|
4
|
+
before(:each) do
|
5
|
+
assign(:user_export_file, stub_model(
|
6
|
+
UserExportFile
|
7
|
+
).as_new_record)
|
8
|
+
view.stub(:current_user).and_return(User.find('enjuadmin'))
|
9
|
+
end
|
10
|
+
|
11
|
+
it "renders new user form" do
|
12
|
+
render
|
13
|
+
|
14
|
+
# Run the generator again with the --webrat flag if you want to use webrat matchers
|
15
|
+
assert_select "form", action: user_export_files_path, method: "post" do
|
16
|
+
assert_select "input", name: "commit"
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'rails_helper'
|
2
|
+
|
3
|
+
describe "user_import_results/index" do
|
4
|
+
fixtures :all
|
5
|
+
|
6
|
+
before(:each) do
|
7
|
+
assign(:user_import_results, UserImportResult.page(1))
|
8
|
+
admin = User.find('enjuadmin')
|
9
|
+
view.stub(:current_user).and_return(admin)
|
10
|
+
end
|
11
|
+
|
12
|
+
it "renders a list of user_import_results" do
|
13
|
+
render
|
14
|
+
expect(rendered).to match /MyString/
|
15
|
+
end
|
16
|
+
|
17
|
+
context "with @user_import_file" do
|
18
|
+
before(:each) do
|
19
|
+
@user_import_file = UserImportFile.find(1)
|
20
|
+
@user_import_results = UserImportResult.where(user_import_file_id: 1).page(1)
|
21
|
+
end
|
22
|
+
it "renders a list of user_import_results for the user_import_file" do
|
23
|
+
render
|
24
|
+
expect(view).to render_template "user_import_results/_list_lines"
|
25
|
+
expect(rendered).to match /MyString/
|
26
|
+
expect(rendered).to match /<td>1<\/td>/
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|