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