Improves server test coverage

pull/190/head
Tpt 3 years ago
parent d986ae526b
commit 0f5e64650e
  1. 72
      server/src/main.rs

@ -1057,15 +1057,26 @@ mod tests {
#[test] #[test]
fn get_query() { fn get_query() {
ServerTest::new().test_status( let server = ServerTest::new();
Request::builder(
Method::GET, let request = Request::builder(Method::POST, "http://localhost/store".parse().unwrap())
"http://localhost/query?query=SELECT%20*%20WHERE%20{%20?s%20?p%20?o%20}" .with_header(HeaderName::CONTENT_TYPE, "application/trig")
.parse() .unwrap()
.unwrap(), .with_body("<http://example.com> <http://example.com> <http://example.com> .");
) server.test_status(request, Status::NO_CONTENT);
.build(),
Status::OK, let request = Request::builder(
Method::GET,
"http://localhost/query?query=SELECT%20?s%20?p%20?o%20WHERE%20{%20?s%20?p%20?o%20}"
.parse()
.unwrap(),
)
.with_header(HeaderName::ACCEPT, "text/csv")
.unwrap()
.build();
server.test_body(
request,
"s,p,o\r\nhttp://example.com,http://example.com,http://example.com",
); );
} }
@ -1073,21 +1084,24 @@ mod tests {
fn get_query_accept_star() { fn get_query_accept_star() {
let request = Request::builder( let request = Request::builder(
Method::GET, Method::GET,
"http://localhost/query?query=SELECT%20*%20WHERE%20{%20?s%20?p%20?o%20}" "http://localhost/query?query=SELECT%20?s%20?p%20?o%20WHERE%20{%20?s%20?p%20?o%20}"
.parse() .parse()
.unwrap(), .unwrap(),
) )
.with_header(HeaderName::ACCEPT, "*/*") .with_header(HeaderName::ACCEPT, "*/*")
.unwrap() .unwrap()
.build(); .build();
ServerTest::new().test_status(request, Status::OK); ServerTest::new().test_body(
request,
"{\"head\":{\"vars\":[\"s\",\"p\",\"o\"]},\"results\":{\"bindings\":[]}}",
);
} }
#[test] #[test]
fn get_query_accept_good() { fn get_query_accept_good() {
let request = Request::builder( let request = Request::builder(
Method::GET, Method::GET,
"http://localhost/query?query=SELECT%20*%20WHERE%20{%20?s%20?p%20?o%20}" "http://localhost/query?query=SELECT%20?s%20?p%20?o%20WHERE%20{%20?s%20?p%20?o%20}"
.parse() .parse()
.unwrap(), .unwrap(),
) )
@ -1097,7 +1111,10 @@ mod tests {
) )
.unwrap() .unwrap()
.build(); .build();
ServerTest::new().test_status(request, Status::OK); ServerTest::new().test_body(
request,
"{\"head\":{\"vars\":[\"s\",\"p\",\"o\"]},\"results\":{\"bindings\":[]}}",
);
} }
#[test] #[test]
@ -1128,11 +1145,26 @@ mod tests {
#[test] #[test]
fn get_query_union_graph() { fn get_query_union_graph() {
ServerTest::new().test_status(Request::builder( let server = ServerTest::new();
let request = Request::builder(Method::PUT, "http://localhost/store/1".parse().unwrap())
.with_header(HeaderName::CONTENT_TYPE, "text/turtle")
.unwrap()
.with_body("<http://example.com> <http://example.com> <http://example.com> .");
server.test_status(request, Status::CREATED);
let request = Request::builder(
Method::GET, Method::GET,
"http://localhost/query?query=SELECT%20*%20WHERE%20{%20?s%20?p%20?o%20}&union-default-graph".parse() "http://localhost/query?query=SELECT%20?s%20?p%20?o%20WHERE%20{%20?s%20?p%20?o%20}&union-default-graph"
.parse()
.unwrap(), .unwrap(),
).build(), Status::OK); ).with_header(HeaderName::ACCEPT, "text/csv")
.unwrap()
.build();
server.test_body(
request,
"s,p,o\r\nhttp://example.com,http://example.com,http://example.com",
);
} }
#[test] #[test]
@ -1540,6 +1572,14 @@ mod tests {
response.body_mut().read_to_string(&mut buf).unwrap(); response.body_mut().read_to_string(&mut buf).unwrap();
assert_eq!(response.status(), expected_status, "Error message: {}", buf); assert_eq!(response.status(), expected_status, "Error message: {}", buf);
} }
fn test_body(&self, request: Request, expected_body: &str) {
let mut response = self.exec(request);
let mut buf = String::new();
response.body_mut().read_to_string(&mut buf).unwrap();
assert_eq!(response.status(), Status::OK, "Error message: {}", buf);
assert_eq!(&buf, expected_body);
}
} }
#[test] #[test]

Loading…
Cancel
Save