-
Notifications
You must be signed in to change notification settings - Fork 2
/
suite_spec.rb
55 lines (49 loc) · 1.72 KB
/
suite_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
$:.unshift "."
require 'spec_helper'
describe RDF::TriG::Reader do
describe "w3c TriG tests" do
require 'suite_helper'
# TriG/manifest.ttl
%w(rdf11/rdf-trig/manifest.ttl).each do |man|
Fixtures::SuiteTest::Manifest.open(Fixtures::SuiteTest::BASE + man) do |m|
describe m.comment do
m.entries.each do |t|
specify "#{t.name}: #{t.comment}" do
case t.name
when false
else
t.logger = RDF::Spec.logger
t.logger.info t.inspect
t.logger.info "source:\n#{t.input}"
reader = RDF::TriG::Reader.new(t.input,
base_uri: t.base,
canonicalize: false,
validate: true,
logger: t.logger)
repo = RDF::Repository.new
if t.positive_test?
begin
repo << reader
rescue Exception => e
expect(e.message).to produce("Not exception #{e.inspect}", t)
end
else
expect {
repo << reader
expect(repo.dump(:nquads)).to produce("not this", t)
}.to raise_error(RDF::ReaderError)
end
if t.evaluate? && t.positive_test?
output_repo = RDF::Repository.load(t.result, format: :nquads, base_uri: t.base)
expect(repo).to be_equivalent_graph(output_repo, t)
elsif !t.evaluate?
expect(repo).to be_a(RDF::Enumerable)
end
end
end
end
end
end
end
end
end unless ENV['CI']