ruby-avm-library/spec/avm/image_spec.rb
2011-03-23 14:10:02 -04:00

351 lines
13 KiB
Ruby

require 'spec_helper'
require 'avm/image'
describe AVM::Image do
let(:image) { self.class.describes.new(options) }
let(:options) { {} }
subject { image }
let(:title) { 'My title' }
let(:headline) { 'Headline' }
let(:description) { 'Description' }
let(:distance_notes) { 'Distance Notes' }
let(:spectral_notes) { 'Spectral Notes' }
let(:reference_url) { 'Reference URL' }
let(:credit) { 'Credit' }
let(:date) { '2010-01-01' }
let(:id) { 'ID' }
let(:type) { 'Observation' }
let(:image_quality) { 'Good' }
let(:redshift) { 'Redshift' }
let(:light_years) { 'Light years' }
let(:subject_names) { [ 'Name one', 'Name two' ] }
let(:categories) { [ 'Category one', 'Category two' ] }
let(:coordinate_frame) { 'ICRS' }
let(:equinox) { '100' }
let(:reference_value) { [ 100, 50 ] }
let(:reference_dimension) { [ 200, 150 ] }
let(:reference_pixel) { [ 25, 15 ] }
let(:spatial_scale) { [ 40, 35 ] }
let(:spatial_rotation) { 10.0 }
let(:coordinate_system_projection) { 'TAN' }
let(:spatial_quality) { 'Full' }
let(:spatial_notes) { 'Spatial Notes' }
let(:fits_header) { 'FITS header' }
let(:spatial_cd_matrix) { [ 1, 2, 3, 4 ] }
let(:publisher) { 'Publisher' }
let(:publisher_id) { 'Publisher ID' }
let(:resource_id) { 'Resource ID' }
let(:resource_url) { 'Resource URL' }
let(:related_resources) { [ 'Resource 1', 'Resource 2' ] }
let(:metadata_date) { '2010-01-05' }
let(:metadata_version) { '1.2' }
def self.with_all_options
let(:options) { {
:title => title,
:headline => headline,
:description => description,
:distance_notes => distance_notes,
:spectral_notes => spectral_notes,
:reference_url => reference_url,
:credit => credit,
:date => date,
:id => id,
:type => type,
:quality => image_quality,
:redshift => redshift,
:light_years => light_years,
:coordinate_frame => coordinate_frame,
:equinox => equinox,
:reference_value => reference_value,
:reference_dimension => reference_dimension,
:reference_pixel => reference_pixel,
:spatial_scale => spatial_scale,
:spatial_rotation => spatial_rotation,
:coordinate_system_projection => coordinate_system_projection,
:spatial_quality => spatial_quality,
:spatial_notes => spatial_notes,
:fits_header => fits_header,
:spatial_cd_matrix => spatial_cd_matrix,
:publisher => publisher,
:publisher_id => publisher_id,
:resource_id => resource_id,
:resource_url => resource_url,
:related_resources => related_resources,
:metadata_date => metadata_date,
:metadata_version => metadata_version,
:subject_names => subject_names,
:categories => categories
} }
end
let(:avm_image_type) { eval("AVM::ImageType::#{type}") }
let(:avm_image_quality) { eval("AVM::ImageQuality::#{image_quality}") }
let(:avm_coordinate_frame) { eval("AVM::CoordinateFrame::#{coordinate_frame}") }
let(:avm_coordinate_system_projection) { eval("AVM::CoordinateSystemProjection::#{coordinate_system_projection}") }
let(:avm_spatial_quality) { eval("AVM::SpatialQuality::#{spatial_quality}") }
def self.has_most_options
its(:creator) { should be_a_kind_of(AVM::Creator) }
its(:title) { should == title }
its(:headline) { should == headline }
its(:description) { should == description }
its(:distance_notes) { should == distance_notes }
its(:spectral_notes) { should == spectral_notes }
its(:reference_url) { should == reference_url }
its(:credit) { should == credit }
its(:date) { should == Time.parse(date) }
its(:id) { should == id }
its(:image_type) { should be_a_kind_of avm_image_type }
its(:image_quality) { should be_a_kind_of avm_image_quality }
its(:coordinate_frame) { should be_a_kind_of avm_coordinate_frame }
its(:equinox) { should == equinox }
its(:reference_value) { should == reference_value }
its(:reference_dimension) { should == reference_dimension }
its(:reference_pixel) { should == reference_pixel }
its(:spatial_scale) { should == spatial_scale }
its(:spatial_rotation) { should == spatial_rotation }
its(:coordinate_system_projection) { should be_a_kind_of avm_coordinate_system_projection }
its(:spatial_quality) { should be_a_kind_of avm_spatial_quality }
its(:spatial_notes) { should == spatial_notes }
its(:fits_header) { should == fits_header }
its(:spatial_cd_matrix) { should == spatial_cd_matrix }
its(:publisher) { should == publisher }
its(:publisher_id) { should == publisher_id }
its(:resource_id) { should == resource_id }
its(:resource_url) { should == resource_url }
its(:related_resources) { should == related_resources }
its(:metadata_date) { should == Time.parse(metadata_date) }
its(:metadata_version) { should == metadata_version }
its(:subject_names) { should == subject_names }
its(:categories) { should == categories }
it { should be_valid }
end
describe '#initialize' do
with_all_options
it { should be_a_kind_of(AVM::Image) }
has_most_options
its(:to_h) { should == {
:title => title,
:headline => headline,
:description => description,
:distance_notes => distance_notes,
:spectral_notes => spectral_notes,
:reference_url => reference_url,
:credit => credit,
:date => Time.parse(date),
:id => id,
:image_type => avm_image_type.new,
:image_quality => avm_image_quality.new,
:coordinate_frame => avm_coordinate_frame.new,
:equinox => equinox,
:reference_value => reference_value,
:reference_dimension => reference_dimension,
:reference_pixel => reference_pixel,
:spatial_scale => spatial_scale,
:spatial_rotation => spatial_rotation,
:coordinate_system_projection => avm_coordinate_system_projection.new,
:spatial_quality => avm_spatial_quality.new,
:spatial_notes => spatial_notes,
:fits_header => fits_header,
:spatial_cd_matrix => spatial_cd_matrix,
:distance => [ light_years, redshift ],
:creator => [],
:publisher => publisher,
:publisher_id => publisher_id,
:resource_id => resource_id,
:resource_url => resource_url,
:related_resources => related_resources,
:metadata_date => Time.parse(metadata_date),
:metadata_version => metadata_version,
:subject_names => subject_names,
:categories => categories,
:observations => []
} }
its(:distance) { should == [ light_years, redshift ] }
end
describe 'not valid' do
let(:image) { AVM::Image.new }
it { should_not be_valid }
end
describe '.from_xml' do
let!(:image) { AVM::Image.from_xml(File.read(file_path)) }
subject { image }
context "nothing in it" do
let(:file_path) { 'spec/sample_files/image/nothing.xmp' }
[ :title, :headline, :description, :distance_notes,
:spectral_notes, :reference_url, :credit, :date,
:id, :image_type, :image_quality, :redshift,
:light_years, :coordinate_frame, :equinox, :reference_value,
:reference_dimension, :reference_pixel, :spatial_scale,
:spatial_rotation, :coordinate_system_projection, :spatial_quality, :spatial_notes,
:fits_header, :spatial_cd_matrix, :subject_names, :categories
].each do |field|
its(field) { should be_nil }
end
it { should_not be_valid }
end
context "image in it" do
context 'distance as a single value, assume light years' do
let(:file_path) { 'spec/sample_files/image/single_value_light_years.xmp' }
has_most_options
its(:redshift) { should be_nil }
its(:light_years) { should == light_years }
end
context "distance in light years" do
let(:file_path) { 'spec/sample_files/image/light_years.xmp' }
has_most_options
its(:redshift) { should be_nil }
its(:light_years) { should == light_years }
end
context "distaince in redshift" do
let(:file_path) { 'spec/sample_files/image/redshift.xmp' }
has_most_options
its(:light_years) { should be_nil }
its(:redshift) { should == redshift }
end
context "distance in both" do
let(:file_path) { 'spec/sample_files/image/both.xmp' }
has_most_options
its(:light_years) { should == light_years }
its(:redshift) { should == redshift }
end
end
end
describe '#to_xml' do
let(:xml) { image.to_xml }
let(:dublin_core) { xml.at_xpath('//rdf:Description[@rdf:about="Dublin Core"]') }
let(:photoshop) { xml.at_xpath('//rdf:Description[@rdf:about="Photoshop"]') }
let(:avm) { xml.at_xpath('//rdf:Description[@rdf:about="AVM"]') }
context 'nothing in it' do
it "should have basic tags" do
xml.at_xpath('//rdf:RDF').should_not be_nil
xml.search('//rdf:RDF/rdf:Description').should_not be_empty
photoshop.at_xpath('./photoshop:DateCreated').should_not be_nil
end
end
context 'with basics' do
with_all_options
def xpath_text(which, xpath)
which.at_xpath(xpath).text
end
def xpath_list(which, xpath, search = './/rdf:li')
which.at_xpath(xpath).search(search).collect(&:text)
end
it "should have the image info tags" do
xpath_text(dublin_core, './dc:title/rdf:Alt/rdf:li').should == title
xpath_text(photoshop, './photoshop:Headline').should == headline
xpath_text(dublin_core, './dc:description/rdf:Alt/rdf:li').should == description
xpath_text(avm, './avm:Distance.Notes').should == distance_notes
xpath_text(avm, './avm:Spectral.Notes').should == spectral_notes
xpath_text(avm, './avm:ReferenceURL').should == reference_url
xpath_text(photoshop, './photoshop:Credit').should == credit
xpath_text(photoshop, './photoshop:DateCreated').should == date
xpath_text(avm, './avm:ID').should == id
xpath_text(avm, './avm:Type').should == type
xpath_text(avm, './avm:Image.ProductQuality').should == image_quality
end
it "should have the spatial tags" do
xpath_text(avm, './avm:Spatial.CoordinateFrame').should == coordinate_frame
xpath_text(avm, './avm:Spatial.Equinox').should == equinox
xpath_list(avm, './avm:Spatial.ReferenceValue').should == reference_value.collect { |v| v.to_f.to_s }
xpath_list(avm, './avm:Spatial.ReferenceDimension').should == reference_dimension.collect { |v| v.to_f.to_s }
xpath_list(avm, './avm:Spatial.ReferencePixel').should == reference_pixel.collect { |v| v.to_f.to_s }
xpath_list(avm, './avm:Spatial.Scale').should == spatial_scale.collect { |v| v.to_f.to_s }
xpath_text(avm, './avm:Spatial.CoordsystemProjection').should == coordinate_system_projection
xpath_text(avm, './avm:Spatial.Quality').should == spatial_quality
xpath_text(avm, './avm:Spatial.Notes').should == spatial_notes
xpath_text(avm, './avm:Spatial.FITSheader').should == fits_header
xpath_list(avm, './avm:Spatial.CDMatrix').should == spatial_cd_matrix.collect { |v| v.to_f.to_s }
end
it "should have the publisher tags" do
xpath_text(avm, './avm:Publisher').should == publisher
xpath_text(avm, './avm:PublisherID').should == publisher_id
xpath_text(avm, './avm:ResourceID').should == resource_id
xpath_text(avm, './avm:ResourceURL').should == resource_url
xpath_list(avm, './avm:RelatedResources', './rdf:Bag/rdf:li').should == related_resources
xpath_text(avm, './avm:MetadataDate').should == metadata_date
xpath_text(avm, './avm:MetadataVersion').should == metadata_version
end
context "distance" do
context "no distances" do
let(:redshift) { nil }
let(:light_years) { nil }
it("should have no distances") { avm.at_xpath('./avm:Distance').should be_nil }
end
context "redshift only" do
let(:light_years) { nil }
it "should have redshift only" do
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[1]').text.should == '-'
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[2]').text.should == redshift
end
end
context "light years only" do
let(:redshift) { nil }
it "should should have light years but not redshift" do
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[1]').text.should == light_years
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[2]').should be_nil
end
end
context "redshift and light years" do
it "should have both light years and redshift" do
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[1]').text.should == light_years
avm.at_xpath('./avm:Distance/rdf:Seq/rdf:li[2]').text.should == redshift
end
end
end
end
end
end