diff options
Diffstat (limited to 'askama_actix')
| -rw-r--r-- | askama_actix/Cargo.toml | 9 | ||||
| -rw-r--r-- | askama_actix/src/lib.rs | 12 | ||||
| -rw-r--r-- | askama_actix/tests/basic.rs | 6 | 
3 files changed, 13 insertions, 14 deletions
| diff --git a/askama_actix/Cargo.toml b/askama_actix/Cargo.toml index 06fd2b3..14e996b 100644 --- a/askama_actix/Cargo.toml +++ b/askama_actix/Cargo.toml @@ -1,6 +1,6 @@  [package]  name = "askama_actix" -version = "0.11.1" +version = "0.12.0"  description = "Actix-Web integration for Askama templates"  documentation = "https://docs.rs/askama"  keywords = ["markup", "template", "jinja2", "html"] @@ -13,11 +13,10 @@ readme = "README.md"  edition = "2018"  [dependencies] -actix-web = { version = "4.0.0-beta.14", default-features = false } +actix-web = { version = "3", default-features = false }  askama = { version = "0.11.0", path = "../askama", default-features = false, features = ["with-actix-web", "mime", "mime_guess"] } -bytes = { version = "1" } +bytes = { version = "0.5" }  futures-util = { version = "0.3" }  [dev-dependencies] -actix-rt = { version = "2", default-features = false } -actix-test = "0.1.0-beta.8" +actix-rt = { version = "1", default-features = false } diff --git a/askama_actix/src/lib.rs b/askama_actix/src/lib.rs index baf9fd6..d9ac62d 100644 --- a/askama_actix/src/lib.rs +++ b/askama_actix/src/lib.rs @@ -3,23 +3,23 @@  pub use askama::*;  use bytes::BytesMut; -use actix_web::{error::ErrorInternalServerError, HttpResponse}; +use actix_web::{error::ErrorInternalServerError, Error, HttpResponse};  pub trait TemplateToResponse { -    fn to_response(&self) -> HttpResponse; +    fn to_response(&self) -> std::result::Result<HttpResponse, Error>;  }  impl<T: askama::Template> TemplateToResponse for T { -    fn to_response(&self) -> HttpResponse { +    fn to_response(&self) -> std::result::Result<HttpResponse, Error> {          let mut buffer = BytesMut::with_capacity(T::SIZE_HINT);          if self.render_into(&mut buffer).is_err() { -            return ErrorInternalServerError("Template parsing error").error_response(); +            return Err(ErrorInternalServerError("Template parsing error"));          }          let ctype = askama::mime::extension_to_mime_type(T::EXTENSION.unwrap_or("txt")).to_string(); -        HttpResponse::Ok() +        Ok(HttpResponse::Ok()              .content_type(ctype.as_str()) -            .body(buffer.freeze()) +            .body(buffer.freeze()))      }  } diff --git a/askama_actix/tests/basic.rs b/askama_actix/tests/basic.rs index 070cbf6..c540076 100644 --- a/askama_actix/tests/basic.rs +++ b/askama_actix/tests/basic.rs @@ -11,7 +11,7 @@ struct HelloTemplate<'a> {  #[actix_rt::test]  async fn test_actix_web() { -    let srv = actix_test::start(|| { +    let srv = actix_web::test::start(|| {          actix_web::App::new()              .service(web::resource("/").to(|| async { HelloTemplate { name: "world" } }))      }); @@ -30,10 +30,10 @@ async fn test_actix_web() {  #[actix_rt::test]  async fn test_actix_web_responder() { -    let srv = actix_test::start(|| { +    let srv = actix_web::test::start(|| {          actix_web::App::new().service(web::resource("/").to(|| async {              let name = "world".to_owned(); -            HelloTemplate { name: &name }.to_response().await +            HelloTemplate { name: &name }.to_response()          }))      }); | 
