|
|
@ -73,18 +73,26 @@ impl Iterator for TestManifest { |
|
|
|
|
|
|
|
|
|
|
|
fn next(&mut self) -> Option<Result<Test>> { |
|
|
|
fn next(&mut self) -> Option<Result<Test>> { |
|
|
|
loop { |
|
|
|
loop { |
|
|
|
return match self.tests_to_do.pop_front().map(|term| match term { |
|
|
|
if let Some(next) = self.next_test() { |
|
|
|
Term::NamedNode(n) => Ok(n), |
|
|
|
return Some(next); |
|
|
|
Term::BlankNode(n) => Ok(NamedNode::new(format!( |
|
|
|
|
|
|
|
"http://oxigraph.org/.well-known/genid/{}", |
|
|
|
|
|
|
|
n.as_str() |
|
|
|
|
|
|
|
))?), |
|
|
|
|
|
|
|
_ => Err(anyhow!("Invalid test identifier. Got {}", term)), |
|
|
|
|
|
|
|
}) { |
|
|
|
|
|
|
|
Some(Ok(test_node)) => { |
|
|
|
|
|
|
|
if self.graph.triples_for_subject(&test_node).next().is_none() { |
|
|
|
|
|
|
|
continue; // This test does not exists
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if let Err(e) = self.load_next_manifest()? { |
|
|
|
|
|
|
|
return Some(Err(e)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl TestManifest { |
|
|
|
|
|
|
|
fn next_test(&mut self) -> Option<Result<Test>> { |
|
|
|
|
|
|
|
let test_node = self.tests_to_do.pop_front()?; |
|
|
|
|
|
|
|
let test_node = match test_node { |
|
|
|
|
|
|
|
Term::NamedNode(n) => n, |
|
|
|
|
|
|
|
_ => { |
|
|
|
|
|
|
|
return Some(Err(anyhow!("Invalid test identifier. Got {}", test_node))); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
let name = match self |
|
|
|
let name = match self |
|
|
|
.graph |
|
|
|
.graph |
|
|
|
.object_for_subject_predicate(&test_node, mf::NAME) |
|
|
|
.object_for_subject_predicate(&test_node, mf::NAME) |
|
|
@ -98,11 +106,18 @@ impl Iterator for TestManifest { |
|
|
|
{ |
|
|
|
{ |
|
|
|
Some(TermRef::NamedNode(c)) => c.into_owned(), |
|
|
|
Some(TermRef::NamedNode(c)) => c.into_owned(), |
|
|
|
_ => { |
|
|
|
_ => { |
|
|
|
return Some(Err(anyhow!( |
|
|
|
return if test_node |
|
|
|
|
|
|
|
.as_str() |
|
|
|
|
|
|
|
.starts_with("http://www.w3.org/2001/sw/DataAccess/tests/data-r2") |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
self.next_test() //TODO: hack to ignore invalid tests: https://github.com/w3c/rdf-tests/pull/82
|
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
Some(Err(anyhow!( |
|
|
|
"The test {} named {} has no rdf:type", |
|
|
|
"The test {} named {} has no rdf:type", |
|
|
|
test_node, |
|
|
|
test_node, |
|
|
|
name.as_deref().unwrap_or("") |
|
|
|
name.as_deref().unwrap_or("") |
|
|
|
))) |
|
|
|
))) |
|
|
|
|
|
|
|
}; |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
let comment = match self |
|
|
|
let comment = match self |
|
|
@ -125,13 +140,11 @@ impl Iterator for TestManifest { |
|
|
|
vec![], |
|
|
|
vec![], |
|
|
|
), |
|
|
|
), |
|
|
|
Some(TermRef::BlankNode(n)) => { |
|
|
|
Some(TermRef::BlankNode(n)) => { |
|
|
|
let query = match self.graph.object_for_subject_predicate(n, qt::QUERY) |
|
|
|
let query = match self.graph.object_for_subject_predicate(n, qt::QUERY) { |
|
|
|
{ |
|
|
|
|
|
|
|
Some(TermRef::NamedNode(q)) => Some(q.as_str().to_owned()), |
|
|
|
Some(TermRef::NamedNode(q)) => Some(q.as_str().to_owned()), |
|
|
|
_ => None, |
|
|
|
_ => None, |
|
|
|
}; |
|
|
|
}; |
|
|
|
let update = |
|
|
|
let update = match self.graph.object_for_subject_predicate(n, ut::REQUEST) { |
|
|
|
match self.graph.object_for_subject_predicate(n, ut::REQUEST) { |
|
|
|
|
|
|
|
Some(TermRef::NamedNode(q)) => Some(q.as_str().to_owned()), |
|
|
|
Some(TermRef::NamedNode(q)) => Some(q.as_str().to_owned()), |
|
|
|
_ => None, |
|
|
|
_ => None, |
|
|
|
}; |
|
|
|
}; |
|
|
@ -148,26 +161,20 @@ impl Iterator for TestManifest { |
|
|
|
.objects_for_subject_predicate(n, qt::GRAPH_DATA) |
|
|
|
.objects_for_subject_predicate(n, qt::GRAPH_DATA) |
|
|
|
.chain(self.graph.objects_for_subject_predicate(n, ut::GRAPH_DATA)) |
|
|
|
.chain(self.graph.objects_for_subject_predicate(n, ut::GRAPH_DATA)) |
|
|
|
.filter_map(|g| match g { |
|
|
|
.filter_map(|g| match g { |
|
|
|
TermRef::NamedNode(q) => { |
|
|
|
TermRef::NamedNode(q) => Some((q.into_owned(), q.as_str().to_owned())), |
|
|
|
Some((q.into_owned(), q.as_str().to_owned())) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
TermRef::BlankNode(node) => { |
|
|
|
TermRef::BlankNode(node) => { |
|
|
|
if let Some(TermRef::NamedNode(graph)) = |
|
|
|
if let Some(TermRef::NamedNode(graph)) = |
|
|
|
self.graph.object_for_subject_predicate(node, ut::GRAPH) |
|
|
|
self.graph.object_for_subject_predicate(node, ut::GRAPH) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if let Some(TermRef::Literal(name)) = self |
|
|
|
if let Some(TermRef::Literal(name)) = |
|
|
|
.graph |
|
|
|
self.graph.object_for_subject_predicate(node, rdfs::LABEL) |
|
|
|
.object_for_subject_predicate(node, rdfs::LABEL) |
|
|
|
|
|
|
|
{ |
|
|
|
{ |
|
|
|
Some(( |
|
|
|
Some(( |
|
|
|
NamedNode::new(name.value()).unwrap(), |
|
|
|
NamedNode::new(name.value()).unwrap(), |
|
|
|
graph.as_str().to_owned(), |
|
|
|
graph.as_str().to_owned(), |
|
|
|
)) |
|
|
|
)) |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
Some(( |
|
|
|
Some((graph.into_owned(), graph.as_str().to_owned())) |
|
|
|
graph.into_owned(), |
|
|
|
|
|
|
|
graph.as_str().to_owned(), |
|
|
|
|
|
|
|
)) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
None |
|
|
|
None |
|
|
@ -192,10 +199,7 @@ impl Iterator for TestManifest { |
|
|
|
self.graph.object_for_subject_predicate(g, qt::ENDPOINT), |
|
|
|
self.graph.object_for_subject_predicate(g, qt::ENDPOINT), |
|
|
|
self.graph.object_for_subject_predicate(g, qt::DATA), |
|
|
|
self.graph.object_for_subject_predicate(g, qt::DATA), |
|
|
|
) { |
|
|
|
) { |
|
|
|
Some(( |
|
|
|
Some((endpoint.as_str().to_owned(), data.as_str().to_owned())) |
|
|
|
endpoint.as_str().to_owned(), |
|
|
|
|
|
|
|
data.as_str().to_owned(), |
|
|
|
|
|
|
|
)) |
|
|
|
|
|
|
|
} else { |
|
|
|
} else { |
|
|
|
None |
|
|
|
None |
|
|
|
} |
|
|
|
} |
|
|
@ -224,26 +228,20 @@ impl Iterator for TestManifest { |
|
|
|
self.graph |
|
|
|
self.graph |
|
|
|
.objects_for_subject_predicate(n, ut::GRAPH_DATA) |
|
|
|
.objects_for_subject_predicate(n, ut::GRAPH_DATA) |
|
|
|
.filter_map(|g| match g { |
|
|
|
.filter_map(|g| match g { |
|
|
|
TermRef::NamedNode(q) => { |
|
|
|
TermRef::NamedNode(q) => Some((q.into_owned(), q.as_str().to_owned())), |
|
|
|
Some((q.into_owned(), q.as_str().to_owned())) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
TermRef::BlankNode(node) => { |
|
|
|
TermRef::BlankNode(node) => { |
|
|
|
if let Some(TermRef::NamedNode(graph)) = |
|
|
|
if let Some(TermRef::NamedNode(graph)) = |
|
|
|
self.graph.object_for_subject_predicate(node, ut::GRAPH) |
|
|
|
self.graph.object_for_subject_predicate(node, ut::GRAPH) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if let Some(TermRef::Literal(name)) = self |
|
|
|
if let Some(TermRef::Literal(name)) = |
|
|
|
.graph |
|
|
|
self.graph.object_for_subject_predicate(node, rdfs::LABEL) |
|
|
|
.object_for_subject_predicate(node, rdfs::LABEL) |
|
|
|
|
|
|
|
{ |
|
|
|
{ |
|
|
|
Some(( |
|
|
|
Some(( |
|
|
|
NamedNode::new(name.value()).unwrap(), |
|
|
|
NamedNode::new(name.value()).unwrap(), |
|
|
|
graph.as_str().to_owned(), |
|
|
|
graph.as_str().to_owned(), |
|
|
|
)) |
|
|
|
)) |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
Some(( |
|
|
|
Some((graph.into_owned(), graph.as_str().to_owned())) |
|
|
|
graph.into_owned(), |
|
|
|
|
|
|
|
graph.as_str().to_owned(), |
|
|
|
|
|
|
|
)) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
None |
|
|
|
None |
|
|
@ -271,27 +269,32 @@ impl Iterator for TestManifest { |
|
|
|
result_graph_data, |
|
|
|
result_graph_data, |
|
|
|
})) |
|
|
|
})) |
|
|
|
} |
|
|
|
} |
|
|
|
Some(Err(error)) => Some(Err(error)), |
|
|
|
|
|
|
|
None => { |
|
|
|
fn load_next_manifest(&mut self) -> Option<Result<()>> { |
|
|
|
match self.manifests_to_do.pop_front() { |
|
|
|
let url = self.manifests_to_do.pop_front()?; |
|
|
|
Some(url) => { |
|
|
|
|
|
|
|
self.graph.clear(); |
|
|
|
self.graph.clear(); |
|
|
|
if let Err(error) = load_to_graph(&url, &mut self.graph) { |
|
|
|
if let Err(error) = load_to_graph(&url, &mut self.graph) { |
|
|
|
return Some(Err(error)); |
|
|
|
return Some(Err(error)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
for manifest in self |
|
|
|
let manifests = self |
|
|
|
.graph |
|
|
|
.graph |
|
|
|
.subjects_for_predicate_object(rdf::TYPE, mf::MANIFEST) |
|
|
|
.subjects_for_predicate_object(rdf::TYPE, mf::MANIFEST) |
|
|
|
{ |
|
|
|
.collect::<Vec<_>>(); |
|
|
|
|
|
|
|
if manifests.len() != 1 { |
|
|
|
|
|
|
|
return Some(Err(anyhow!( |
|
|
|
|
|
|
|
"The file {} should contain a single manifest", |
|
|
|
|
|
|
|
url |
|
|
|
|
|
|
|
))); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
for manifest in manifests { |
|
|
|
match self |
|
|
|
match self |
|
|
|
.graph |
|
|
|
.graph |
|
|
|
.object_for_subject_predicate(manifest, mf::INCLUDE) |
|
|
|
.object_for_subject_predicate(manifest, mf::INCLUDE) |
|
|
|
{ |
|
|
|
{ |
|
|
|
Some(TermRef::BlankNode(list)) => { |
|
|
|
Some(TermRef::BlankNode(list)) => { |
|
|
|
self.manifests_to_do.extend( |
|
|
|
self.manifests_to_do.extend( |
|
|
|
RdfListIterator::iter(&self.graph, list.into()) |
|
|
|
RdfListIterator::iter(&self.graph, list.into()).filter_map(|m| match m { |
|
|
|
.filter_map(|m| match m { |
|
|
|
|
|
|
|
Term::NamedNode(nm) => Some(nm.into_string()), |
|
|
|
Term::NamedNode(nm) => Some(nm.into_string()), |
|
|
|
_ => None, |
|
|
|
_ => None, |
|
|
|
}), |
|
|
|
}), |
|
|
@ -307,27 +310,16 @@ impl Iterator for TestManifest { |
|
|
|
.object_for_subject_predicate(manifest, mf::ENTRIES) |
|
|
|
.object_for_subject_predicate(manifest, mf::ENTRIES) |
|
|
|
{ |
|
|
|
{ |
|
|
|
Some(TermRef::BlankNode(list)) => { |
|
|
|
Some(TermRef::BlankNode(list)) => { |
|
|
|
self.tests_to_do.extend(RdfListIterator::iter( |
|
|
|
self.tests_to_do |
|
|
|
&self.graph, |
|
|
|
.extend(RdfListIterator::iter(&self.graph, list.into())); |
|
|
|
list.into(), |
|
|
|
|
|
|
|
)); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
Some(term) => { |
|
|
|
Some(term) => { |
|
|
|
return Some(Err(anyhow!( |
|
|
|
return Some(Err(anyhow!("Invalid tests list. Got term {}", term))); |
|
|
|
"Invalid tests list. Got term {}", |
|
|
|
|
|
|
|
term |
|
|
|
|
|
|
|
))); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
None => (), |
|
|
|
None => (), |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
continue; |
|
|
|
Some(Ok(())) |
|
|
|
} |
|
|
|
|
|
|
|
None => None, |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|