|
|
@ -94,7 +94,7 @@ fn simple_service_test() { |
|
|
|
"#; |
|
|
|
"#; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let query_options = QueryOptions::default(); |
|
|
|
let query_options = QueryOptions::default().with_service_handler(Box::new(TestServiceHandler)); |
|
|
|
let prepared_query = connection.prepare_query(query, &query_options).unwrap(); |
|
|
|
let prepared_query = connection.prepare_query(query, &query_options).unwrap(); |
|
|
|
let results = prepared_query.exec(&query_options).unwrap(); |
|
|
|
let results = prepared_query.exec(&query_options).unwrap(); |
|
|
|
if let QueryResult::Bindings(results) = results { |
|
|
|
if let QueryResult::Bindings(results) = results { |
|
|
@ -107,10 +107,16 @@ fn simple_service_test() { |
|
|
|
assert_eq!(true, false); |
|
|
|
assert_eq!(true, false); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
/* |
|
|
|
|
|
|
|
#[derive(Clone,Copy)] |
|
|
|
|
|
|
|
struct TwoServiceTest; |
|
|
|
|
|
|
|
impl ServiceHandler for TwoServiceTest { |
|
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
|
|
|
fn two_service_test() { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Clone,Copy)] |
|
|
|
|
|
|
|
struct TwoServiceTest; |
|
|
|
|
|
|
|
impl ServiceHandler for TwoServiceTest { |
|
|
|
fn handle<'a>(&'a self, named_node: NamedNode) -> Option<(fn(GraphPattern) -> Result<BindingsIterator<'a>>)> { |
|
|
|
fn handle<'a>(&'a self, named_node: NamedNode) -> Option<(fn(GraphPattern) -> Result<BindingsIterator<'a>>)> { |
|
|
|
println!("Handler called for {:?}", named_node);
|
|
|
|
println!("Handler called for {:?}", named_node);
|
|
|
|
let service1 = NamedNode::parse("http://service1.org").unwrap(); |
|
|
|
let service1 = NamedNode::parse("http://service1.org").unwrap(); |
|
|
@ -119,10 +125,10 @@ impl ServiceHandler for TwoServiceTest { |
|
|
|
else if named_node == service2 { Some(TwoServiceTest::handle_service2) } |
|
|
|
else if named_node == service2 { Some(TwoServiceTest::handle_service2) } |
|
|
|
else { None}
|
|
|
|
else { None}
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl TwoServiceTest { |
|
|
|
impl TwoServiceTest { |
|
|
|
|
|
|
|
|
|
|
|
fn handle_service1<'a>(graph_pattern: GraphPattern) -> Result<BindingsIterator<'a>> { |
|
|
|
fn handle_service1<'a>(graph_pattern: GraphPattern) -> Result<BindingsIterator<'a>> { |
|
|
|
let repository = MemoryRepository::default(); |
|
|
|
let repository = MemoryRepository::default(); |
|
|
@ -132,8 +138,9 @@ impl TwoServiceTest { |
|
|
|
<http://example.com/alice> <http://xmlns.com/foaf/0.1/name> "Alice" .
|
|
|
|
<http://example.com/alice> <http://xmlns.com/foaf/0.1/name> "Alice" .
|
|
|
|
"#; |
|
|
|
"#; |
|
|
|
connection.load_graph(file.as_ref(), GraphSyntax::NTriples, None, None).unwrap(); |
|
|
|
connection.load_graph(file.as_ref(), GraphSyntax::NTriples, None, None).unwrap(); |
|
|
|
let prepared_query = connection.prepare_query_from_pattern(&graph_pattern, None).unwrap(); |
|
|
|
let query_options = QueryOptions::default().with_service_handler(Box::new(TwoServiceTest)); |
|
|
|
let result = prepared_query.exec(&Some(NoneService)).unwrap(); |
|
|
|
let prepared_query = connection.prepare_query_from_pattern(&graph_pattern, &query_options).unwrap(); |
|
|
|
|
|
|
|
let result = prepared_query.exec(&query_options).unwrap(); |
|
|
|
match result { |
|
|
|
match result { |
|
|
|
QueryResult::Bindings(iterator) => { |
|
|
|
QueryResult::Bindings(iterator) => { |
|
|
|
let (variables, iter) = iterator.destruct(); |
|
|
|
let (variables, iter) = iterator.destruct(); |
|
|
@ -156,8 +163,9 @@ impl TwoServiceTest { |
|
|
|
<http://example.com/alice> <http://xmlns.com/foaf/0.1/mbox> <mailto:alice@example.com> .
|
|
|
|
<http://example.com/alice> <http://xmlns.com/foaf/0.1/mbox> <mailto:alice@example.com> .
|
|
|
|
"#; |
|
|
|
"#; |
|
|
|
connection.load_graph(file.as_ref(), GraphSyntax::NTriples, None, None).unwrap(); |
|
|
|
connection.load_graph(file.as_ref(), GraphSyntax::NTriples, None, None).unwrap(); |
|
|
|
let prepared_query = connection.prepare_query_from_pattern(&graph_pattern, None).unwrap(); |
|
|
|
let query_options = QueryOptions::default().with_service_handler(Box::new(TwoServiceTest)); |
|
|
|
let result = prepared_query.exec(&Some(NoneService)).unwrap(); |
|
|
|
let prepared_query = connection.prepare_query_from_pattern(&graph_pattern, &query_options).unwrap(); |
|
|
|
|
|
|
|
let result = prepared_query.exec(&query_options).unwrap(); |
|
|
|
match result { |
|
|
|
match result { |
|
|
|
QueryResult::Bindings(iterator) => { |
|
|
|
QueryResult::Bindings(iterator) => { |
|
|
|
let (variables, iter) = iterator.destruct(); |
|
|
|
let (variables, iter) = iterator.destruct(); |
|
|
@ -169,11 +177,8 @@ impl TwoServiceTest { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
|
|
|
fn two_service_test() { |
|
|
|
|
|
|
|
let repository = MemoryRepository::default(); |
|
|
|
let repository = MemoryRepository::default(); |
|
|
|
let connection = repository.connection().unwrap(); |
|
|
|
let connection = repository.connection().unwrap(); |
|
|
|
|
|
|
|
|
|
|
@ -193,9 +198,9 @@ fn two_service_test() { |
|
|
|
ORDER BY ?name |
|
|
|
ORDER BY ?name |
|
|
|
"#; |
|
|
|
"#; |
|
|
|
|
|
|
|
|
|
|
|
let prepared_query = connection.prepare_query(query, None).unwrap(); |
|
|
|
let query_options = QueryOptions::default().with_service_handler(Box::new(TwoServiceTest)); |
|
|
|
let service_handler = Some(TwoServiceTest); |
|
|
|
let prepared_query = connection.prepare_query(query, &query_options).unwrap(); |
|
|
|
let results = prepared_query.exec(&service_handler).unwrap(); |
|
|
|
let results = prepared_query.exec(&query_options).unwrap(); |
|
|
|
if let QueryResult::Bindings(results) = results { |
|
|
|
if let QueryResult::Bindings(results) = results { |
|
|
|
let collected = results.into_values_iter().map(move |b| b.unwrap()).collect::<Vec<_>>(); |
|
|
|
let collected = results.into_values_iter().map(move |b| b.unwrap()).collect::<Vec<_>>(); |
|
|
|
for c in collected.clone() { |
|
|
|
for c in collected.clone() { |
|
|
@ -212,6 +217,5 @@ fn two_service_test() { |
|
|
|
assert_eq!(true, false); |
|
|
|
assert_eq!(true, false); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
*/ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|