require File.join(File.dirname(__FILE__), 'spec_helper')
describe "Literals: " do
describe "an untyped string" do
subject {Literal.untyped("tom")}
it "should be equal if they have the same contents" do should == Literal.untyped("tom") end
it "should not be equal if they do not have the same contents" do should_not == Literal.untyped("tim") end
it "should match a string" do should == "tom" end
it "should return a string using to_s" do subject.to_s.should == "tom" end
it "should infer type" do
other = Literal.build_from("foo")
other.encoding.should == "http://www.w3.org/2001/XMLSchema#string"
end
describe "should handle specific cases" do
{
'"Gregg"' => Literal.untyped("Gregg"),
'"\u677E\u672C \u540E\u5B50"' => Literal.untyped("松本 后子"),
'"D\u00FCrst"' => Literal.untyped("Dürst")
}.each_pair do |encoded, literal|
it "should encode '#{literal.contents}'" do
literal.to_n3.should == encoded
end
end
end
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"tom\"" end
it "should return ntriples" do subject.to_ntriples.should == "\"tom\"" end
it "should return xml_args" do subject.xml_args.should == ["tom", {}] end
it "should return TriX" do subject.to_trix.should == "tom" end
end
describe "with extended characters" do
subject { Literal.untyped("松本 后子") }
describe "encodings" do
it "should return n3" do subject.to_n3.should == '"\u677E\u672C \u540E\u5B50"' end
it "should return ntriples" do subject.to_ntriples.should == '"\u677E\u672C \u540E\u5B50"' end
it "should return xml_args" do subject.xml_args.should == ["松本 后子", {}] end
it "should return TriX" do subject.to_trix.should == "" + "松本 后子" + "" end
end
end
describe "with a language" do
subject { Literal.untyped("tom", "en") }
it "should accept a language tag" do
subject.lang.should == "en"
end
it "should be equal if they have the same contents and language" do
should == Literal.untyped("tom", "en")
end
it "should not be equal if they do not have the same contents" do
should_not == Literal.untyped("tim", "en")
end
it "should not be equal if they do not have the same language" do
should_not == Literal.untyped("tom", "fr")
end
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"tom\"@en" end
it "should return ntriples" do subject.to_ntriples.should == "\"tom\"@en" end
it "should return xml_args" do subject.xml_args.should == ["tom", {"xml:lang" => "en"}] end
it "should return TriX" do subject.to_trix.should == "tom" end
end
it "should normalize language tags to lower case" do
f = Literal.untyped("tom", "EN")
f.lang.should == "en"
end
end
end
describe "a typed string" do
subject { Literal.typed("tom", "http://www.w3.org/2001/XMLSchema#string") }
it "accepts an encoding" do
subject.encoding.to_s.should == "http://www.w3.org/2001/XMLSchema#string"
end
it "should be equal if they have the same contents and datatype" do
should == Literal.typed("tom", "http://www.w3.org/2001/XMLSchema#string")
end
it "should not be equal if they do not have the same contents" do
should_not == Literal.typed("tim", "http://www.w3.org/2001/XMLSchema#string")
end
it "should not be equal if they do not have the same datatype" do
should_not == Literal.typed("tom", "http://www.w3.org/2001/XMLSchema#token")
end
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"tom\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["tom", {"rdf:datatype" => "http://www.w3.org/2001/XMLSchema#string"}] end
it "should return TriX" do subject.to_trix.should == "tom" end
end
end
describe "an integer" do
describe "encodings" do
subject { Literal.typed(5, "http://www.w3.org/2001/XMLSchema#int") }
it "should return n3" do subject.to_n3.should == "\"5\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["5", {"rdf:datatype" => "http://www.w3.org/2001/XMLSchema#int"}] end
it "should return TriX" do subject.to_trix.should == "5" end
end
it "should infer type" do
int = Literal.build_from(15)
int.encoding.should == "http://www.w3.org/2001/XMLSchema#int"
end
end
describe "a float" do
describe "encodings" do
subject { Literal.typed(15.4, "http://www.w3.org/2001/XMLSchema#float") }
it "should return n3" do subject.to_n3.should == "\"15.4\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["15.4", {"rdf:datatype" => "http://www.w3.org/2001/XMLSchema#float"}] end
it "should return TriX" do subject.to_trix.should == "15.4" end
end
it "should infer type" do
float = Literal.build_from(15.4)
float.encoding.should == "http://www.w3.org/2001/XMLSchema#float"
end
end
describe "XML Literal" do
describe "with no namespace" do
subject { Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral") }
it "should indicate xmlliteral?" do
subject.xmlliteral?.should == true
end
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"foo bar baz!\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["foo bar baz!", {"rdf:parseType" => "Literal"}] end
it "should return TriX" do subject.to_trix.should == "foo bar baz!" end
end
it "should be equal if they have the same contents" do
should == Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral")
end
it "should be a XMLLiteral encoding" do
subject.encoding.should == "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral"
end
end
describe "with a namespace" do
subject {
Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:namespaces => {"dc" => Namespace.new("http://purl.org/dc/elements/1.1/", "dc")})
}
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"foo bar baz!\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["foo bar baz!", {"rdf:parseType" => "Literal"}] end
it "should return TriX" do subject.to_trix.should == "foo bar baz!" end
end
describe "and language" do
subject {
Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:namespaces => {"dc" => Namespace.new("http://purl.org/dc/elements/1.1/", "dc")},
:language => "fr")
}
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"foo bar baz!\"\^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["foo bar baz!", {"rdf:parseType" => "Literal"}] end
it "should return TriX" do subject.to_trix.should == "foo bar baz!" end
end
end
describe "and language with an existing language embedded" do
subject {
Literal.typed("foo barbaz",
"http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:language => "fr")
}
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"foo barbaz\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["foo barbaz", {"rdf:parseType" => "Literal"}] end
it "should return TriX" do subject.to_trix.should == "foo barbaz" end
end
end
describe "and namespaced element" do
subject {
root = Nokogiri::XML.parse(%(
Test 0100
), nil, nil, Nokogiri::XML::ParseOptions::DEFAULT_XML).root
content = root.css("h2").children
Literal.typed(content,
"http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:namespaces => {
"svg" => Namespace.new("http://www.w3.org/2000/svg", "svg"),
"dc" => Namespace.new("http://purl.org/dc/elements/1.1/", "dc")
})
}
it "should return xml_args" do subject.xml_args.should == ["", {"rdf:parseType" => "Literal"}] end
end
describe "and existing namespace definition" do
subject {
Literal.typed("",
"http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:namespaces => {"svg" => Namespace.new("http://www.w3.org/2000/svg", "svg")})
}
it "should return xml_args" do subject.xml_args.should == ["", {"rdf:parseType" => "Literal"}] end
end
end
describe "with a default namespace" do
subject {
Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral",
:namespaces => {"" => Namespace.new("http://purl.org/dc/elements/1.1/", "")})
}
describe "encodings" do
it "should return n3" do subject.to_n3.should == "\"foo bar baz!\"^^" end
it "should return ntriples" do subject.to_ntriples.should == subject.to_n3 end
it "should return xml_args" do subject.xml_args.should == ["foo bar baz!", {"rdf:parseType" => "Literal"}] end
it "should return TriX" do subject.to_trix.should == "foo bar baz!" end
end
end
describe "with multiple namespaces" do
subject {
Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral")
}
it "should ignore namespace order" do
g = Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral")
should == g
end
end
describe "with multiple attributes" do
it "should ignore attribute order" do
f = Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral")
g = Literal.typed("foo bar baz!", "http://www.w3.org/1999/02/22-rdf-syntax-ns#XMLLiteral")
f.should == g
end
end
end
describe "an n3 literal" do
{
"Gregg" => ['Gregg', nil, nil],
"Dürst" => ['D\u00FCrst', nil, nil],
"simple literal" => ['simple literal', nil, nil],
"backslash:\\" => ['backslash:\\\\', nil, nil],
"dquote:\"" => ['dquote:\\"', nil, nil],
"newline:\n" => ['newline:\\n', nil, nil],
"return:\r" => ['return:\\r', nil, nil],
"tab:\t" => ['tab:\\t', nil, nil],
}.each_pair do |name, args|
specify "test #{name}" do
Literal.n3_encoded(*args).contents.should == name
end
end
end
# it "build_from_language" do
# english = Literal.build_from_language("Have a nice day")
# english.encoding.should == "en"
#
# french = Literal.build_from_language("Bonjour, madame. Parlez vous francais?")
# french.encoding.should == "fr"
#
# german = Literal.build_from_language("Achtung")
# german.encoding.should == "de"
# end
# TODO: refactor based on new interface
# describe "Languages" do
# it "should be inspectable" do
# literal = Reddy::Literal.new("foo", "en")
# lang = literal.lang
# lang.to_s == "en"
# lang.hash.class.should == Fixnum
# end
# end
end