fingerd/local_email: write tests
Build and test / check (push) Successful in 1m8s
Build and test / build (push) Successful in 1m38s
Build and test / test (push) Successful in 1m54s
Build and test / docs (push) Successful in 4m46s

This commit is contained in:
2026-06-24 13:22:37 +09:00
parent 41d00321d5
commit a6a1bd2324
3 changed files with 149 additions and 0 deletions
+117
View File
@@ -89,3 +89,120 @@ fn detect_new_mail_by_maildir(maildir_path: &Path) -> anyhow::Result<MailStatus>
))
}
}
#[cfg(test)]
mod tests {
use super::*;
use nix::{
fcntl::AT_FDCWD,
sys::{stat::UtimensatFlags, time::TimeSpec},
};
use std::{fs, os::unix::fs::MetadataExt};
use tempfile::TempDir;
fn set_file_times(path: &Path, atime: i64, mtime: i64) {
nix::sys::stat::utimensat(
AT_FDCWD,
path,
&TimeSpec::new(atime, 0),
&TimeSpec::new(mtime, 0),
UtimensatFlags::FollowSymlink,
)
.unwrap();
}
fn set_dir_mtime(path: &Path, mtime: i64) {
let metadata = fs::metadata(path).unwrap();
set_file_times(path, metadata.atime(), mtime);
}
#[test]
fn test_detect_new_mail_by_mailbox_new_mail_received() {
let tempdir = TempDir::new().unwrap();
let mailbox = tempdir.path().join("Mailbox");
fs::write(&mailbox, b"mail").unwrap();
set_file_times(&mailbox, 1_700_000_000, 1_700_000_100);
let status = detect_new_mail_by_mailbox(&mailbox).unwrap();
assert_eq!(
status,
MailStatus::NewMailReceived {
received_time: Utc.timestamp_opt(1_700_000_100, 0).single().unwrap(),
unread_since: Utc.timestamp_opt(1_700_000_000, 0).single().unwrap(),
}
);
}
#[test]
fn test_detect_new_mail_by_mailbox_mail_last_read() {
let tempdir = TempDir::new().unwrap();
let mailbox = tempdir.path().join("Mailbox");
fs::write(&mailbox, b"mail").unwrap();
set_file_times(&mailbox, 1_700_000_100, 1_700_000_000);
let status = detect_new_mail_by_mailbox(&mailbox).unwrap();
assert_eq!(
status,
MailStatus::MailLastRead(Utc.timestamp_opt(1_700_000_100, 0).single().unwrap())
);
}
#[test]
fn test_detect_new_mail_by_maildir_no_mail() {
let tempdir = TempDir::new().unwrap();
let maildir = tempdir.path().join("Maildir");
let new_dir = maildir.join("new");
let cur_dir = maildir.join("cur");
fs::create_dir_all(&new_dir).unwrap();
fs::create_dir_all(&cur_dir).unwrap();
let status = detect_new_mail_by_maildir(&maildir).unwrap();
assert_eq!(status, MailStatus::NoMail);
}
#[test]
fn test_detect_new_mail_by_maildir_new_mail_received() {
let tempdir = TempDir::new().unwrap();
let maildir = tempdir.path().join("Maildir");
let new_dir = maildir.join("new");
let cur_dir = maildir.join("cur");
fs::create_dir_all(&new_dir).unwrap();
fs::create_dir_all(&cur_dir).unwrap();
fs::write(new_dir.join("msg"), b"mail").unwrap();
set_dir_mtime(&cur_dir, 1_700_000_000);
set_dir_mtime(&new_dir, 1_700_000_100);
let status = detect_new_mail_by_maildir(&maildir).unwrap();
assert_eq!(
status,
MailStatus::NewMailReceived {
received_time: Utc.timestamp_opt(1_700_000_100, 0).single().unwrap(),
unread_since: Utc.timestamp_opt(1_700_000_000, 0).single().unwrap(),
}
);
}
#[test]
fn test_detect_new_mail_by_maildir_mail_last_read() {
let tempdir = TempDir::new().unwrap();
let maildir = tempdir.path().join("Maildir");
let new_dir = maildir.join("new");
let cur_dir = maildir.join("cur");
fs::create_dir_all(&new_dir).unwrap();
fs::create_dir_all(&cur_dir).unwrap();
fs::write(cur_dir.join("msg"), b"mail").unwrap();
set_dir_mtime(&new_dir, 1_700_000_000);
set_dir_mtime(&cur_dir, 1_700_000_100);
let status = detect_new_mail_by_maildir(&maildir).unwrap();
assert_eq!(
status,
MailStatus::MailLastRead(Utc.timestamp_opt(1_700_000_100, 0).single().unwrap())
);
}
}