Skip to content

Commit

Permalink
test: add an integration test
Browse files Browse the repository at this point in the history
Signed-off-by: hi-rustin <[email protected]>
  • Loading branch information
Rustin170506 committed Apr 5, 2024
1 parent 7d8cf16 commit c1964bf
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 6 deletions.
4 changes: 2 additions & 2 deletions src/typosquat/database.rs
Original file line number Diff line number Diff line change
Expand Up @@ -174,8 +174,8 @@ mod tests {
let mut faker = Faker::new();

// Set up two users.
let user_a = faker.user(&mut conn, "a")?;
let user_b = faker.user(&mut conn, "b")?;
let user_a = faker.user(&mut conn, "a", None)?;
let user_b = faker.user(&mut conn, "b", None)?;

// Set up three crates with various ownership schemes.
let _top_a = faker.crate_and_version(&mut conn, "a", "Hello", &user_a, 2)?;
Expand Down
9 changes: 7 additions & 2 deletions src/typosquat/test_util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,10 +101,15 @@ impl Faker {
))
}

pub fn user(&mut self, conn: &mut PgConnection, login: &str) -> anyhow::Result<User> {
pub fn user(
&mut self,
conn: &mut PgConnection,
login: &str,
email: Option<String>,
) -> anyhow::Result<User> {
Ok(
NewUser::new(self.next_id(), login, None, None, "token").create_or_update(
None,
email.as_deref(),
&self.emails,
conn,
)?,
Expand Down
50 changes: 50 additions & 0 deletions src/worker/jobs/expiry_notification.rs
Original file line number Diff line number Diff line change
Expand Up @@ -84,3 +84,53 @@ impl Email for ExpiryNotificationEmail {
)
}
}

#[cfg(test)]
mod tests {
use super::*;
use crate::{
models::token::ApiToken, schema::api_tokens, test_util::test_db_connection,
typosquat::test_util::Faker, util::token::PlainToken,
};
use diesel::{QueryDsl, SelectableHelper};
use lettre::Address;

#[tokio::test]
async fn test_expiry_notification() -> anyhow::Result<()> {
let emails = Emails::new_in_memory();
let (_test_db, mut conn) = test_db_connection();
let mut faker = Faker::new();

// Set up a user and a token that is about to expire.
let user = faker.user(&mut conn, "a", Some("[email protected]".to_owned()))?;
let token = PlainToken::generate();
let expired_at = diesel::dsl::now;

let token: ApiToken = diesel::insert_into(api_tokens::table)
.values((
api_tokens::user_id.eq(user.id),
api_tokens::name.eq("test_token"),
api_tokens::token.eq(token.hashed()),
api_tokens::expired_at.eq(expired_at),
))
.returning(ApiToken::as_returning())
.get_result(&mut conn)?;

// Check that the token is about to expire.
check(&emails, &mut conn)?;

// Check that an email was sent.
let sent_mail = emails.mails_in_memory().unwrap();
assert_eq!(sent_mail.len(), 1);
let sent = &sent_mail[0];
assert_eq!(&sent.0.to(), &["[email protected]".parse::<Address>()?]);
assert!(sent.1.contains("Your token is about to expire"));
let update_token = api_tokens::table
.filter(api_tokens::id.eq(token.id))
.select(ApiToken::as_select())
.first::<ApiToken>(&mut conn)?;
assert!(update_token.expiry_notification_at.is_some());

Ok(())
}
}
4 changes: 2 additions & 2 deletions src/worker/jobs/typosquat.rs
Original file line number Diff line number Diff line change
Expand Up @@ -130,14 +130,14 @@ mod tests {
let mut faker = Faker::new();

// Set up a user and a popular crate to match against.
let user = faker.user(&mut conn, "a")?;
let user = faker.user(&mut conn, "a", None)?;
faker.crate_and_version(&mut conn, "my-crate", "It's awesome", &user, 100)?;

// Prime the cache so it only includes the crate we just created.
let cache = Cache::new(vec!["[email protected]".to_string()], &mut conn)?;

// Now we'll create new crates: one problematic, one not so.
let other_user = faker.user(&mut conn, "b")?;
let other_user = faker.user(&mut conn, "b", None)?;
let (angel, _version) = faker.crate_and_version(
&mut conn,
"innocent-crate",
Expand Down

0 comments on commit c1964bf

Please sign in to comment.