113 lines
3.3 KiB
Rust
113 lines
3.3 KiB
Rust
use crate::helpers::{TestApp, when_sending_an_email};
|
|
use wiremock::ResponseTemplate;
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_displays_a_confirmation_message_for_valid_form_data() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
when_sending_an_email()
|
|
.respond_with(ResponseTemplate::new(200))
|
|
.mount(&app.email_server)
|
|
.await;
|
|
|
|
let email = "alphonse.paix@outlook.com";
|
|
let body = format!("email={email}");
|
|
let response = app.post_subscriptions(body).await;
|
|
|
|
assert!(response.status().is_success());
|
|
let html_fragment = response.text().await.unwrap();
|
|
assert!(html_fragment.contains("You'll receive a confirmation email shortly"));
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_persists_the_new_subscriber() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
when_sending_an_email()
|
|
.respond_with(ResponseTemplate::new(200))
|
|
.mount(&app.email_server)
|
|
.await;
|
|
|
|
let email = "alphonse.paix@outlook.com";
|
|
let body = format!("email={email}");
|
|
let response = app.post_subscriptions(body).await;
|
|
|
|
assert!(response.status().is_success());
|
|
let html_fragment = dbg!(response.text().await.unwrap());
|
|
assert!(html_fragment.contains("You'll receive a confirmation email shortly"));
|
|
|
|
let saved = sqlx::query!("SELECT email, status FROM subscriptions")
|
|
.fetch_one(&app.connection_pool)
|
|
.await
|
|
.expect("Failed to fetch saved subscription");
|
|
|
|
assert_eq!(saved.email, "alphonse.paix@outlook.com");
|
|
assert_eq!(saved.status, "pending_confirmation");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_returns_a_422_when_data_is_missing() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
let response = app.post_subscriptions(String::new()).await;
|
|
|
|
assert_eq!(
|
|
422,
|
|
response.status().as_u16(),
|
|
"the API did not fail with 422 Unprocessable Entity when the payload was missing the email"
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_sends_a_confirmation_email_for_valid_data() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
let email = "alphonse.paix@outlook.com";
|
|
let body = format!("email={email}");
|
|
|
|
when_sending_an_email()
|
|
.respond_with(ResponseTemplate::new(200))
|
|
.expect(1)
|
|
.mount(&app.email_server)
|
|
.await;
|
|
|
|
app.post_subscriptions(body).await;
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_sends_a_confirmation_email_with_a_link() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
let email = "alphonse.paix@outlook.com";
|
|
let body = format!("email={email}");
|
|
|
|
when_sending_an_email()
|
|
.respond_with(ResponseTemplate::new(200))
|
|
.expect(1)
|
|
.mount(&app.email_server)
|
|
.await;
|
|
|
|
app.post_subscriptions(body).await;
|
|
|
|
let email_request = &app.email_server.received_requests().await.unwrap()[0];
|
|
let confirmation_links = app.get_confirmation_links(email_request);
|
|
assert_eq!(confirmation_links.html, confirmation_links.text);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn subscribe_fails_if_there_is_a_fatal_database_error() {
|
|
let app = TestApp::spawn().await;
|
|
|
|
let email = "alphonse.paix@outlook.com";
|
|
let body = format!("name=Alphonse&email={}", email);
|
|
|
|
sqlx::query!("ALTER TABLE subscriptions DROP COLUMN email")
|
|
.execute(&app.connection_pool)
|
|
.await
|
|
.unwrap();
|
|
|
|
let response = app.post_subscriptions(body).await;
|
|
|
|
assert_eq!(response.status().as_u16(), 500);
|
|
}
|