geo_concerns 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +13 -0
- data/.rubocop.yml +101 -0
- data/.travis.yml +17 -0
- data/Gemfile +46 -0
- data/LICENSE +202 -0
- data/README.md +46 -0
- data/Rakefile +21 -0
- data/app/actors/geo_concerns/file_actor.rb +20 -0
- data/app/actors/geo_concerns/file_set_actor.rb +7 -0
- data/app/assets/images/geo_concerns/.keep +0 -0
- data/app/assets/images/geo_concerns/images/geocoder.png +0 -0
- data/app/assets/images/geo_concerns/images/throbber.gif +0 -0
- data/app/assets/images/geo_concerns/img/filter-icon.png +0 -0
- data/app/assets/images/geo_concerns/img/move-handle.png +0 -0
- data/app/assets/images/geo_concerns/img/resize-handle.png +0 -0
- data/app/assets/javascripts/geo_concerns/Control.Geocoder.js +1056 -0
- data/app/assets/javascripts/geo_concerns/application.js +5 -0
- data/app/assets/javascripts/geo_concerns/bounding_box_selector.js +100 -0
- data/app/assets/javascripts/geo_concerns/leaflet-boundingbox.js +467 -0
- data/app/assets/stylesheets/geo_concerns/Control.Geocoder.css +104 -0
- data/app/assets/stylesheets/geo_concerns/application.css +18 -0
- data/app/assets/stylesheets/geo_concerns/bounding_box.scss +7 -0
- data/app/assets/stylesheets/geo_concerns/leaflet-boundingbox.css +17 -0
- data/app/controllers/concerns/geo_concerns/file_sets_controller_behavior.rb +19 -0
- data/app/controllers/concerns/geo_concerns/image_works_controller_behavior.rb +13 -0
- data/app/controllers/concerns/geo_concerns/raster_works_controller_behavior.rb +23 -0
- data/app/controllers/concerns/geo_concerns/vector_works_controller_behavior.rb +23 -0
- data/app/forms/geo_concerns/basic_geo_metadata_form.rb +8 -0
- data/app/forms/geo_concerns/external_metadata_file_form.rb +8 -0
- data/app/forms/geo_concerns/georeferenced_form.rb +9 -0
- data/app/forms/geo_concerns/image_work_form.rb +9 -0
- data/app/forms/geo_concerns/raster_work_form.rb +8 -0
- data/app/forms/geo_concerns/vector_work_form.rb +8 -0
- data/app/helpers/bounding_box_helper.rb +24 -0
- data/app/helpers/geo_concerns/application_helper.rb +4 -0
- data/app/models/concerns/geo_concerns/basic_geo_metadata.rb +21 -0
- data/app/models/concerns/geo_concerns/external_metadata_file_behavior.rb +31 -0
- data/app/models/concerns/geo_concerns/extractors/fgdc_helper.rb +9 -0
- data/app/models/concerns/geo_concerns/extractors/fgdc_metadata_extractor.rb +114 -0
- data/app/models/concerns/geo_concerns/extractors/iso19139_helper.rb +50 -0
- data/app/models/concerns/geo_concerns/extractors/mods_helper.rb +15 -0
- data/app/models/concerns/geo_concerns/file_set/derivatives.rb +60 -0
- data/app/models/concerns/geo_concerns/file_set_presenter_behavior.rb +7 -0
- data/app/models/concerns/geo_concerns/geo_file_format_behavior.rb +37 -0
- data/app/models/concerns/geo_concerns/geo_file_set_behavior.rb +11 -0
- data/app/models/concerns/geo_concerns/georeferenced_behavior.rb +18 -0
- data/app/models/concerns/geo_concerns/image_file_behavior.rb +14 -0
- data/app/models/concerns/geo_concerns/image_work_behavior.rb +69 -0
- data/app/models/concerns/geo_concerns/metadata_extraction_helper.rb +28 -0
- data/app/models/concerns/geo_concerns/raster_file_behavior.rb +14 -0
- data/app/models/concerns/geo_concerns/raster_work_behavior.rb +82 -0
- data/app/models/concerns/geo_concerns/solr_document_behavior.rb +25 -0
- data/app/models/concerns/geo_concerns/vector_file_behavior.rb +14 -0
- data/app/models/concerns/geo_concerns/vector_work_behavior.rb +78 -0
- data/app/presenters/geo_concerns/geo_concerns_show_presenter.rb +30 -0
- data/app/presenters/geo_concerns/image_work_show_presenter.rb +18 -0
- data/app/presenters/geo_concerns/raster_work_show_presenter.rb +18 -0
- data/app/presenters/geo_concerns/vector_work_show_presenter.rb +10 -0
- data/app/processors/geo_concerns/processors/base_geo_processor.rb +86 -0
- data/app/processors/geo_concerns/processors/raster.rb +11 -0
- data/app/processors/geo_concerns/processors/raster/aig.rb +44 -0
- data/app/processors/geo_concerns/processors/raster/base.rb +74 -0
- data/app/processors/geo_concerns/processors/raster/dem.rb +46 -0
- data/app/processors/geo_concerns/processors/raster/processor.rb +27 -0
- data/app/processors/geo_concerns/processors/vector.rb +11 -0
- data/app/processors/geo_concerns/processors/vector/base.rb +68 -0
- data/app/processors/geo_concerns/processors/vector/processor.rb +25 -0
- data/app/processors/geo_concerns/processors/vector/shapefile.rb +20 -0
- data/app/processors/geo_concerns/processors/zip.rb +31 -0
- data/app/renderers/coverage_renderer.rb +34 -0
- data/app/runners/geo_concerns/runners/raster_derivatives.rb +9 -0
- data/app/runners/geo_concerns/runners/vector_derivatives.rb +9 -0
- data/app/schemas/geo_concerns/basic_geo_metadata_optional.rb +39 -0
- data/app/schemas/geo_concerns/basic_geo_metadata_required.rb +25 -0
- data/app/services/authority_service.rb +23 -0
- data/app/services/geo_concerns/derivative_path.rb +16 -0
- data/app/services/image_format_service.rb +4 -0
- data/app/services/metadata_format_service.rb +4 -0
- data/app/services/raster_format_service.rb +4 -0
- data/app/services/vector_format_service.rb +4 -0
- data/app/values/geo_concerns/coverage.rb +36 -0
- data/app/values/geo_concerns/time_period.rb +31 -0
- data/app/views/curation_concerns/file_sets/_form.html.erb +48 -0
- data/app/views/curation_concerns/image_works/_form.html.erb +23 -0
- data/app/views/curation_concerns/image_works/_image_work.html.erb +2 -0
- data/app/views/curation_concerns/image_works/_members.html.erb +30 -0
- data/app/views/curation_concerns/image_works/_related_image_files.html.erb +24 -0
- data/app/views/curation_concerns/image_works/_show_actions.html.erb +16 -0
- data/app/views/curation_concerns/image_works/show.html.erb +17 -0
- data/app/views/curation_concerns/raster_works/_form.html.erb +25 -0
- data/app/views/curation_concerns/raster_works/_members.html.erb +30 -0
- data/app/views/curation_concerns/raster_works/_raster_work.html.erb +2 -0
- data/app/views/curation_concerns/raster_works/_related_raster_files.html.erb +24 -0
- data/app/views/curation_concerns/raster_works/_show_actions.html.erb +16 -0
- data/app/views/curation_concerns/raster_works/show.html.erb +17 -0
- data/app/views/curation_concerns/vector_works/_form.html.erb +25 -0
- data/app/views/curation_concerns/vector_works/_related_vector_files.html.erb +24 -0
- data/app/views/curation_concerns/vector_works/_show_actions.html.erb +15 -0
- data/app/views/curation_concerns/vector_works/_vector_work.html.erb +2 -0
- data/app/views/curation_concerns/vector_works/show.html.erb +15 -0
- data/app/views/geo_concerns/_attribute_rows.html.erb +11 -0
- data/app/views/geo_concerns/_attributes.html.erb +13 -0
- data/app/views/geo_concerns/_form_additional_information.html.erb +11 -0
- data/app/views/geo_concerns/_form_bounding_box.html.erb +9 -0
- data/app/views/geo_concerns/_form_descriptive_fields.html.erb +9 -0
- data/app/views/geo_concerns/_form_files_and_links.html.erb +0 -0
- data/app/views/geo_concerns/_form_populate_metadata.html.erb +8 -0
- data/app/views/geo_concerns/_form_required_information.html.erb +12 -0
- data/app/views/geo_concerns/_form_supplementary_fields.html.erb +15 -0
- data/app/views/geo_concerns/_related_external_metadata_files.html.erb +24 -0
- data/app/vocabs/geo_concerns/geo_terms.rb +12 -0
- data/bin/rails +12 -0
- data/config/routes.rb +6 -0
- data/geo_concerns.gemspec +36 -0
- data/lib/generators/geo_concerns/install_generator.rb +119 -0
- data/lib/generators/geo_concerns/templates/actors/curation_concerns/image_work_actor.rb +4 -0
- data/lib/generators/geo_concerns/templates/actors/curation_concerns/raster_work_actor.rb +4 -0
- data/lib/generators/geo_concerns/templates/actors/curation_concerns/vector_work_actor.rb +4 -0
- data/lib/generators/geo_concerns/templates/config/authorities/image_formats.yml +5 -0
- data/lib/generators/geo_concerns/templates/config/authorities/metadata_formats.yml +7 -0
- data/lib/generators/geo_concerns/templates/config/authorities/raster_formats.yml +9 -0
- data/lib/generators/geo_concerns/templates/config/authorities/vector_formats.yml +5 -0
- data/lib/generators/geo_concerns/templates/controllers/curation_concerns/file_sets_controller.rb +6 -0
- data/lib/generators/geo_concerns/templates/controllers/curation_concerns/image_works_controller.rb +5 -0
- data/lib/generators/geo_concerns/templates/controllers/curation_concerns/raster_works_controller.rb +6 -0
- data/lib/generators/geo_concerns/templates/controllers/curation_concerns/vector_works_controller.rb +6 -0
- data/lib/generators/geo_concerns/templates/geo_concerns.js +1 -0
- data/lib/generators/geo_concerns/templates/geo_concerns.scss +3 -0
- data/lib/generators/geo_concerns/templates/jobs/characterize_job.rb +12 -0
- data/lib/generators/geo_concerns/templates/models/file_set.rb +4 -0
- data/lib/generators/geo_concerns/templates/models/image_work.rb +6 -0
- data/lib/generators/geo_concerns/templates/models/raster_work.rb +7 -0
- data/lib/generators/geo_concerns/templates/models/vector_work.rb +7 -0
- data/lib/generators/geo_concerns/templates/presenters/file_set_presenter.rb +3 -0
- data/lib/generators/geo_concerns/templates/spec/actor_spec.rb.erb +9 -0
- data/lib/generators/geo_concerns/templates/spec/controller_spec.rb.erb +9 -0
- data/lib/generators/geo_concerns/templates/spec/model_spec.rb.erb +9 -0
- data/lib/geo_concerns.rb +6 -0
- data/lib/geo_concerns/engine.rb +4 -0
- data/lib/geo_concerns/version.rb +3 -0
- data/lib/tasks/geo_concerns_tasks.rake +4 -0
- data/solr/config/_rest_managed.json +3 -0
- data/solr/config/admin-extra.html +31 -0
- data/solr/config/elevate.xml +36 -0
- data/solr/config/mapping-ISOLatin1Accent.txt +246 -0
- data/solr/config/protwords.txt +21 -0
- data/solr/config/schema.xml +372 -0
- data/solr/config/scripts.conf +24 -0
- data/solr/config/solrconfig.xml +312 -0
- data/solr/config/spellings.txt +2 -0
- data/solr/config/stopwords.txt +58 -0
- data/solr/config/stopwords_en.txt +58 -0
- data/solr/config/synonyms.txt +31 -0
- data/solr/config/xslt/example.xsl +132 -0
- data/solr/config/xslt/example_atom.xsl +67 -0
- data/solr/config/xslt/example_rss.xsl +66 -0
- data/solr/config/xslt/luke.xsl +337 -0
- data/spec/actors/geo_concerns/file_actor_spec.rb +26 -0
- data/spec/controllers/image_works_controller_spec.rb +25 -0
- data/spec/controllers/raster_works_controller_spec.rb +50 -0
- data/spec/controllers/vector_works_controller_spec.rb +50 -0
- data/spec/factories/external_metadata_files.rb +20 -0
- data/spec/factories/image_files.rb +32 -0
- data/spec/factories/image_works.rb +68 -0
- data/spec/factories/raster_files.rb +35 -0
- data/spec/factories/raster_works.rb +86 -0
- data/spec/factories/users.rb +26 -0
- data/spec/factories/vector_files.rb +31 -0
- data/spec/factories/vector_works.rb +83 -0
- data/spec/features/create_raster_work_spec.rb +49 -0
- data/spec/forms/geo_concerns/basic_geo_metadata_form_spec.rb +27 -0
- data/spec/forms/geo_concerns/external_metadata_file_form_spec.rb +27 -0
- data/spec/forms/geo_concerns/georeferenced_form_spec.rb +29 -0
- data/spec/forms/geo_concerns/image_work_form_spec.rb +11 -0
- data/spec/forms/geo_concerns/raster_work_form_spec.rb +15 -0
- data/spec/forms/geo_concerns/vector_work_form_spec.rb +15 -0
- data/spec/helpers/bounding_box_helper_spec.rb +34 -0
- data/spec/models/concerns/basic_geo_metadata_spec.rb +21 -0
- data/spec/models/concerns/geo_concerns/file_set/derivatives_spec.rb +108 -0
- data/spec/models/concerns/geo_concerns/file_set/geo_file_format_behavior_spec.rb +56 -0
- data/spec/models/external_metadata_file_spec.rb +118 -0
- data/spec/models/file_set_spec.rb +9 -0
- data/spec/models/image_file_spec.rb +48 -0
- data/spec/models/image_work_spec.rb +71 -0
- data/spec/models/raster_file_spec.rb +48 -0
- data/spec/models/raster_work_spec.rb +122 -0
- data/spec/models/solr_document_spec.rb +35 -0
- data/spec/models/vector_file_spec.rb +48 -0
- data/spec/models/vector_work_spec.rb +113 -0
- data/spec/presenters/file_set_presenter_spec.rb +13 -0
- data/spec/presenters/geo_concerns_show_presenter_spec.rb +56 -0
- data/spec/presenters/image_work_show_presenter_spec.rb +52 -0
- data/spec/presenters/raster_work_show_presenter_spec.rb +52 -0
- data/spec/presenters/vector_work_show_presenter_spec.rb +41 -0
- data/spec/processors/geo_concerns/processors/base_geo_processor_spec.rb +109 -0
- data/spec/processors/geo_concerns/processors/raster/aig_spec.rb +28 -0
- data/spec/processors/geo_concerns/processors/raster/base_spec.rb +86 -0
- data/spec/processors/geo_concerns/processors/raster/dem_spec.rb +26 -0
- data/spec/processors/geo_concerns/processors/raster/processor_spec.rb +39 -0
- data/spec/processors/geo_concerns/processors/vector/base_spec.rb +67 -0
- data/spec/processors/geo_concerns/processors/vector/processor_spec.rb +28 -0
- data/spec/processors/geo_concerns/processors/vector/shapefile_spec.rb +17 -0
- data/spec/processors/geo_concerns/processors/zip_spec.rb +39 -0
- data/spec/renderers/coverage_renderer_spec.rb +21 -0
- data/spec/services/derivative_path_spec.rb +12 -0
- data/spec/services/raster_format_service_spec.rb +13 -0
- data/spec/spec_helper.rb +34 -0
- data/spec/support/controllers/engine_helpers.rb +7 -0
- data/spec/support/database_cleaner.rb +18 -0
- data/spec/support/devise.rb +10 -0
- data/spec/support/devise_helpers.rb +6 -0
- data/spec/support/factory_girl.rb +3 -0
- data/spec/support/features.rb +14 -0
- data/spec/support/features/session_helpers.rb +40 -0
- data/spec/support/fixture_reader.rb +7 -0
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +20 -0
- data/spec/values/coverage_spec.rb +40 -0
- data/tasks/ci.rake +49 -0
- metadata +527 -0
@@ -0,0 +1,83 @@
|
|
1
|
+
FactoryGirl.define do
|
2
|
+
factory :vector_work, aliases: [:private_vector_work], class: VectorWork do
|
3
|
+
transient do
|
4
|
+
user { FactoryGirl.create(:user) }
|
5
|
+
|
6
|
+
visibility Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE
|
7
|
+
end
|
8
|
+
|
9
|
+
after(:build) do |vector_work, evaluator|
|
10
|
+
vector_work.apply_depositor_metadata(evaluator.user.user_key)
|
11
|
+
end
|
12
|
+
|
13
|
+
factory :public_vector_work do
|
14
|
+
before(:create) do |vector_work, _evaluator|
|
15
|
+
vector_work.visibility = Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
factory :vector_work_with_one_file do
|
20
|
+
before(:create) do |vector_work, evaluator|
|
21
|
+
vector_work.ordered_members << FactoryGirl.create(:vector_file, user: evaluator.user, title: ['A shapefile'], filename: 'filename.zip')
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
factory :vector_work_with_files do
|
26
|
+
before(:create) do |vector_work, evaluator|
|
27
|
+
2.times { vector_work.ordered_members << FactoryGirl.create(:vector_file, user: evaluator.user) }
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
factory :vector_work_with_raster_works do
|
32
|
+
before(:create) do |vector_work, evaluator|
|
33
|
+
2.times do
|
34
|
+
raster = FactoryGirl.create(:raster, user: evaluator.user)
|
35
|
+
raster.ordered_members << vector_work
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
factory :vector_work_with_one_metadata_file do
|
41
|
+
after(:create) do |vector_work, evaluator|
|
42
|
+
1.times { vector_work.ordered_members << FactoryGirl.create(:external_metadata_file, user: evaluator.user) }
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
factory :vector_work_with_metadata_files do
|
47
|
+
after(:create) do |vector_work, evaluator|
|
48
|
+
2.times { vector_work.ordered_members << FactoryGirl.create(:external_metadata_file, user: evaluator.user) }
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
factory :vector_work_with_vector_and_metadata_files do
|
53
|
+
before(:create) do |vector_work, evaluator|
|
54
|
+
2.times { vector_work.ordered_members << FactoryGirl.create(:vector_file, user: evaluator.user) }
|
55
|
+
2.times { vector_work.ordered_members << FactoryGirl.create(:external_metadata_file, user: evaluator.user) }
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
factory :vector_work_with_embargo_date do
|
60
|
+
transient do
|
61
|
+
embargo_date { Date.tomorrow.to_s }
|
62
|
+
end
|
63
|
+
|
64
|
+
factory :embargoed_vector_work do
|
65
|
+
after(:build) { |vector_work, evaluator| vector_work.apply_embargo(evaluator.embargo_date, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC) }
|
66
|
+
end
|
67
|
+
|
68
|
+
factory :embargoed_vector_work_with_files do
|
69
|
+
after(:build) { |vector_work, evaluator| vector_work.apply_embargo(evaluator.embargo_date, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC) }
|
70
|
+
after(:create) { |vector_work, evaluator| 2.times { vector_work.ordered_members << FactoryGirl.create(:vector_file, user: evaluator.user) } }
|
71
|
+
end
|
72
|
+
|
73
|
+
factory :leased_vector_work do
|
74
|
+
after(:build) { |vector_work, evaluator| vector_work.apply_lease(evaluator.embargo_date, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE) }
|
75
|
+
end
|
76
|
+
|
77
|
+
factory :leased_vector_work_with_files do
|
78
|
+
after(:build) { |vector_work, evaluator| vector_work.apply_lease(evaluator.embargo_date, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PUBLIC, Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE) }
|
79
|
+
after(:create) { |vector_work, evaluator| 2.times { vector_work.ordered_members << FactoryGirl.create(:vector_file, user: evaluator.user) } }
|
80
|
+
end
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
RSpec.feature 'RasterWorkController', type: :feature do
|
4
|
+
let(:user) { FactoryGirl.create(:admin) }
|
5
|
+
let(:fgdc_file) { test_data_fixture_path('zipcodes_fgdc.xml') }
|
6
|
+
|
7
|
+
context "an authorized user" do
|
8
|
+
before do
|
9
|
+
expect(CharacterizeJob).to receive(:perform_later)
|
10
|
+
sign_in user
|
11
|
+
end
|
12
|
+
|
13
|
+
scenario "creating a raster work and attaching a vector work" do
|
14
|
+
visit new_curation_concerns_raster_work_path
|
15
|
+
expect(page).not_to have_text 'Add Your Content'
|
16
|
+
fill_in 'raster_work_title', with: 'Raster Title'
|
17
|
+
fill_in 'raster_work_temporal', with: '1989'
|
18
|
+
choose 'raster_work_visibility_open'
|
19
|
+
select 'Attribution 3.0 United States', from: 'raster_work[rights]'
|
20
|
+
click_button 'Create Raster work'
|
21
|
+
|
22
|
+
expect(page).to have_text 'Raster Title'
|
23
|
+
expect(page).to have_text '1989'
|
24
|
+
expect(page).to have_text 'Open Access'
|
25
|
+
expect(page).to have_link 'Attribution 3.0 United States', href: 'http://creativecommons.org/licenses/by/3.0/us/'
|
26
|
+
|
27
|
+
click_link 'Attach a Vector Work'
|
28
|
+
expect(page).not_to have_text 'Add Your Content'
|
29
|
+
fill_in 'vector_work_title', with: 'Vector Title'
|
30
|
+
fill_in 'vector_work_temporal', with: '1990'
|
31
|
+
choose 'vector_work_visibility_authenticated'
|
32
|
+
select 'Attribution-ShareAlike 3.0 United States', from: 'vector_work[rights]'
|
33
|
+
click_button 'Create Vector work'
|
34
|
+
|
35
|
+
expect(page).to have_text 'Vector Title'
|
36
|
+
expect(page).to have_text '1990'
|
37
|
+
expect(page).to have_text 'Institution Name'
|
38
|
+
expect(page).to have_link 'Attribution-ShareAlike 3.0 United States', href: 'http://creativecommons.org/licenses/by-sa/3.0/us/'
|
39
|
+
|
40
|
+
click_link 'Attach a Metadata File'
|
41
|
+
fill_in 'file_set[title][]', with: 'File Title'
|
42
|
+
select 'FGDC', from: 'file_set_mime_type'
|
43
|
+
attach_file 'file_set[files][]', fgdc_file
|
44
|
+
click_button 'Attach to Vector Work'
|
45
|
+
|
46
|
+
expect(page).to have_text 'zipcodes_fgdc.xml'
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::BasicGeoMetadataForm do
|
4
|
+
before do
|
5
|
+
class TestModel < ActiveFedora::Base
|
6
|
+
property :coverage, predicate: ::RDF::Vocab::DC11.coverage, multiple: false
|
7
|
+
end
|
8
|
+
|
9
|
+
class TestForm < CurationConcerns::Forms::WorkForm
|
10
|
+
include GeoConcerns::BasicGeoMetadataForm
|
11
|
+
self.model_class = TestModel
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
after do
|
16
|
+
Object.send(:remove_const, :TestForm)
|
17
|
+
Object.send(:remove_const, :TestModel)
|
18
|
+
end
|
19
|
+
|
20
|
+
let(:object) { TestModel.new(coverage: GeoConcerns::Coverage.new(43.039, -69.856, 42.943, -71.032).to_s) }
|
21
|
+
let(:form) { TestForm.new(object, nil) }
|
22
|
+
|
23
|
+
describe '.terms' do
|
24
|
+
subject { form.terms }
|
25
|
+
it { is_expected.to include(:coverage) }
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::ExternalMetadataFileForm do
|
4
|
+
before do
|
5
|
+
class TestModel < ActiveFedora::Base
|
6
|
+
end
|
7
|
+
|
8
|
+
class TestForm < CurationConcerns::Forms::WorkForm
|
9
|
+
include GeoConcerns::ExternalMetadataFileForm
|
10
|
+
self.model_class = TestModel
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
after do
|
15
|
+
Object.send(:remove_const, :TestForm)
|
16
|
+
Object.send(:remove_const, :TestModel)
|
17
|
+
end
|
18
|
+
|
19
|
+
let(:object) { TestModel.new }
|
20
|
+
let(:form) { TestForm.new(object, nil) }
|
21
|
+
|
22
|
+
describe '.triggers' do
|
23
|
+
it 'has should_populate_metadata trigger attribute' do
|
24
|
+
expect(form.respond_to?(:should_populate_metadata)).to be_truthy
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::GeoreferencedForm do
|
4
|
+
before do
|
5
|
+
class TestModel < ActiveFedora::Base
|
6
|
+
property :cartographic_projection,
|
7
|
+
predicate: ::RDF::URI.new('http://bibframe.org/vocab/cartographicProjection'),
|
8
|
+
multiple: false
|
9
|
+
end
|
10
|
+
|
11
|
+
class TestForm < CurationConcerns::Forms::WorkForm
|
12
|
+
include GeoConcerns::GeoreferencedForm
|
13
|
+
self.model_class = TestModel
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
after do
|
18
|
+
Object.send(:remove_const, :TestForm)
|
19
|
+
Object.send(:remove_const, :TestModel)
|
20
|
+
end
|
21
|
+
|
22
|
+
let(:object) { TestModel.new(cartographic_projection: 'urn:ogc:def:crs:EPSG:6.3:26986') }
|
23
|
+
let(:form) { TestForm.new(object, nil) }
|
24
|
+
|
25
|
+
describe '.terms' do
|
26
|
+
subject { form.terms }
|
27
|
+
it { is_expected.to include(:cartographic_projection) }
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::ImageWorkForm do
|
4
|
+
let(:coverage) { GeoConcerns::Coverage.new(43.039, -69.856, 42.943, -71.032) }
|
5
|
+
let(:raw_attributes) { ActionController::Parameters.new(coverage: coverage.to_s) }
|
6
|
+
|
7
|
+
describe ".model_attributes" do
|
8
|
+
subject { described_class.model_attributes(raw_attributes) }
|
9
|
+
it { is_expected.to eq('coverage' => coverage.to_s) }
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::RasterWorkForm do
|
4
|
+
let(:coverage) { GeoConcerns::Coverage.new(43.039, -69.856, 42.943, -71.032) }
|
5
|
+
let(:raw_attributes) { ActionController::Parameters.new(
|
6
|
+
coverage: coverage.to_s,
|
7
|
+
cartographic_projection: 'urn:ogc:def:crs:EPSG:6.3:26986')
|
8
|
+
}
|
9
|
+
|
10
|
+
describe '.model_attributes' do
|
11
|
+
subject { described_class.model_attributes(raw_attributes) }
|
12
|
+
it { is_expected.to include('coverage' => coverage.to_s) }
|
13
|
+
it { is_expected.to include('cartographic_projection' => 'urn:ogc:def:crs:EPSG:6.3:26986') }
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::VectorWorkForm do
|
4
|
+
let(:coverage) { GeoConcerns::Coverage.new(43.039, -69.856, 42.943, -71.032) }
|
5
|
+
let(:raw_attributes) { ActionController::Parameters.new(
|
6
|
+
coverage: coverage.to_s,
|
7
|
+
cartographic_projection: 'urn:ogc:def:crs:EPSG:6.3:26986')
|
8
|
+
}
|
9
|
+
|
10
|
+
describe '.model_attributes' do
|
11
|
+
subject { described_class.model_attributes(raw_attributes) }
|
12
|
+
it { is_expected.to include('coverage' => coverage.to_s) }
|
13
|
+
it { is_expected.to include('cartographic_projection' => 'urn:ogc:def:crs:EPSG:6.3:26986') }
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe BoundingBoxHelper do
|
4
|
+
let(:property) { :coverage }
|
5
|
+
let(:helper) { TestingHelper.new }
|
6
|
+
before do
|
7
|
+
class TestingHelper
|
8
|
+
include BoundingBoxHelper
|
9
|
+
|
10
|
+
def curation_concern
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
after do
|
15
|
+
Object.send(:remove_const, :TestingHelper)
|
16
|
+
end
|
17
|
+
|
18
|
+
before do
|
19
|
+
vector_work = instance_double('vector_work', class: VectorWork)
|
20
|
+
allow(helper).to receive(:curation_concern).and_return(vector_work)
|
21
|
+
end
|
22
|
+
|
23
|
+
describe '#bbox' do
|
24
|
+
it 'builds bounding box selector' do
|
25
|
+
expect(helper.bbox(property)).to include("{inputId: vector_work_coverage})")
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
describe '#base_input_id' do
|
30
|
+
it 'returns the id of the bounding box input element' do
|
31
|
+
expect(helper.bbox_input_id(property)).to eq('vector_work_coverage')
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
RSpec.describe GeoConcerns::BasicGeoMetadata do
|
4
|
+
subject { VectorWork.new }
|
5
|
+
|
6
|
+
it 'inherits the specified properties' do
|
7
|
+
%w(title date_uploaded date_modified contributor creator date_created
|
8
|
+
description identifier language part_of publisher resource_type
|
9
|
+
rights source subject tag).map(&:to_sym).each do |p|
|
10
|
+
expect(subject.respond_to?(p)).to be_truthy
|
11
|
+
expect(subject.respond_to?("#{p}=".to_sym)).to be_truthy
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
it 'defines the specified properties' do
|
16
|
+
%w(coverage provenance spatial temporal issued).map(&:to_sym).each do |p|
|
17
|
+
expect(subject.respond_to?(p)).to be_truthy
|
18
|
+
expect(subject.respond_to?("#{p}=".to_sym)).to be_truthy
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,108 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
shared_examples 'a set of raster derivatives' do
|
4
|
+
it 'makes a thumbnail' do
|
5
|
+
new_thumb = "#{Rails.root}/tmp/derivatives/#{file_set.id}/thumbnail.thumbnail"
|
6
|
+
expect {
|
7
|
+
file_set.create_derivatives(file_name)
|
8
|
+
}.to change { Dir[new_thumb].empty? }
|
9
|
+
.from(true).to(false)
|
10
|
+
end
|
11
|
+
|
12
|
+
it 'makes a display raster' do
|
13
|
+
new_thumb = "#{Rails.root}/tmp/derivatives/#{file_set.id}/display_raster.display_raster"
|
14
|
+
expect {
|
15
|
+
file_set.create_derivatives(file_name)
|
16
|
+
}.to change { Dir[new_thumb].empty? }
|
17
|
+
.from(true).to(false)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
shared_examples 'a set of vector derivatives' do
|
22
|
+
it 'makes a thumbnail' do
|
23
|
+
new_thumb = "#{Rails.root}/tmp/derivatives/#{file_set.id}/thumbnail.thumbnail"
|
24
|
+
expect {
|
25
|
+
file_set.create_derivatives(file_name)
|
26
|
+
}.to change { Dir[new_thumb].empty? }
|
27
|
+
.from(true).to(false)
|
28
|
+
end
|
29
|
+
|
30
|
+
it 'makes a display vector' do
|
31
|
+
new_thumb = "#{Rails.root}/tmp/derivatives/#{file_set.id}/display_vector.display_vector"
|
32
|
+
expect {
|
33
|
+
file_set.create_derivatives(file_name)
|
34
|
+
}.to change { Dir[new_thumb].empty? }
|
35
|
+
.from(true).to(false)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
shared_examples 'a set of image derivatives' do
|
40
|
+
it 'makes a thumbnail' do
|
41
|
+
new_thumb = "#{Rails.root}/tmp/derivatives/#{file_set.id}/thumbnail.thumbnail"
|
42
|
+
expect {
|
43
|
+
file_set.create_derivatives(file_name)
|
44
|
+
}.to change { Dir[new_thumb].empty? }
|
45
|
+
.from(true).to(false)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
describe CurationConcerns::FileSet do
|
50
|
+
let(:file_set) { FileSet.create { |gf| gf.apply_depositor_metadata('geonerd@example.com') } }
|
51
|
+
|
52
|
+
before do
|
53
|
+
allow(file_set).to receive(:mime_type).and_return(mime_type)
|
54
|
+
|
55
|
+
allow(CurationConcerns::DerivativePath).to receive(:derivative_path_for_reference) do |object, key|
|
56
|
+
"#{Rails.root}/tmp/derivatives/#{object.id}/#{key}.#{key}"
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
after do
|
61
|
+
dir = File.join(CurationConcerns.config.derivatives_path, file_set.id)
|
62
|
+
FileUtils.rm_r(dir) if File.directory?(dir)
|
63
|
+
end
|
64
|
+
|
65
|
+
describe 'geo derivatives' do
|
66
|
+
describe 'image processing' do
|
67
|
+
context 'with a jpeg' do
|
68
|
+
let(:mime_type) { 'image/jpeg' }
|
69
|
+
let(:file_name) { File.join(fixture_path, 'files', 'americas.jpg') }
|
70
|
+
it_behaves_like 'a set of image derivatives'
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
describe 'vector processing' do
|
75
|
+
context 'with a shapefile' do
|
76
|
+
let(:mime_type) { 'application/zip; ogr-format="ESRI Shapefile"' }
|
77
|
+
let(:file_name) { File.join(fixture_path, 'files', 'tufts-cambridgegrid100-04.zip') }
|
78
|
+
it_behaves_like 'a set of vector derivatives'
|
79
|
+
end
|
80
|
+
|
81
|
+
context 'with a geojson file' do
|
82
|
+
let(:mime_type) { 'application/vnd.geo+json' }
|
83
|
+
let(:file_name) { File.join(fixture_path, 'files', 'mercer.json') }
|
84
|
+
it_behaves_like 'a set of vector derivatives'
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
describe 'raster processing' do
|
89
|
+
context 'with a geo tiff file' do
|
90
|
+
let(:mime_type) { 'image/tiff; gdal-format=GTiff' }
|
91
|
+
let(:file_name) { File.join(fixture_path, 'files', 'S_566_1914_clip.tif') }
|
92
|
+
it_behaves_like 'a set of raster derivatives'
|
93
|
+
end
|
94
|
+
|
95
|
+
context 'with a usgs ascii dem file' do
|
96
|
+
let(:mime_type) { 'text/plain; gdal-format=USGSDEM' }
|
97
|
+
let(:file_name) { File.join(fixture_path, 'files', 'shandaken_clip.dem') }
|
98
|
+
it_behaves_like 'a set of raster derivatives'
|
99
|
+
end
|
100
|
+
|
101
|
+
context 'with an arc/info binary grid file' do
|
102
|
+
let(:mime_type) { 'application/octet-stream; gdal-format=AIG' }
|
103
|
+
let(:file_name) { File.join(fixture_path, 'files', 'precipitation.zip') }
|
104
|
+
it_behaves_like 'a set of raster derivatives'
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe GeoConcerns::GeoFileFormatBehavior do
|
4
|
+
subject { FileSet.new }
|
5
|
+
|
6
|
+
describe '#image_file?' do
|
7
|
+
before do
|
8
|
+
allow(subject).to receive(:mime_type).and_return('image/tiff')
|
9
|
+
end
|
10
|
+
it 'is true' do
|
11
|
+
expect(subject.image_file?).to be true
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
describe '#raster_file?' do
|
16
|
+
before do
|
17
|
+
allow(subject).to receive(:mime_type).and_return('image/tiff; gdal-format=GTiff')
|
18
|
+
end
|
19
|
+
it 'is true' do
|
20
|
+
expect(subject.raster_file?).to be true
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
describe '#vector_file?' do
|
25
|
+
before do
|
26
|
+
allow(subject).to receive(:mime_type).and_return('application/zip; ogr-format="ESRI Shapefile"')
|
27
|
+
end
|
28
|
+
it 'is true' do
|
29
|
+
expect(subject.vector_file?).to be true
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe '#external_metadata_file?' do
|
34
|
+
before do
|
35
|
+
allow(subject).to receive(:mime_type).and_return('application/xml; schema=iso19139')
|
36
|
+
end
|
37
|
+
it 'is true' do
|
38
|
+
expect(subject.external_metadata_file?).to be true
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
describe '#geo_file_format?' do
|
43
|
+
before do
|
44
|
+
allow(subject).to receive(:mime_type).and_return('image/tiff; gdal-format=GTiff')
|
45
|
+
end
|
46
|
+
it 'is true' do
|
47
|
+
expect(subject.geo_file_format?).to be true
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
describe '#image_work?' do
|
52
|
+
it 'is false' do
|
53
|
+
expect(subject.image_work?).to be false
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|