From 4d764b55a58797c7d4eb2e99a30e645567d9fc9f Mon Sep 17 00:00:00 2001 From: Justin Coyne Date: Mon, 19 Aug 2024 08:46:06 -0500 Subject: [PATCH] Convert feature spec to request spec --- .rubocop_todo.yml | 21 +- .../iiif2_manifest_spec.rb} | 120 ++++------ .../iiif3_manifest_spec.rb | 211 ++++++++---------- 3 files changed, 155 insertions(+), 197 deletions(-) rename spec/{features/iiif_manifest_spec.rb => requests/iiif2_manifest_spec.rb} (85%) rename spec/{features => requests}/iiif3_manifest_spec.rb (74%) diff --git a/.rubocop_todo.yml b/.rubocop_todo.yml index 1140b738..32f177ac 100644 --- a/.rubocop_todo.yml +++ b/.rubocop_todo.yml @@ -1,6 +1,6 @@ # This configuration was generated by # `rubocop --auto-gen-config` -# on 2024-08-14 21:47:26 UTC using RuboCop version 1.65.1. +# on 2024-08-19 13:52:42 UTC using RuboCop version 1.65.1. # The point is for the user to remove these configuration records # one by one as the offenses are removed from the code base. # Note that changes in the inspected code, or installation of new @@ -18,7 +18,7 @@ Lint/DuplicateBranch: Metrics/BlockLength: Max: 58 -# Offense count: 3 +# Offense count: 4 # Configuration parameters: CountComments, CountAsOne. Metrics/ClassLength: Max: 192 @@ -40,30 +40,26 @@ Naming/HeredocDelimiterNaming: Exclude: - 'spec/model/purl_version_spec.rb' -# Offense count: 21 +# Offense count: 17 # Configuration parameters: Prefixes, AllowedPatterns. # Prefixes: when, with, without RSpec/ContextWording: Exclude: - 'spec/features/display_purl_page_spec.rb' - - 'spec/features/iiif3_manifest_spec.rb' - - 'spec/features/iiif_manifest_spec.rb' - 'spec/integration/purl_spec.rb' - 'spec/views/purl/_find_it.html.erb_spec.rb' -# Offense count: 52 +# Offense count: 48 # Configuration parameters: CountAsOne. RSpec/ExampleLength: - Max: 45 + Max: 47 -# Offense count: 3 +# Offense count: 1 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: CustomTransform, IgnoredWords, DisallowedExamples. # DisallowedExamples: works RSpec/ExampleWording: Exclude: - - 'spec/features/iiif3_manifest_spec.rb' - - 'spec/features/iiif_manifest_spec.rb' - 'spec/features/preview_spec.rb' # Offense count: 12 @@ -81,7 +77,7 @@ RSpec/LeadingSubject: # Offense count: 80 RSpec/MultipleExpectations: - Max: 19 + Max: 22 # Offense count: 41 # Configuration parameters: AllowSubject. @@ -122,11 +118,10 @@ Rails/Blank: Exclude: - 'app/models/iiif_presentation_manifest.rb' -# Offense count: 5 +# Offense count: 4 Rails/I18nLocaleTexts: Exclude: - 'app/controllers/feedback_forms_controller.rb' - - 'app/controllers/purl_controller.rb' - 'app/controllers/webauth_controller.rb' - 'app/mailers/feedback_mailer.rb' diff --git a/spec/features/iiif_manifest_spec.rb b/spec/requests/iiif2_manifest_spec.rb similarity index 85% rename from spec/features/iiif_manifest_spec.rb rename to spec/requests/iiif2_manifest_spec.rb index 9cd9bc5f..33d22f52 100644 --- a/spec/features/iiif_manifest_spec.rb +++ b/spec/requests/iiif2_manifest_spec.rb @@ -1,9 +1,10 @@ require 'rails_helper' RSpec.describe 'IIIF v2 manifests' do - it 'works' do - visit '/bb157hs6068/iiif/manifest.json' - json = JSON.parse(page.body) + let(:json) { response.parsed_body } + + it 'is successful' do + get '/bb157hs6068/iiif/manifest' expect(json['@context']).to eq 'http://iiif.io/api/presentation/2/context.json' expect(json['label']).to include 'NOUVELLE CARTE DE LA SPHERE POUR FAIRE CONNOITRE LES' # ... @@ -11,6 +12,9 @@ expect(json['attribution']).to start_with 'This work has been identified as being free of known restrictions' expect(json['seeAlso']['@id']).to eq 'http://www.example.com/bb157hs6068.mods' expect(json['thumbnail']['@id']).to eq 'https://stacks.stanford.edu/image/iiif/bb157hs6068/bb157hs6068_05_0001/full/!400,400/0/default.jpg' + expect(json['thumbnail']['@type']).to eq 'dctypes:Image' + expect(json['thumbnail']['width']).to eq 400 + expect(json['thumbnail']['height']).to eq 345 expect(json['sequences'].length).to eq 1 canvas = json['sequences'].first['canvases'].first @@ -56,19 +60,9 @@ expect(json['metadata']).to eq(expected_metadata) end - it 'includes a representative thumbnail' do - visit '/bb157hs6068/iiif/manifest.json' - json = JSON.parse(page.body) - - expect(json['thumbnail']['@id']).to eq 'https://stacks.stanford.edu/image/iiif/bb157hs6068/bb157hs6068_05_0001/full/!400,400/0/default.jpg' - expect(json['thumbnail']['@type']).to eq 'dctypes:Image' - expect(json['thumbnail']['width']).to eq 400 - expect(json['thumbnail']['height']).to eq 345 - end - it 'includes the representative thumbnail as part of the image sequence' do - visit '/rf433wv2584/iiif/manifest.json' - json = JSON.parse(page.body) + get '/rf433wv2584/iiif/manifest' + expect(json['thumbnail']['@id']).to eq 'https://stacks.stanford.edu/image/iiif/rf433wv2584/9082000/full/!400,400/0/default.jpg' expect(json['sequences'].length).to eq 1 @@ -79,34 +73,34 @@ end it 'includes canvas rendering of jp2 if downloadable' do - visit '/bb157hs6068/iiif/manifest.json' - json = JSON.parse(page.body) + get '/bb157hs6068/iiif/manifest' + canvas = json['sequences'].first['canvases'].first expect(canvas['rendering'].first['label']).to eq 'Original source file (17 MB)' end it 'does not include canvas rendering if jp2 is not downloadable' do - visit '/rf433wv2584/iiif/manifest.json' - json = JSON.parse(page.body) + get '/rf433wv2584/iiif/manifest' + canvas = json['sequences'].first['canvases'].first expect(canvas['rendering']).to be_nil end it 'includes viewing direction when viewing direction is defined' do - visit '/yr183sf1341/iiif/manifest' - json = JSON.parse(page.body) + get '/yr183sf1341/iiif/manifest' + expect(json['sequences'].first['viewingDirection']).to eq 'right-to-left' end it 'uses left-to-right as default viewing direction if viewing direction is not defined' do - visit '/py305sy7961/iiif/manifest' - json = JSON.parse(page.body) + get '/py305sy7961/iiif/manifest' + expect(json['sequences'].first['viewingDirection']).to eq('left-to-right') end it 'includes authorization services for a Stanford-only image' do - visit '/bb001dq8600/iiif/manifest.json' - json = JSON.parse(page.body) + get '/bb001dq8600/iiif/manifest' + expect(json['sequences'].length).to eq 1 canvas = json['sequences'].first['canvases'].first expect(canvas['images'].length).to eq 1 @@ -127,8 +121,8 @@ end it 'includes authorization services for cdl images' do - visit '/pg500wr6297/iiif/manifest.json' - json = JSON.parse(page.body) + get '/pg500wr6297/iiif/manifest' + expect(json['sequences'].length).to eq 1 canvas = json['sequences'].first['canvases'].first expect(canvas['images'].length).to eq 1 @@ -148,45 +142,40 @@ end it 'includes some copyright language for cdl resources' do - visit '/pg500wr6297/iiif/manifest.json' - json = JSON.parse(page.body) + get '/pg500wr6297/iiif/manifest' expect(json['attribution'].length).to eq 1 expect(json['attribution'].first).to match(/The copyright law of the United States/) end it 'properly decodes XML entities into their UTF-8 characters' do - visit '/bb737zp0787/iiif/manifest.json' - json = JSON.parse(page.body) + get '/bb737zp0787/iiif/manifest' + expect(json['attribution']).to eq 'Property rights reside with the repository. Copyright © Stanford University. All Rights Reserved.' end it 'suppresses sequences for dark resources' do - visit '/bc421tk1152/iiif/manifest.json' - json = JSON.parse(page.body) + get '/bc421tk1152/iiif/manifest' expect(json['sequences'].length).to eq 1 expect(json['sequences'].first['canvases']).to be_blank end it 'publishes IIIF manifests for books with image constituents' do - visit '/zf119tw4418/iiif/manifest.json' - json = JSON.parse(page.body) + get '/zf119tw4418/iiif/manifest' expect(json['sequences'].length).to eq 1 expect(json['metadata'].length).to eq 29 end it 'does not publish services for pages without OCR content' do - visit '/py305sy7961/iiif3/manifest' - json = JSON.parse(page.body) + get '/py305sy7961/iiif3/manifest' expect(json).not_to have_key 'service' end it 'publishes IIIF Content Search API for pages with OCR content' do - visit '/jg072yr3056/iiif/manifest.json' - json = JSON.parse(page.body) + get '/jg072yr3056/iiif/manifest' expect(json['service'].first).to match '@context' => 'http://iiif.io/api/search/1/context.json', '@id' => 'http://example.com/content_search/jg072yr3056/search', @@ -195,8 +184,7 @@ end it 'publishes seeAlso for canvases with OCR content' do - visit '/jg072yr3056/iiif/manifest.json' - json = JSON.parse(page.body) + get '/jg072yr3056/iiif/manifest' expect(json['sequences'].first['canvases'].first['seeAlso']).to eq [ { @@ -209,8 +197,7 @@ end it 'provides otherContent for annotations that exist in an image resource' do - visit '/hx163dc5225/iiif/manifest' - json = JSON.parse(page.body) + get '/hx163dc5225/iiif/manifest' expect(json.dig('sequences', 0, 'canvases', 7, 'otherContent')).to eq [ { @@ -221,22 +208,19 @@ end it 'does not advertise an IIIF Content Search API for pages with stanford-only OCR content' do - visit '/bf995rh7184/iiif/manifest' - json = JSON.parse(page.body) + get '/bf995rh7184/iiif/manifest' expect(json).not_to include('service') end it 'does not advertise an IIIF Content Search API for pages with no-download OCR content' do - visit '/bf385jz2076/iiif/manifest' - json = JSON.parse(page.body) + get '/bf385jz2076/iiif/manifest' expect(json).not_to include('service') end it 'publishes a rendering section for objects with additional resources' do - visit '/zf119tw4418/iiif/manifest.json' - json = JSON.parse(page.body) + get '/zf119tw4418/iiif/manifest' rendering = json['sequences'].first['rendering'] expect(rendering).to include( @@ -247,22 +231,20 @@ end it 'does not advertise downloadable files for stanford-only no-download content' do - visit '/bf995rh7184/iiif/manifest' - json = JSON.parse(page.body) + get '/bf995rh7184/iiif/manifest' expect(json['sequences'].first).not_to include 'rendering' end # Virtual objects consist of a parent object and children objects who hold the file resources - context 'virtual objects' do + context 'with virtual objects' do describe 'first child object' do let(:druid) { 'cg767mn6478' } - it 'generates a correct manifest.json' do - visit "/#{druid}/iiif/manifest.json" - expect(page).to have_http_status(:ok) + it 'generates a correct manifest' do + get "/#{druid}/iiif/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']).to start_with '(Covers to) Carey\'s American Atlas' expect(json['sequences'].length).to eq 1 expect(json['sequences'].first['canvases'].length).to eq 1 @@ -281,11 +263,10 @@ describe 'second child object' do let(:druid) { 'jw923xn5254' } - it 'generates a correct manifest.json' do - visit "/#{druid}/iiif/manifest.json" - expect(page).to have_http_status(:ok) + it 'generates a correct manifest' do + get "/#{druid}/iiif/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']).to start_with '(Title Page to) Carey\'s American Atlas' expect(json['sequences'].length).to eq 1 expect(json['sequences'].first['canvases'].length).to eq 1 @@ -304,11 +285,10 @@ describe 'parent object' do let(:druid) { 'hj097bm8879' } - it 'generates a correct manifest.json' do - visit "/#{druid}/iiif/manifest.json" - expect(page).to have_http_status(:ok) + it 'generates a correct manifest' do + get "/#{druid}/iiif/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']).to start_with 'Carey\'s American Atlas' expect(json['thumbnail']['@id']).to end_with '/image/iiif/cg767mn6478/2542A/full/!400,400/0/default.jpg' # first child expect(json['sequences'].length).to eq 1 @@ -339,10 +319,9 @@ let(:druid) { 'bb361mj1737' } it 'generates a IIIF v2 manifest that includes location authentication information' do - visit "/#{druid}/iiif/manifest.json" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) external_interaction_service = json['sequences'].first['canvases'].first['images'].first['resource']['service']['service'].first expect(external_interaction_service['profile']).to eq 'http://iiif.io/api/auth/1/external' expect(external_interaction_service['label']).to eq 'External Authentication Required' @@ -353,14 +332,13 @@ end end - context 'a resource with special characters' do + context 'when a resource has special characters in the filename' do let(:druid) { 'fg019pm1396' } it 'generates a IIIF v2 manifest that escapes resources in urls' do - visit "/#{druid}/iiif/manifest.json" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) image_ids = json['sequences'].flat_map { |x| x['canvases'] }.flat_map { |x| x['images'] }.map { |x| x['resource']['@id'] } # handle spaces diff --git a/spec/features/iiif3_manifest_spec.rb b/spec/requests/iiif3_manifest_spec.rb similarity index 74% rename from spec/features/iiif3_manifest_spec.rb rename to spec/requests/iiif3_manifest_spec.rb index a08bec19..1249b766 100644 --- a/spec/features/iiif3_manifest_spec.rb +++ b/spec/requests/iiif3_manifest_spec.rb @@ -2,9 +2,10 @@ require 'iiif/v3/presentation' # Can we get the iiif-presentation gem to load this? RSpec.describe 'IIIF v3 manifests' do - it 'works' do - visit '/bb157hs6068/iiif3/manifest' - json = JSON.parse(page.body) + let(:json) { response.parsed_body } + + it 'is successful' do + get '/bb157hs6068/iiif3/manifest' expect(json['@context']).to include 'http://www.w3.org/ns/anno.jsonld', 'http://iiif.io/api/presentation/3/context.json' expect(json['label']['en'].first).to include 'NOUVELLE CARTE DE LA SPHERE POUR FAIRE CONNOITRE LES' # ... @@ -14,6 +15,9 @@ expect(json['thumbnail']).to be_an Array expect(json['thumbnail'].size).to eq 1 expect(json['thumbnail'].first['id']).to eq 'https://stacks.stanford.edu/image/iiif/bb157hs6068/bb157hs6068_05_0001/full/!400,400/0/default.jpg' + expect(json['thumbnail'].first['type']).to eq 'Image' + expect(json['thumbnail'].first['width']).to eq 400 + expect(json['thumbnail'].first['height']).to eq 345 expect(json['items'].length).to eq 1 canvas = json['items'].first @@ -57,109 +61,101 @@ expect(json['metadata']).to eq(expected_dc_metadata) end - it 'includes a representative thumbnail' do - visit '/bb157hs6068/iiif3/manifest' - json = JSON.parse(page.body) - - expect(json['thumbnail']).to be_an Array - expect(json['thumbnail'].size).to eq 1 - expect(json['thumbnail'].first['id']).to eq 'https://stacks.stanford.edu/image/iiif/bb157hs6068/bb157hs6068_05_0001/full/!400,400/0/default.jpg' - expect(json['thumbnail'].first['type']).to eq 'Image' - expect(json['thumbnail'].first['width']).to eq 400 - expect(json['thumbnail'].first['height']).to eq 345 - end - - it 'includes viewing direction when viewing direction is defined' do - visit '/yr183sf1341/iiif3/manifest' - json = JSON.parse(page.body) - expect(json['viewingDirection']).to eq 'right-to-left' + context 'when viewing direction is defined' do + it 'includes viewing direction' do + get '/yr183sf1341/iiif3/manifest' + expect(json['viewingDirection']).to eq 'right-to-left' + end end - it 'uses left-to-right as default viewing direction if viewing direction is not defined' do - visit '/py305sy7961/iiif3/manifest' - json = JSON.parse(page.body) - expect(json['viewingDirection']).to eq('left-to-right') + context 'when viewing direction is not defined' do + it 'uses left-to-right as default viewing direction' do + get '/py305sy7961/iiif3/manifest' + expect(json['viewingDirection']).to eq('left-to-right') + end end - it 'includes authorization services for a Stanford-only image' do - visit '/bb001dq8600/iiif3/manifest' - json = JSON.parse(page.body) - expect(json['items'].length).to eq 1 - canvas = json['items'].first - expect(canvas['items'].first['items'].length).to eq 1 - image = canvas['items'].first['items'].first - service = image['body']['service'].first - expect(service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/login' - - login_service = service['service'].detect { |x| x['profile'] == 'http://iiif.io/api/auth/1/login' } - expect(login_service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/token' - expect(login_service['label']).to eq 'Log in to access all available features.' - expect(login_service['confirmLabel']).to eq 'Login' - expect(login_service['failureHeader']).to eq 'Unable to authenticate' - expect(login_service['failureDescription']).to eq 'The authentication serv' \ - 'ice cannot be reached. If your browser is configured to block pop-up wi' \ - 'ndows, try allowing pop-up windows for this site before attempting to l' \ - 'og in again.' + context 'with a Stanford-only image' do + it 'includes authorization services' do + get '/bb001dq8600/iiif3/manifest' + expect(json['items'].length).to eq 1 + canvas = json['items'].first + expect(canvas['items'].first['items'].length).to eq 1 + image = canvas['items'].first['items'].first + service = image['body']['service'].first + expect(service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/login' + + login_service = service['service'].detect { |x| x['profile'] == 'http://iiif.io/api/auth/1/login' } + expect(login_service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/token' + expect(login_service['label']).to eq 'Log in to access all available features.' + expect(login_service['confirmLabel']).to eq 'Login' + expect(login_service['failureHeader']).to eq 'Unable to authenticate' + expect(login_service['failureDescription']).to eq 'The authentication serv' \ + 'ice cannot be reached. If your browser is configured to block pop-up wi' \ + 'ndows, try allowing pop-up windows for this site before attempting to l' \ + 'og in again.' + end end - it 'includes authorization services for cdl images' do - visit '/pg500wr6297/iiif3/manifest.json' - json = JSON.parse(page.body) - service = json['items'][2]['items'].first['items'].first['body']['service'].first - expect(service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/login' - - login_service = service['service'].detect { |x| x['profile'] == 'http://iiif.io/api/auth/1/login' } - expect(login_service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/token' - expect(login_service['label']).to eq 'Available for checkout.' - expect(login_service['confirmLabel']).to eq 'Checkout' - expect(login_service['id']).to eq 'https://stacks.stanford.edu/auth/iiif/cdl/pg500wr6297/checkout' - expect(login_service['failureHeader']).to eq 'Unable to authenticate' - expect(login_service['failureDescription']).to eq 'The authentication serv' \ - 'ice cannot be reached.' + context 'with a cdl access' do + it 'includes authorization services' do + get '/pg500wr6297/iiif3/manifest' + + service = json['items'][2]['items'].first['items'].first['body']['service'].first + expect(service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/login' + + login_service = service['service'].detect { |x| x['profile'] == 'http://iiif.io/api/auth/1/login' } + expect(login_service['service']).to include hash_including 'profile' => 'http://iiif.io/api/auth/1/token' + expect(login_service['label']).to eq 'Available for checkout.' + expect(login_service['confirmLabel']).to eq 'Checkout' + expect(login_service['id']).to eq 'https://stacks.stanford.edu/auth/iiif/cdl/pg500wr6297/checkout' + expect(login_service['failureHeader']).to eq 'Unable to authenticate' + expect(login_service['failureDescription']).to eq 'The authentication serv' \ + 'ice cannot be reached.' + end end it 'properly decodes XML entities into their UTF-8 characters' do - visit '/bb737zp0787/iiif3/manifest' - json = JSON.parse(page.body) + get '/bb737zp0787/iiif3/manifest' expect(json['requiredStatement']['value']['en'].first) .to eq 'Property rights reside with the repository. Copyright © Stanford University. All Rights Reserved.' end it 'publishes IIIF manifests for books with image constituents' do - visit '/zf119tw4418/iiif3/manifest' - json = JSON.parse(page.body) + get '/zf119tw4418/iiif3/manifest' expect(json['items'].length).to eq 58 expect(json['metadata'].length).to eq 13 end - it 'does not publish services for pages without OCR content' do - visit '/py305sy7961/iiif3/manifest' - json = JSON.parse(page.body) + context 'when pages do not have OCR content' do + it 'does not publish search services' do + get '/py305sy7961/iiif3/manifest' - expect(json).not_to have_key 'service' + expect(json).not_to have_key 'service' + end end - it 'publishes IIIF Content Search API for pages with OCR content' do - visit '/jg072yr3056/iiif/manifest.json' - json = JSON.parse(page.body) + context 'when pages have OCR content' do + it 'publishes IIIF Content Search API' do + get '/jg072yr3056/iiif/manifest' - expect(json['service'].first).to match '@context' => 'http://iiif.io/api/search/1/context.json', - '@id' => 'http://example.com/content_search/jg072yr3056/search', - 'profile' => 'http://iiif.io/api/search/1/search', - 'label' => 'Search within this manifest' + expect(json['service'].first).to match '@context' => 'http://iiif.io/api/search/1/context.json', + '@id' => 'http://example.com/content_search/jg072yr3056/search', + 'profile' => 'http://iiif.io/api/search/1/search', + 'label' => 'Search within this manifest' + end end # Virtual objects consist of a parent object and children objects who hold the file resources - context 'virtual objects' do + context 'with virtual objects' do describe 'first child object' do let(:druid) { 'cg767mn6478' } it 'generates a correct manifest' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']['en'].first).to start_with '(Covers to) Carey\'s American Atlas' expect(json['items'].length).to eq 1 @@ -179,10 +175,9 @@ let(:druid) { 'jw923xn5254' } it 'generates a correct manifest' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']['en'].first).to start_with '(Title Page to) Carey\'s American Atlas' expect(json['items'].length).to eq 1 @@ -202,10 +197,9 @@ let(:druid) { 'hj097bm8879' } it 'generates a correct manifest' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']['en'].first).to start_with 'Carey\'s American Atlas' expect(json['thumbnail']).to be_an Array expect(json['thumbnail'].size).to eq 1 @@ -235,14 +229,13 @@ end end - describe 'a PDF object' do + context 'with a PDF object' do let(:druid) { 'bb132pr2055' } it 'generates a correct manifest' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']['en'].first).to eq 'How does politics affect central banking? : evidence from the Federal Reserve' expect(json['items'].length).to eq 1 @@ -259,14 +252,13 @@ end end - describe 'a Stanford-only PDF object' do + context 'with a Stanford-only PDF object' do let(:druid) { 'bb253gh8060' } it 'generates a manifest that includes the login service for the restricted file' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['label']['en'].first).to eq 'Agenda' expect(json['items'].length).to eq 1 @@ -290,14 +282,12 @@ end end - describe 'a 3D object' do + context 'with a 3D object' do let(:druid) { 'hc941fm6529' } it 'generates a correct IIIF v3 manifest' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) - - json = JSON.parse(page.body) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) expect(json['label']['en'].first).to start_with 'Sheep' expect(json['items'].length).to eq 1 @@ -326,19 +316,17 @@ end it 'returns 404' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:not_found) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:not_found) end end - describe 'a 3D object as obj' do + context 'with a 3D object as obj' do let(:druid) { 'bg387kw8222' } it 'only generates a single 3d resource on the canvas' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) - - json = JSON.parse(page.body) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) expect(json['label']['en'].first).to start_with 'Department of Anthropology Bone Collection' expect(json['items'].length).to eq 1 @@ -356,14 +344,13 @@ end end - describe 'a location restricted image' do + context 'with a location restricted image' do let(:druid) { 'yy816tv6021' } it 'generates a IIIF v3 manifest that includes location authentication information' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) external_interaction_service = json['items'].first['items'].first['items'].first['body']['service'].first['service'].first expect(external_interaction_service['profile']).to eq 'http://iiif.io/api/auth/1/external' expect(external_interaction_service['label']).to eq 'External Authentication Required' @@ -374,14 +361,13 @@ end end - context 'a video object with captions' do + context 'with a video object with captions' do let(:druid) { 'wr231qr2829' } it 'includes a placeholder canvas and caption annotations' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) canvas = json.dig('items', 0) expect(canvas.dig('items', 0, 'items', 0, 'body')).to include('type' => 'Video') @@ -399,14 +385,13 @@ end end - describe 'an object with coordinates' do + context 'with an object that has coordinates' do let(:druid) { 'rp193xx6845' } it 'generates a correct manifest with navPlace' do - visit "/#{druid}/iiif3/manifest" - expect(page).to have_http_status(:ok) + get "/#{druid}/iiif3/manifest" + expect(response).to have_http_status(:ok) - json = JSON.parse(page.body) expect(json['@context']).to include 'http://iiif.io/api/extension/navplace/context.json' features = json['navPlace']['features'] expect(features.length).to eq 2