exlibris-primo 0.1.5 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/MIT-LICENSE +1 -1
- data/README.md +111 -0
- data/Rakefile +2 -1
- data/lib/exlibris-primo.rb +4 -14
- data/lib/exlibris/primo.rb +13 -0
- data/lib/exlibris/primo/abstract.rb +28 -0
- data/lib/exlibris/primo/chain_gang/README.md +9 -0
- data/lib/exlibris/primo/chain_gang/base.rb +121 -0
- data/lib/exlibris/primo/chain_gang/record.rb +18 -0
- data/lib/exlibris/primo/chain_gang/search.rb +319 -0
- data/lib/exlibris/primo/chain_gang/user.rb +18 -0
- data/lib/exlibris/primo/config.rb +69 -0
- data/lib/exlibris/primo/eshelf.rb +115 -62
- data/lib/exlibris/primo/facet.rb +40 -0
- data/lib/exlibris/primo/facet_value.rb +40 -0
- data/lib/exlibris/primo/holding.rb +81 -152
- data/lib/exlibris/primo/link.rb +32 -0
- data/lib/exlibris/primo/namespaces.rb +44 -0
- data/lib/exlibris/primo/pnx/dedup_mgr.rb +91 -0
- data/lib/exlibris/primo/pnx/elements.rb +79 -0
- data/lib/exlibris/primo/pnx/frbr.rb +24 -0
- data/lib/exlibris/primo/pnx/holdings.rb +36 -0
- data/lib/exlibris/primo/pnx/links.rb +54 -0
- data/lib/exlibris/primo/pnx/openurl.rb +24 -0
- data/lib/exlibris/primo/pnx/subfields.rb +18 -0
- data/lib/exlibris/primo/record.rb +20 -106
- data/lib/exlibris/primo/request_attributes.rb +28 -0
- data/lib/exlibris/primo/review.rb +46 -0
- data/lib/exlibris/primo/reviews.rb +81 -0
- data/lib/exlibris/primo/search.rb +82 -0
- data/lib/exlibris/primo/source/aleph.rb +77 -31
- data/lib/exlibris/primo/tag.rb +34 -0
- data/lib/exlibris/primo/tags.rb +103 -0
- data/lib/exlibris/primo/version.rb +1 -1
- data/lib/exlibris/primo/web_service/client/base.rb +30 -0
- data/lib/exlibris/primo/web_service/client/base/endpoint.rb +29 -0
- data/lib/exlibris/primo/web_service/client/base/savon_client.rb +24 -0
- data/lib/exlibris/primo/web_service/client/base/savon_config.rb +19 -0
- data/lib/exlibris/primo/web_service/client/base/soap_actions.rb +55 -0
- data/lib/exlibris/primo/web_service/client/base/wsdl.rb +14 -0
- data/lib/exlibris/primo/web_service/client/eshelf.rb +22 -0
- data/lib/exlibris/primo/web_service/client/reviews.rb +15 -0
- data/lib/exlibris/primo/web_service/client/search.rb +15 -0
- data/lib/exlibris/primo/web_service/client/tags.rb +14 -0
- data/lib/exlibris/primo/web_service/request/base.rb +77 -0
- data/lib/exlibris/primo/web_service/request/base/base_elements.rb +71 -0
- data/lib/exlibris/primo/web_service/request/base/call.rb +19 -0
- data/lib/exlibris/primo/web_service/request/base/client.rb +45 -0
- data/lib/exlibris/primo/web_service/request/base/soap_action.rb +29 -0
- data/lib/exlibris/primo/web_service/request/eshelf.rb +71 -0
- data/lib/exlibris/primo/web_service/request/reviews.rb +57 -0
- data/lib/exlibris/primo/web_service/request/search.rb +49 -0
- data/lib/exlibris/primo/web_service/request/search/display_fields.rb +30 -0
- data/lib/exlibris/primo/web_service/request/search/languages.rb +32 -0
- data/lib/exlibris/primo/web_service/request/search/location.rb +15 -0
- data/lib/exlibris/primo/web_service/request/search/locations.rb +33 -0
- data/lib/exlibris/primo/web_service/request/search/query_term.rb +43 -0
- data/lib/exlibris/primo/web_service/request/search/query_terms.rb +40 -0
- data/lib/exlibris/primo/web_service/request/search/search_elements.rb +97 -0
- data/lib/exlibris/primo/web_service/request/search/sort_bys.rb +32 -0
- data/lib/exlibris/primo/web_service/request/tags.rb +56 -0
- data/lib/exlibris/primo/web_service/response/base.rb +28 -0
- data/lib/exlibris/primo/web_service/response/base/error.rb +25 -0
- data/lib/exlibris/primo/web_service/response/base/util.rb +19 -0
- data/lib/exlibris/primo/web_service/response/did_u_mean.rb +17 -0
- data/lib/exlibris/primo/web_service/response/eshelf.rb +68 -0
- data/lib/exlibris/primo/web_service/response/facets.rb +21 -0
- data/lib/exlibris/primo/web_service/response/records.rb +17 -0
- data/lib/exlibris/primo/web_service/response/reviews.rb +49 -0
- data/lib/exlibris/primo/web_service/response/search.rb +36 -0
- data/lib/exlibris/primo/web_service/response/search_stats.rb +48 -0
- data/lib/exlibris/primo/web_service/response/tags.rb +54 -0
- data/lib/exlibris/primo/write_attributes.rb +38 -0
- data/lib/exlibris/primo/xml_util.rb +63 -0
- data/test/{unit/eshelf_test.rb → bak/eshelf_test.rb.bak} +0 -0
- data/test/{unit/record_test.rb → bak/record_test.rb.bak} +0 -0
- data/test/{unit/searcher_test.rb → bak/searcher_test.rb.bak} +0 -0
- data/test/{unit/web_service_test.rb → bak/web_service_test.rb.bak} +0 -0
- data/test/config_test.rb +72 -0
- data/test/eshelf_test.rb +66 -0
- data/test/exlibris-primo_test.rb +0 -1
- data/test/facet_test.rb +27 -0
- data/test/facet_value_test.rb +62 -0
- data/test/holding_test.rb +26 -0
- data/test/link_test.rb +42 -0
- data/test/pnx/dedup_mgr_test.rb +16 -0
- data/test/pnx/elements_test.rb +16 -0
- data/test/pnx/frbr_test.rb +12 -0
- data/test/pnx/holdings_test.rb +53 -0
- data/test/pnx/links_test.rb +44 -0
- data/test/pnx/openurl_test.rb +10 -0
- data/test/record_test.rb +11 -0
- data/test/review_test.rb +15 -0
- data/test/reviews_test.rb +50 -0
- data/test/search_test.rb +328 -0
- data/test/source/aleph_test.rb +52 -0
- data/test/support/config.yml +35 -0
- data/test/tag_test.rb +12 -0
- data/test/tags_test.rb +65 -0
- data/test/test_helper.rb +536 -4
- data/test/vcr_cassettes/client_action_no_arguments.yml +38 -0
- data/test/vcr_cassettes/client_get_all_my_reviews.yml +49 -0
- data/test/vcr_cassettes/client_get_all_my_tags.yml +49 -0
- data/test/vcr_cassettes/client_get_eshelf.yml +13812 -0
- data/test/vcr_cassettes/client_get_record.yml +222 -0
- data/test/vcr_cassettes/client_get_reviews.yml +39 -0
- data/test/vcr_cassettes/client_get_tags.yml +42 -0
- data/test/vcr_cassettes/client_search_brief_isbn.yml +288 -0
- data/test/vcr_cassettes/client_search_brief_issn.yml +282 -0
- data/test/vcr_cassettes/client_too_many_arguments.yml +38 -0
- data/test/vcr_cassettes/eshelf.yml +13845 -0
- data/test/vcr_cassettes/eshelf_add_folder.yml +109 -0
- data/test/vcr_cassettes/eshelf_add_record.yml +14237 -0
- data/test/vcr_cassettes/eshelf_add_records.yml +14156 -0
- data/test/vcr_cassettes/eshelf_basket_id.yml +36 -0
- data/test/vcr_cassettes/eshelf_records.yml +13460 -0
- data/test/vcr_cassettes/eshelf_remove_folder.yml +76 -0
- data/test/vcr_cassettes/eshelf_remove_record.yml +13500 -0
- data/test/vcr_cassettes/eshelf_remove_records.yml +13741 -0
- data/test/vcr_cassettes/{web_service_single_document.yml → remote_record_call.yml} +12 -23
- data/test/vcr_cassettes/{searcher_dedupmrg_by_id.yml → remote_record_dedupmgr.yml} +19 -31
- data/test/vcr_cassettes/request_add_folder_to_eshelf.yml +43 -0
- data/test/vcr_cassettes/request_add_to_eshelf.yml +43 -0
- data/test/vcr_cassettes/request_did_u_mean_enabled.yml +48 -0
- data/test/vcr_cassettes/request_full_view.yml +222 -0
- data/test/vcr_cassettes/request_get_eshelf.yml +13812 -0
- data/test/vcr_cassettes/request_get_eshelf_structure.yml +36 -0
- data/test/vcr_cassettes/request_get_reviews.yml +39 -0
- data/test/vcr_cassettes/request_get_tags.yml +42 -0
- data/test/vcr_cassettes/request_remove_folder_from_eshelf.yml +43 -0
- data/test/vcr_cassettes/request_remove_from_eshelf.yml +43 -0
- data/test/vcr_cassettes/request_search_author.yml +1258 -0
- data/test/vcr_cassettes/request_search_did_u_mean.yml +48 -0
- data/test/vcr_cassettes/request_search_genre.yml +1321 -0
- data/test/vcr_cassettes/request_search_isbn.yml +288 -0
- data/test/vcr_cassettes/request_search_issn.yml +282 -0
- data/test/vcr_cassettes/request_search_locations.yml +288 -0
- data/test/vcr_cassettes/request_search_title.yml +1024 -0
- data/test/vcr_cassettes/request_search_title_author_genre.yml +708 -0
- data/test/vcr_cassettes/response_add_folder_to_eshelf.yml +43 -0
- data/test/vcr_cassettes/response_add_review.yml +39 -0
- data/test/vcr_cassettes/response_add_tag.yml +39 -0
- data/test/vcr_cassettes/response_add_to_eshelf.yml +43 -0
- data/test/vcr_cassettes/response_did_u_mean_disabled.yml +46 -0
- data/test/vcr_cassettes/response_did_u_mean_enabled.yml +48 -0
- data/test/vcr_cassettes/response_full_view.yml +222 -0
- data/test/vcr_cassettes/response_get_all_my_reviews.yml +49 -0
- data/test/vcr_cassettes/response_get_all_my_tags.yml +49 -0
- data/test/vcr_cassettes/response_get_eshelf.yml +13633 -0
- data/test/vcr_cassettes/response_get_eshelf_structure.yml +36 -0
- data/test/vcr_cassettes/response_get_reviews.yml +39 -0
- data/test/vcr_cassettes/response_get_reviews_by_rating.yml +49 -0
- data/test/vcr_cassettes/response_get_reviews_for_record.yml +39 -0
- data/test/vcr_cassettes/response_get_tags.yml +42 -0
- data/test/vcr_cassettes/response_get_tags_for_record.yml +42 -0
- data/test/vcr_cassettes/response_remove_folder_from_eshelf.yml +43 -0
- data/test/vcr_cassettes/response_remove_from_eshelf.yml +43 -0
- data/test/vcr_cassettes/response_remove_review.yml +39 -0
- data/test/vcr_cassettes/response_remove_tag.yml +39 -0
- data/test/vcr_cassettes/response_remove_user_tags.yml +39 -0
- data/test/vcr_cassettes/response_search.yml +288 -0
- data/test/vcr_cassettes/response_search_did_u_mean.yml +48 -0
- data/test/vcr_cassettes/reviews.yml +49 -0
- data/test/vcr_cassettes/reviews_add_review.yml +39 -0
- data/test/vcr_cassettes/reviews_check_empty_reviews_first.yml +39 -0
- data/test/vcr_cassettes/reviews_check_empty_reviews_last.yml +39 -0
- data/test/vcr_cassettes/reviews_rating.yml +168 -0
- data/test/vcr_cassettes/reviews_record.yml +49 -0
- data/test/vcr_cassettes/reviews_remove_review.yml +39 -0
- data/test/vcr_cassettes/reviews_reviews.yml +49 -0
- data/test/vcr_cassettes/reviews_user.yml +58 -0
- data/test/vcr_cassettes/search_chaining_author_title.yml +938 -0
- data/test/vcr_cassettes/search_chaining_contains_any.yml +1453 -0
- data/test/vcr_cassettes/search_chaining_contains_author_starts_with_title.yml +1055 -0
- data/test/vcr_cassettes/search_chaining_isbn.yml +288 -0
- data/test/vcr_cassettes/search_chaining_page_size_author.yml +5933 -0
- data/test/vcr_cassettes/search_did_u_mean.yml +48 -0
- data/test/vcr_cassettes/search_enable_highlighting.yml +1337 -0
- data/test/vcr_cassettes/search_isbn.yml +288 -0
- data/test/vcr_cassettes/search_languages.yml +1332 -0
- data/test/vcr_cassettes/search_locations.yml +1440 -0
- data/test/vcr_cassettes/search_record_id.yml +222 -0
- data/test/vcr_cassettes/search_record_id_chaining.yml +222 -0
- data/test/vcr_cassettes/search_sort_by.yml +1289 -0
- data/test/vcr_cassettes/search_sort_by_locations.yml +1387 -0
- data/test/vcr_cassettes/tags.yml +56 -0
- data/test/vcr_cassettes/tags_add_extra_tag.yml +39 -0
- data/test/vcr_cassettes/tags_add_tag.yml +39 -0
- data/test/vcr_cassettes/tags_add_tags.yml +111 -0
- data/test/vcr_cassettes/tags_check_1_tags.yml +56 -0
- data/test/vcr_cassettes/tags_check_2_tags.yml +68 -0
- data/test/vcr_cassettes/tags_check_empty_tags_first.yml +42 -0
- data/test/vcr_cassettes/tags_check_empty_tags_last.yml +42 -0
- data/test/vcr_cassettes/tags_remove_tag.yml +39 -0
- data/test/vcr_cassettes/tags_remove_tags.yml +111 -0
- data/test/vcr_cassettes/tags_remove_user_tags.yml +39 -0
- data/test/vcr_cassettes/tags_tags.yml +104 -0
- data/test/vcr_cassettes/tags_user.yml +73 -0
- data/test/web_service/client/abstract_test.rb +29 -0
- data/test/web_service/client/eshelf_test.rb +22 -0
- data/test/web_service/client/reviews_test.rb +31 -0
- data/test/web_service/client/savon_client_test.rb +17 -0
- data/test/web_service/client/search_benchmarks.rb +29 -0
- data/test/web_service/client/search_test.rb +44 -0
- data/test/web_service/client/soap_actions_test.rb +45 -0
- data/test/web_service/client/tags_test.rb +31 -0
- data/test/web_service/request/abstract_test.rb +68 -0
- data/test/web_service/request/base_elements_test.rb +231 -0
- data/test/web_service/request/build_xml_test.rb +23 -0
- data/test/web_service/request/client_test.rb +53 -0
- data/test/web_service/request/eshelf_test.rb +26 -0
- data/test/web_service/request/location_test.rb +25 -0
- data/test/web_service/request/query_term_test.rb +29 -0
- data/test/web_service/request/reviews_test.rb +27 -0
- data/test/web_service/request/search_test.rb +234 -0
- data/test/web_service/request/soap_action_test.rb +120 -0
- data/test/web_service/request/tags_test.rb +27 -0
- data/test/web_service/response/abstract_test.rb +200 -0
- data/test/web_service/response/did_u_mean_test.rb +44 -0
- data/test/web_service/response/error_test.rb +31 -0
- data/test/web_service/response/eshelf_test.rb +28 -0
- data/test/web_service/response/facets_test.rb +42 -0
- data/test/web_service/response/records_test.rb +56 -0
- data/test/web_service/response/reviews_test.rb +28 -0
- data/test/web_service/response/search_stats_test.rb +75 -0
- data/test/web_service/response/search_test.rb +40 -0
- data/test/web_service/response/tags_test.rb +28 -0
- data/test/xml_util_test.rb +23 -0
- metadata +456 -114
- data/README.rdoc +0 -68
- data/lib/exlibris/primo/related_link.rb +0 -20
- data/lib/exlibris/primo/rsrc.rb +0 -20
- data/lib/exlibris/primo/searcher.rb +0 -277
- data/lib/exlibris/primo/toc.rb +0 -20
- data/lib/exlibris/primo/web_service.rb +0 -203
- data/test/unit/searcher_benchmarks.rb +0 -74
- data/test/unit/web_service_benchmarks.rb +0 -58
- data/test/vcr_cassettes/eshelf_add_invalid_records.yml +0 -107
- data/test/vcr_cassettes/eshelf_add_same_record_twice.yml +0 -159
- data/test/vcr_cassettes/eshelf_add_to_empty_basket.yml +0 -107
- data/test/vcr_cassettes/eshelf_add_to_invalid_basket.yml +0 -55
- data/test/vcr_cassettes/eshelf_invalid_eshelf.yml +0 -55
- data/test/vcr_cassettes/eshelf_invalid_institution.yml +0 -55
- data/test/vcr_cassettes/eshelf_valid_eshelf.yml +0 -2553
- data/test/vcr_cassettes/eshelf_valid_eshelf_structure.yml +0 -47
- data/test/vcr_cassettes/record.yml +0 -212
- data/test/vcr_cassettes/record_invalid_record.yml +0 -55
- data/test/vcr_cassettes/record_sub_record.yml +0 -212
- data/test/vcr_cassettes/record_valid_record.yml +0 -212
- data/test/vcr_cassettes/searcher_base_holdings_by_id.yml +0 -212
- data/test/vcr_cassettes/searcher_diacritics1_by_id.yml +0 -207
- data/test/vcr_cassettes/searcher_diacritics2_by_id.yml +0 -232
- data/test/vcr_cassettes/searcher_holdings_by_id.yml +0 -212
- data/test/vcr_cassettes/searcher_invalid_id.yml +0 -55
- data/test/vcr_cassettes/searcher_rsrcs_by_id.yml +0 -270
- data/test/vcr_cassettes/searcher_search_by_isbn.yml +0 -278
- data/test/vcr_cassettes/searcher_search_by_issn.yml +0 -297
- data/test/vcr_cassettes/searcher_search_by_title_author_genre.yml +0 -671
- data/test/vcr_cassettes/searcher_test_bug_1361.yml +0 -224
- data/test/vcr_cassettes/searcher_test_problem_by_id.yml +0 -194
- data/test/vcr_cassettes/searcher_tocs_by_id.yml +0 -217
- data/test/vcr_cassettes/web_service_author_search.yml +0 -1269
- data/test/vcr_cassettes/web_service_bogus_200.yml +0 -392
- data/test/vcr_cassettes/web_service_brief_search.yml +0 -299
- data/test/vcr_cassettes/web_service_get_eshelf.yml +0 -11823
- data/test/vcr_cassettes/web_service_get_eshelf_structure_search.yml +0 -47
- data/test/vcr_cassettes/web_service_invalid_document.yml +0 -54
- data/test/vcr_cassettes/web_service_isbn_search.yml +0 -299
- data/test/vcr_cassettes/web_service_issn_search.yml +0 -293
- data/test/vcr_cassettes/web_service_problem_document.yml +0 -193
- data/test/vcr_cassettes/web_service_title_author_genre_search.yml +0 -719
- data/test/vcr_cassettes/web_service_title_search.yml +0 -1035
@@ -0,0 +1,27 @@
|
|
1
|
+
module WebService
|
2
|
+
module Request
|
3
|
+
require 'test_helper'
|
4
|
+
class TagsTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@institution = "NYU"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@doc_id = "nyu_aleph000062856"
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_get_tags
|
13
|
+
request = Exlibris::Primo::WebService::Request::GetTags.new :base_url => @base_url,
|
14
|
+
:institution => @institution, :doc_id => @doc_id, :user_id => @user_id
|
15
|
+
assert_request request, "getTagsRequest",
|
16
|
+
"<institution>NYU</institution>",
|
17
|
+
"<docId>nyu_aleph000062856</docId>",
|
18
|
+
"<userId>N12162279</userId>"
|
19
|
+
VCR.use_cassette('request get tags') do
|
20
|
+
assert_nothing_raised {
|
21
|
+
response = request.call
|
22
|
+
}
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,200 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class AbstractTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
@basket_id ="210075761"
|
13
|
+
@new_folder_name = "new folder"
|
14
|
+
@folder_to_remove = "377472735"
|
15
|
+
end
|
16
|
+
|
17
|
+
def test_abstract_raise
|
18
|
+
assert_raise(NotImplementedError) {
|
19
|
+
Exlibris::Primo::WebService::Response::Base.new "", ""
|
20
|
+
}
|
21
|
+
assert_raise(NotImplementedError) {
|
22
|
+
Exlibris::Primo::WebService::Response::Eshelf.new "", ""
|
23
|
+
}
|
24
|
+
assert_raise(NotImplementedError) {
|
25
|
+
Exlibris::Primo::WebService::Response::Reviews.new "", ""
|
26
|
+
}
|
27
|
+
assert_raise(NotImplementedError) {
|
28
|
+
Exlibris::Primo::WebService::Response::Tags.new "", ""
|
29
|
+
}
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_non_abstract_nothing_raised
|
33
|
+
assert_nothing_raised {
|
34
|
+
VCR.use_cassette('response get eshelf structure') {
|
35
|
+
soap_action = :get_eshelf_structure
|
36
|
+
request = Exlibris::Primo::WebService::Request::GetEshelfStructure.new(:user_id => @user_id,
|
37
|
+
:institution => @institution)
|
38
|
+
client = Exlibris::Primo::WebService::Client::EshelfStructure.new(:base_url => @base_url)
|
39
|
+
response =Exlibris::Primo::WebService::Response::GetEshelfStructure.new(
|
40
|
+
client.send(soap_action, request.to_xml), soap_action)
|
41
|
+
}
|
42
|
+
VCR.use_cassette('response get eshelf') {
|
43
|
+
soap_action = :get_eshelf
|
44
|
+
request = Exlibris::Primo::WebService::Request::GetEshelf.new(:user_id => @user_id,
|
45
|
+
:institution => @institution)
|
46
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
47
|
+
response =Exlibris::Primo::WebService::Response::GetEshelf.new(
|
48
|
+
client.send(soap_action, request.to_xml), soap_action)
|
49
|
+
}
|
50
|
+
VCR.use_cassette('response add to eshelf') {
|
51
|
+
soap_action = :add_to_eshelf
|
52
|
+
request = Exlibris::Primo::WebService::Request::AddToEshelf.new(:user_id => @user_id,
|
53
|
+
:institution => @institution, :doc_id => @doc_id, :folder_id => @basket_id)
|
54
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
55
|
+
response =Exlibris::Primo::WebService::Response::AddToEshelf.new(
|
56
|
+
client.send(soap_action, request.to_xml), soap_action)
|
57
|
+
}
|
58
|
+
VCR.use_cassette('response remove from eshelf') {
|
59
|
+
soap_action = :remove_from_eshelf
|
60
|
+
request = Exlibris::Primo::WebService::Request::RemoveFromEshelf.new(:user_id => @user_id,
|
61
|
+
:institution => @institution, :doc_id => @doc_id, :folder_id => @basket_id)
|
62
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
63
|
+
response =Exlibris::Primo::WebService::Response::RemoveFromEshelf.new(
|
64
|
+
client.send(soap_action, request.to_xml), soap_action)
|
65
|
+
}
|
66
|
+
VCR.use_cassette('response add folder to eshelf') {
|
67
|
+
soap_action = :add_folder_to_eshelf
|
68
|
+
request = Exlibris::Primo::WebService::Request::AddFolderToEshelf.new(:user_id => @user_id,
|
69
|
+
:institution => @institution, :parent_folder => @basket_id, :folder_name => @new_folder_name)
|
70
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
71
|
+
response =Exlibris::Primo::WebService::Response::AddFolderToEshelf.new(
|
72
|
+
client.send(soap_action, request.to_xml), soap_action)
|
73
|
+
}
|
74
|
+
VCR.use_cassette('response remove folder from eshelf') {
|
75
|
+
soap_action = :remove_folder_from_eshelf
|
76
|
+
request = Exlibris::Primo::WebService::Request::RemoveFolderFromEshelf.new(:user_id => @user_id,
|
77
|
+
:institution => @institution, :folder_id => @folder_to_remove)
|
78
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
79
|
+
response =Exlibris::Primo::WebService::Response::RemoveFolderFromEshelf.new(
|
80
|
+
client.send(soap_action, request.to_xml), soap_action)
|
81
|
+
}
|
82
|
+
VCR.use_cassette('response get reviews') {
|
83
|
+
soap_action = :get_reviews
|
84
|
+
request = Exlibris::Primo::WebService::Request::GetReviews.new(:user_id => @user_id,
|
85
|
+
:institution => @institution, :doc_id => @doc_id)
|
86
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
87
|
+
response =Exlibris::Primo::WebService::Response::GetReviews.new(
|
88
|
+
client.send(soap_action, request.to_xml), soap_action)
|
89
|
+
}
|
90
|
+
VCR.use_cassette('response get all my reviews') {
|
91
|
+
soap_action = :get_all_my_reviews
|
92
|
+
request = Exlibris::Primo::WebService::Request::GetAllMyReviews.new(:user_id => @user_id,
|
93
|
+
:institution => @institution)
|
94
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
95
|
+
response =Exlibris::Primo::WebService::Response::GetAllMyReviews.new(
|
96
|
+
client.send(soap_action, request.to_xml), soap_action)
|
97
|
+
}
|
98
|
+
VCR.use_cassette('response get reviews for record') {
|
99
|
+
soap_action = :get_reviews_for_record
|
100
|
+
request = Exlibris::Primo::WebService::Request::GetReviewsForRecord.new(
|
101
|
+
:institution => @institution, :doc_id => @doc_id)
|
102
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
103
|
+
response =Exlibris::Primo::WebService::Response::GetReviewsForRecord.new(
|
104
|
+
client.send(soap_action, request.to_xml), soap_action)
|
105
|
+
}
|
106
|
+
VCR.use_cassette('response get reviews by rating') {
|
107
|
+
soap_action = :get_reviews_by_rating
|
108
|
+
request = Exlibris::Primo::WebService::Request::GetReviewsByRating.new(:user_id => @user_id,
|
109
|
+
:institution => @institution, :rating => "1")
|
110
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
111
|
+
response =Exlibris::Primo::WebService::Response::GetReviewsByRating.new(
|
112
|
+
client.send(soap_action, request.to_xml), soap_action)
|
113
|
+
}
|
114
|
+
VCR.use_cassette('response add review') {
|
115
|
+
soap_action = :add_review
|
116
|
+
request = Exlibris::Primo::WebService::Request::AddReview.new(:user_id => @user_id,
|
117
|
+
:institution => @institution, :doc_id => @doc_id, :value => "Test reviews", :rating => "1", :user_display_name => "Test user display name",
|
118
|
+
:allow_user_name => "true", :status => "2")
|
119
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
120
|
+
response =Exlibris::Primo::WebService::Response::AddReview.new(
|
121
|
+
client.send(soap_action, request.to_xml), soap_action)
|
122
|
+
}
|
123
|
+
VCR.use_cassette('response remove review') {
|
124
|
+
soap_action = :remove_review
|
125
|
+
request = Exlibris::Primo::WebService::Request::RemoveReview.new(:user_id => @user_id,
|
126
|
+
:institution => @institution, :doc_id => @doc_id)
|
127
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
128
|
+
response =Exlibris::Primo::WebService::Response::RemoveReview.new(
|
129
|
+
client.send(soap_action, request.to_xml), soap_action)
|
130
|
+
}
|
131
|
+
VCR.use_cassette('response get tags') {
|
132
|
+
soap_action = :get_tags
|
133
|
+
request = Exlibris::Primo::WebService::Request::GetTags.new(:user_id => @user_id,
|
134
|
+
:institution => @institution, :doc_id => @doc_id)
|
135
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
136
|
+
response =Exlibris::Primo::WebService::Response::GetTags.new(
|
137
|
+
client.send(soap_action, request.to_xml), soap_action)
|
138
|
+
}
|
139
|
+
VCR.use_cassette('response get all my tags') {
|
140
|
+
soap_action = :get_all_my_tags
|
141
|
+
request = Exlibris::Primo::WebService::Request::GetAllMyTags.new(:user_id => @user_id,
|
142
|
+
:institution => @institution)
|
143
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
144
|
+
response =Exlibris::Primo::WebService::Response::GetAllMyTags.new(
|
145
|
+
client.send(soap_action, request.to_xml), soap_action)
|
146
|
+
}
|
147
|
+
VCR.use_cassette('response get tags for record') {
|
148
|
+
soap_action = :get_tags_for_record
|
149
|
+
request = Exlibris::Primo::WebService::Request::GetTagsForRecord.new(
|
150
|
+
:institution => @institution, :doc_id => @doc_id)
|
151
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
152
|
+
response =Exlibris::Primo::WebService::Response::GetTagsForRecord.new(
|
153
|
+
client.send(soap_action, request.to_xml), soap_action)
|
154
|
+
}
|
155
|
+
VCR.use_cassette('response add tag') {
|
156
|
+
soap_action = :add_tag
|
157
|
+
request = Exlibris::Primo::WebService::Request::AddTag.new(:user_id => @user_id,
|
158
|
+
:institution => @institution, :doc_id => @doc_id, :value => "test tag")
|
159
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
160
|
+
response =Exlibris::Primo::WebService::Response::AddTag.new(
|
161
|
+
client.send(soap_action, request.to_xml), soap_action)
|
162
|
+
}
|
163
|
+
VCR.use_cassette('response remove tag') {
|
164
|
+
soap_action = :remove_tag
|
165
|
+
request = Exlibris::Primo::WebService::Request::RemoveTag.new(:user_id => @user_id,
|
166
|
+
:institution => @institution, :doc_id => @doc_id, :value => "test tag")
|
167
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
168
|
+
response =Exlibris::Primo::WebService::Response::RemoveTag.new(
|
169
|
+
client.send(soap_action, request.to_xml), soap_action)
|
170
|
+
}
|
171
|
+
VCR.use_cassette('response remove user tags') {
|
172
|
+
soap_action = :remove_user_tags
|
173
|
+
request = Exlibris::Primo::WebService::Request::RemoveUserTags.new(:user_id => @user_id,
|
174
|
+
:institution => @institution)
|
175
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
176
|
+
response =Exlibris::Primo::WebService::Response::RemoveUserTags.new(
|
177
|
+
client.send(soap_action, request.to_xml), soap_action)
|
178
|
+
}
|
179
|
+
VCR.use_cassette('response search') {
|
180
|
+
soap_action = :search_brief
|
181
|
+
request = Exlibris::Primo::WebService::Request::Search.new(:user_id => @user_id,
|
182
|
+
:institution => @institution)
|
183
|
+
request.add_query_term(@isbn, "isbn", "exact")
|
184
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
185
|
+
response =Exlibris::Primo::WebService::Response::Search.new(
|
186
|
+
client.send(soap_action, request.to_xml), soap_action)
|
187
|
+
}
|
188
|
+
VCR.use_cassette('response full view') {
|
189
|
+
soap_action = :get_record
|
190
|
+
request = Exlibris::Primo::WebService::Request::FullView.new(:user_id => @user_id,
|
191
|
+
:institution => @institution, :doc_id => @doc_id)
|
192
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
193
|
+
response =Exlibris::Primo::WebService::Response::FullView.new(
|
194
|
+
client.send(soap_action, request.to_xml), soap_action)
|
195
|
+
}
|
196
|
+
}
|
197
|
+
end
|
198
|
+
end
|
199
|
+
end
|
200
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class DidUMeanTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
@basket_id ="210075761"
|
13
|
+
@did_u_mean_title = "Digital dvide"
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_did_u_mean_enabled
|
17
|
+
VCR.use_cassette('response did u mean enabled') {
|
18
|
+
soap_action = :search_brief
|
19
|
+
request = Exlibris::Primo::WebService::Request::Search.new(:user_id => @user_id,
|
20
|
+
:institution => @institution, :did_u_mean_enabled => "true")
|
21
|
+
request.add_query_term(@did_u_mean_title, "title")
|
22
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
23
|
+
response = Exlibris::Primo::WebService::Response::Search.new(
|
24
|
+
client.send(soap_action, request.to_xml), soap_action)
|
25
|
+
assert_not_nil response.did_u_mean
|
26
|
+
assert_equal "digital d vide", response.did_u_mean
|
27
|
+
}
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_did_u_mean_disabled
|
31
|
+
VCR.use_cassette('response did u mean disabled') {
|
32
|
+
soap_action = :search_brief
|
33
|
+
request = Exlibris::Primo::WebService::Request::Search.new(:user_id => @user_id,
|
34
|
+
:institution => @institution)
|
35
|
+
request.add_query_term(@did_u_mean_title, "title")
|
36
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
37
|
+
response = Exlibris::Primo::WebService::Response::Search.new(
|
38
|
+
client.send(soap_action, request.to_xml), soap_action)
|
39
|
+
assert_nil response.did_u_mean
|
40
|
+
}
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class ErrorTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
@basket_id ="210075761"
|
13
|
+
@new_folder_name = "new folder"
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_get_tags
|
17
|
+
VCR.use_cassette('response add tag') {
|
18
|
+
soap_action = :add_tag
|
19
|
+
request = Exlibris::Primo::WebService::Request::AddTag.new(:user_id => @user_id,
|
20
|
+
:institution => @institution, :doc_id => @doc_id, :value => "test tag")
|
21
|
+
client = Exlibris::Primo::WebService::Client::Tags.new(:base_url => @base_url)
|
22
|
+
response =Exlibris::Primo::WebService::Response::AddTag.new(
|
23
|
+
client.send(soap_action, request.to_xml), soap_action)
|
24
|
+
assert((not response.error?))
|
25
|
+
assert_equal("0", response.error_code)
|
26
|
+
assert_equal("Add tag action completed successfully", response.error_message)
|
27
|
+
}
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class EshelfTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
@basket_id ="210075761"
|
13
|
+
@new_folder_name = "new folder"
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_get_eshelf
|
17
|
+
VCR.use_cassette('response get eshelf') {
|
18
|
+
soap_action = :get_eshelf
|
19
|
+
request = Exlibris::Primo::WebService::Request::GetEshelf.new(:user_id => @user_id,
|
20
|
+
:institution => @institution)
|
21
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
22
|
+
response = Exlibris::Primo::WebService::Response::GetEshelf.new(
|
23
|
+
client.send(soap_action, request.to_xml), soap_action)
|
24
|
+
}
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class FacetsTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_search
|
15
|
+
VCR.use_cassette('response search') {
|
16
|
+
soap_action = :search_brief
|
17
|
+
request = Exlibris::Primo::WebService::Request::Search.new(:user_id => @user_id,
|
18
|
+
:institution => @institution)
|
19
|
+
request.add_query_term(@isbn, "isbn", "exact")
|
20
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
21
|
+
response = Exlibris::Primo::WebService::Response::Search.new(
|
22
|
+
client.send(soap_action, request.to_xml), soap_action)
|
23
|
+
assert_not_nil response.facets
|
24
|
+
assert((not response.facets.empty?))
|
25
|
+
}
|
26
|
+
end
|
27
|
+
|
28
|
+
def test_full_view
|
29
|
+
VCR.use_cassette('response full view') {
|
30
|
+
soap_action = :get_record
|
31
|
+
request = Exlibris::Primo::WebService::Request::FullView.new(:user_id => @user_id,
|
32
|
+
:institution => @institution, :doc_id => @doc_id)
|
33
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
34
|
+
response = Exlibris::Primo::WebService::Response::FullView.new(
|
35
|
+
client.send(soap_action, request.to_xml), soap_action)
|
36
|
+
assert_not_nil response.facets
|
37
|
+
assert response.facets.empty?
|
38
|
+
}
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class RecordsTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_get_eshelf
|
15
|
+
VCR.use_cassette('response get eshelf') {
|
16
|
+
soap_action = :get_eshelf
|
17
|
+
request = Exlibris::Primo::WebService::Request::GetEshelf.new(:user_id => @user_id,
|
18
|
+
:institution => @institution)
|
19
|
+
client = Exlibris::Primo::WebService::Client::Eshelf.new(:base_url => @base_url)
|
20
|
+
response = Exlibris::Primo::WebService::Response::GetEshelf.new(
|
21
|
+
client.send(soap_action, request.to_xml), soap_action)
|
22
|
+
assert_not_nil response.records
|
23
|
+
assert((not response.records.empty?))
|
24
|
+
}
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_search
|
28
|
+
VCR.use_cassette('response search') {
|
29
|
+
soap_action = :search_brief
|
30
|
+
request = Exlibris::Primo::WebService::Request::Search.new(:user_id => @user_id,
|
31
|
+
:institution => @institution)
|
32
|
+
request.add_query_term(@isbn, "isbn", "exact")
|
33
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
34
|
+
response = Exlibris::Primo::WebService::Response::Search.new(
|
35
|
+
client.send(soap_action, request.to_xml), soap_action)
|
36
|
+
assert_not_nil response.records
|
37
|
+
assert((not response.records.empty?))
|
38
|
+
}
|
39
|
+
end
|
40
|
+
|
41
|
+
def test_full_view
|
42
|
+
VCR.use_cassette('response full view') {
|
43
|
+
soap_action = :get_record
|
44
|
+
request = Exlibris::Primo::WebService::Request::FullView.new(:user_id => @user_id,
|
45
|
+
:institution => @institution, :doc_id => @doc_id)
|
46
|
+
client = Exlibris::Primo::WebService::Client::Search.new(:base_url => @base_url)
|
47
|
+
response = Exlibris::Primo::WebService::Response::FullView.new(
|
48
|
+
client.send(soap_action, request.to_xml), soap_action)
|
49
|
+
assert_not_nil response.records
|
50
|
+
assert((not response.records.empty?))
|
51
|
+
assert_equal(1, response.records.size)
|
52
|
+
}
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module WebService
|
2
|
+
module Response
|
3
|
+
require 'test_helper'
|
4
|
+
class ReviewsTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@base_url = "http://bobcatdev.library.nyu.edu"
|
7
|
+
@isbn = "0143039008"
|
8
|
+
@user_id = "N12162279"
|
9
|
+
@institution = "NYU"
|
10
|
+
@doc_id = "nyu_aleph000062856"
|
11
|
+
@dedupmgr_id = "dedupmrg17343091"
|
12
|
+
@basket_id ="210075761"
|
13
|
+
@new_folder_name = "new folder"
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_get_reviews
|
17
|
+
VCR.use_cassette('response get reviews') {
|
18
|
+
soap_action = :get_reviews
|
19
|
+
request = Exlibris::Primo::WebService::Request::GetReviews.new(:user_id => @user_id,
|
20
|
+
:institution => @institution)
|
21
|
+
client = Exlibris::Primo::WebService::Client::Reviews.new(:base_url => @base_url)
|
22
|
+
response = Exlibris::Primo::WebService::Response::GetReviews.new(
|
23
|
+
client.send(soap_action, request.to_xml), soap_action)
|
24
|
+
}
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|