# coding: utf-8 $:.unshift "." require 'spec_helper' require 'rdf/spec/writer' describe JSON::LD::Writer do let(:logger) {RDF::Spec.logger} after(:each) {|example| puts logger.to_s if example.exception} it_behaves_like 'an RDF::Writer' do let(:writer) {JSON::LD::Writer.new(StringIO.new, logger: logger)} end describe ".for" do formats = [ :jsonld, "etc/doap.jsonld", {file_name: 'etc/doap.jsonld'}, {file_extension: 'jsonld'}, {content_type: 'application/ld+json'}, {content_type: 'application/x-ld+json'}, ].each do |arg| it "discovers with #{arg.inspect}" do expect(RDF::Reader.for(arg)).to eq JSON::LD::Reader end end end context "simple tests" do it "should use full URIs without base" do input = %( .) expect(serialize(input)).to produce([{ '@id' => "http://a/b", "http://a/c" => [{"@id" => "http://a/d"}] }], logger) end it "should use qname URIs with standard prefix" do input = %( .) expect(serialize(input, standard_prefixes: true)).to produce({ '@context' => { "foaf" => "http://xmlns.com/foaf/0.1/", }, '@id' => "foaf:b", "foaf:c" => {"@id" => "foaf:d"} }, logger) end it "should use qname URIs with parsed prefix" do input = %( . "Rhythm Paradise"@en . "Rhythm Tengoku"@en . "rhythm-tengoku" . ) expect(serialize(input, prefixes: { dc: "http://purl.org/dc/terms/", frbr: "http://vocab.org/frbr/core#", senet: "https://senet.org/ns#", })).to produce({ '@context' => { "dc" => "http://purl.org/dc/terms/", "frbr" => "http://vocab.org/frbr/core#", "senet" => "https://senet.org/ns#" }, '@id' => "https://senet.org/gm", "@type" => "frbr:Work", "dc:title" => {"@value" => "Rhythm Paradise","@language" => "en"}, "senet:unofficialTitle" => {"@value" => "Rhythm Tengoku","@language" => "en"}, "senet:urlkey" => "rhythm-tengoku" }, logger) end it "should use CURIEs with empty prefix" do input = %( .) begin expect(serialize(input, prefixes: { "" => RDF::Vocab::FOAF})). to produce({ "@context" => { "" => "http://xmlns.com/foaf/0.1/" }, '@id' => ":b", ":c" => {"@id" => ":d"} }, logger) rescue JSON::LD::JsonLdError, JSON::LD::JsonLdError, TypeError => e fail("#{e.class}: #{e.message}\n" + "#{logger}\n" + "Backtrace:\n#{e.backtrace.join("\n")}") end end it "should not use terms if no suffix" do input = %( .) expect(serialize(input, standard_prefixes: true)). not_to produce({ "@context" => {"foaf" => "http://xmlns.com/foaf/0.1/"}, '@id' => "foaf", "foaf" => {"@id" => "foaf"} }, logger) end it "should not use CURIE with illegal local part" do input = %( @prefix db: . @prefix dbo: . db:Michael_Jackson dbo:artistOf . ) expect(serialize(input, prefixes: { "db" => RDF::URI("http://dbpedia.org/resource/"), "dbo" => RDF::URI("http://dbpedia.org/ontology/")})). to produce({ "@context" => { "db" => "http://dbpedia.org/resource/", "dbo" => "http://dbpedia.org/ontology/" }, '@id' => "db:Michael_Jackson", "dbo:artistOf" => {"@id" => "db:%28I_Can%27t_Make_It%29_Another_Day"} }, logger) end it "should not use provided node identifiers if :unique_bnodes set" do input = %(_:a _:b \.) result = serialize(input, unique_bnodes: true, context: {}) expect(result.to_json).to match(%r(_:g\w+)) end it "serializes multiple subjects" do input = %q( @prefix : . @prefix dc: . a :TestCase . a :TestCase . ) expect(serialize(input, prefixes: {"" => "http://www.w3.org/2006/03/test-description#"})). to produce({ '@context' => { "" => "http://www.w3.org/2006/03/test-description#", "dc" => RDF::Vocab::DC.to_s }, '@graph' => [ {'@id' => "http://example.com/test-cases/0001", '@type' => ":TestCase"}, {'@id' => "http://example.com/test-cases/0002", '@type' => ":TestCase"} ] }, logger) end it "serializes Wikia OWL example" do input = %q( @prefix owl: . @prefix rdf: . @prefix rdfs: . @prefix xsd: . a owl:Class; rdfs:subClassOf _:a . _:a a owl:Restriction; owl:minQualifiedCardinality "1"^^xsd:nonNegativeInteger; owl:onClass ; owl:onProperty . ) expect(serialize(input, rename_bnodes: false, prefixes: { owl: "http://www.w3.org/2002/07/owl#", rdfs: "http://www.w3.org/2000/01/rdf-schema#", xsd: "http://www.w3.org/2001/XMLSchema#" })). to produce({ '@context' => { "owl" => "http://www.w3.org/2002/07/owl#", "rdf" => "http://www.w3.org/1999/02/22-rdf-syntax-ns#", "rdfs" => "http://www.w3.org/2000/01/rdf-schema#", "xsd" => "http://www.w3.org/2001/XMLSchema#" }, '@graph' => [ { "@id" => "_:a", "@type" => "owl:Restriction", "owl:minQualifiedCardinality" => {"@value" => "1","@type" => "xsd:nonNegativeInteger"}, "owl:onClass" => {"@id" => "http://data.wikia.com/terms#Element"}, "owl:onProperty" => {"@id" => "http://data.wikia.com/terms#characterIn"} }, { "@id" => "http://data.wikia.com/terms#Character", "@type" => "owl:Class", "rdfs:subClassOf" => {"@id" => "_:a"} } ] }, logger) end end context "Writes fromRdf tests to isomorphic graph", skip: ENV['CI'] do require 'suite_helper' m = Fixtures::SuiteTest::Manifest.open("#{Fixtures::SuiteTest::SUITE}tests/fromRdf-manifest.jsonld") describe m.name do m.entries.each do |t| next unless t.positiveTest? && !t.property('input').include?('0016') specify "#{t.property('input')}: #{t.name}" do logger.info "test: #{t.inspect}" logger.info "source: #{t.input}" t.logger = logger pending "Shared list BNode in different graphs" if t.property('input').include?("fromRdf-0021") pending "graph comparison issue" if t.property('input').include?("fromRdf-0008") repo = RDF::Repository.load(t.input_loc, format: :nquads) jsonld = JSON::LD::Writer.buffer(logger: t.logger) do |writer| writer << repo end # And then, re-generate jsonld as RDF expect(parse(jsonld, format: :jsonld)).to be_equivalent_graph(repo, t) end end end end def parse(input, options = {}) format = options.fetch(:format, :trig) reader = RDF::Reader.for(format) RDF::Repository.new << reader.new(input, options) end # Serialize ntstr to a string and compare against regexps def serialize(ntstr, options = {}) g = ntstr.is_a?(String) ? parse(ntstr, options) : ntstr #logger.info g.dump(:ttl) result = JSON::LD::Writer.buffer(options.merge(logger: logger)) do |writer| writer << g end if $verbose #puts hash.to_json end JSON.parse(result) end end