Skip to content

Commit

Permalink
better handling for error cases in FileMetadata.find
Browse files Browse the repository at this point in the history
the base case originally tested relied on a bug in
Valkyrie (samvera/valkyrie#905).

this reimplements with a more serious error handling approach.
  • Loading branch information
tamsin johnson authored and dunn committed Jun 17, 2022
1 parent a8980bd commit aaa7626
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 10 deletions.
18 changes: 10 additions & 8 deletions app/models/hyrax/file_metadata.rb
Original file line number Diff line number Diff line change
Expand Up @@ -157,15 +157,17 @@ def content
''
end

##
# @return [Valkyrie::StorageAdapter::File]
#
# @raise [Valkyrie::StorageAdapter::AdapterNotFoundError] if no adapter
# could be found matching the file_identifier's scheme
# @raise [Valkyrie::StorageAdapter::FileNotFound] when the file can't
# be found in the registered adapter
def file
adapter =
begin
Valkyrie::StorageAdapter.adapter_for(id: file_identifier)
rescue Valkyrie::StorageAdapter::AdapterNotFoundError => _err
Hyrax.storage_adapter
end

adapter.find_by(id: file_identifier)
Valkyrie::StorageAdapter
.adapter_for(id: file_identifier)
.find_by(id: file_identifier)
end
end
end
37 changes: 35 additions & 2 deletions spec/models/hyrax/file_metadata_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -116,8 +116,41 @@
end

describe '#file' do
it 'returns file from storage adapter' do
expect(subject.file).to be_a Valkyrie::StorageAdapter::StreamFile
it 'raises an error for a missing file_identifier' do
expect { file_metadata.file }
.to raise_error Valkyrie::StorageAdapter::AdapterNotFoundError
end

context 'when file_identifier is saved with storage_adapter' do
let(:file_metadata) { described_class.new(file_identifier: stored.id) }
let(:file_set) { FactoryBot.valkyrie_create(:hyrax_file_set) }

let(:stored) do
Hyrax.storage_adapter.upload(resource: file_set,
file: file,
original_filename: file.original_filename)
end

it 'gives the exact file' do
expect(file_metadata.file.read).to eq stored.read
end
end

context 'when file_identifier is saved with an arbitrary adapter' do
let(:file_metadata) { described_class.new(file_identifier: stored.id) }
let(:file_set) { FactoryBot.valkyrie_create(:hyrax_file_set) }

let(:stored) do
Valkyrie::StorageAdapter
.find(:test_disk)
.upload(resource: file_set,
file: file,
original_filename: file.original_filename)
end

it 'gives the exact file' do
expect(file_metadata.file.read).to eq stored.read
end
end
end

Expand Down

0 comments on commit aaa7626

Please sign in to comment.