require File.expand_path('../../../spec_helper', __FILE__)
require 'nokogiri'
module NcsNavigator::Mdes
describe VariableType do
describe '.from_xsd_simple_type' do
def vtype(body_s, name=nil)
VariableType.from_xsd_simple_type(schema_element(<<-XML), :log => logger)
#{body_s}
XML
end
def vtype_from_string(restriction_body, name=nil)
vtype(<<-XML, name)
#{restriction_body}
XML
end
describe 'with an unsupported restriction base' do
let!(:subject) { vtype('') }
it 'is nil' do
subject.should be_nil
end
it 'logs a warning' do
logger[:warn].first.
should == 'Unsupported restriction base in simpleType on line 2'
end
end
describe 'with an unsupported restriction subelement' do
let!(:subject) { vtype_from_string('') }
it 'logs a warning' do
logger[:warn].first.should == 'Unsupported restriction element "color" on line 4'
end
end
describe '#name' do
it 'is set if there is one' do
vtype_from_string(nil, 'foo').name.should == 'foo'
end
it 'is nil if there is not one' do
vtype_from_string(nil, nil).name.should be_nil
end
end
describe '#max_length' do
it 'is set if present' do
vtype_from_string('').max_length.should == 255
end
end
describe '#min_length' do
it 'is set if present' do
vtype_from_string('').min_length.should == 1
end
end
describe '#pattern' do
it 'is compiled to a regexp if present' do
vtype_from_string('').
pattern.should == /^([0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9])?$/
end
describe 'when malformed' do
let!(:subject) { vtype_from_string('') }
it 'is nil if present but malformed' do
subject.pattern.should be_nil
end
it 'logs a warning' do
logger[:warn].first.should == 'Uncompilable pattern "([" in simpleType on line 4'
end
end
end
describe '#base_type' do
it 'is :string' do
vtype_from_string('').base_type.should == :string
end
end
it 'is not a reference' do
vtype_from_string('').should_not be_reference
end
describe '#code_list' do
context 'when there are no enumerated values' do
it 'is nil' do
vtype_from_string('').code_list.should be_nil
end
end
context 'when there are enumerated values' do
subject {
vtype_from_string(<<-XSD)
XSD
}
it 'has an entry for each value' do
subject.code_list.collect(&:to_s).should == %w(1 2 3 -7 -4)
end
it 'has the description' do
subject.code_list.description.should == "Eq"
end
end
end
end
describe '.reference' do
subject { VariableType.reference('ncs:bar') }
it 'has the right name' do
subject.name.should == 'ncs:bar'
end
it 'is a reference' do
subject.should be_reference
end
end
describe '.xml_schema_type' do
subject { VariableType.xml_schema_type('int') }
it 'has no name' do
subject.name.should be_nil
end
it 'has the correct base type' do
subject.base_type.should == :int
end
it 'is not a reference' do
subject.should_not be_reference
end
end
end
describe VariableType::CodeListEntry do
describe '.from_xsd_enumeration' do
def code_list_entry(xml_s)
VariableType::CodeListEntry.from_xsd_enumeration(schema_element(xml_s), :log => logger)
end
let(:missing) {
code_list_entry(<<-XSD)
XSD
}
describe '#value' do
it 'is set' do
missing.value.should == "-4"
end
it 'warns when missing' do
code_list_entry('')
logger[:warn].first.should == 'Missing value for code list entry on line 2'
end
describe 'with external whitespace on the value' do
let(:missing) {
code_list_entry(<<-XSD)
XSD
}
it 'removes the whitespace' do
missing.value.should == '-4'
end
end
end
describe "#label" do
it 'is set' do
missing.label.should == "Missing in Error"
end
end
describe '#global_value' do
it 'is set' do
missing.global_value.should == '99-4'
end
end
describe '#master_cl' do
it 'is set' do
missing.master_cl.should == 'missing_data'
end
end
end
describe '#to_s' do
it 'is the value' do
VariableType::CodeListEntry.new('14').to_s.should == '14'
end
end
end
end