2020-02-14 08:03:38 +00:00
|
|
|
mod common;
|
|
|
|
|
2021-12-21 17:40:01 +00:00
|
|
|
pub use common::*;
|
2023-01-18 09:23:21 +00:00
|
|
|
|
|
|
|
use byte_strings::c_str;
|
|
|
|
use indymilter_test::*;
|
2020-02-14 08:03:38 +00:00
|
|
|
use spamassassin_milter::*;
|
|
|
|
|
2023-01-18 09:23:21 +00:00
|
|
|
/// A spam message is rejected with an SMTP error reply.
|
2022-02-21 17:58:24 +00:00
|
|
|
#[tokio::test]
|
|
|
|
async fn reject_spam() {
|
2022-03-06 08:21:05 +00:00
|
|
|
let config = configure_spamc(Config::builder())
|
2020-06-14 07:53:08 +00:00
|
|
|
.reject_spam(true)
|
2020-06-16 09:29:25 +00:00
|
|
|
.reply_code("554".into())
|
2020-06-14 07:53:08 +00:00
|
|
|
.reply_text("Not allowed!".into())
|
2023-01-18 09:12:45 +00:00
|
|
|
.spamc_args([format!("--port={SPAMD_PORT}")])
|
2022-03-06 08:21:05 +00:00
|
|
|
.build();
|
2020-02-14 08:03:38 +00:00
|
|
|
|
|
|
|
let server = spawn_mock_spamd_server(SPAMD_PORT, |spam| {
|
|
|
|
Err(spam.replacen("\r\n\r\n", "\r\nX-Spam-Flag: YES\r\n\r\n", 1))
|
2022-02-21 17:58:24 +00:00
|
|
|
})
|
|
|
|
.await
|
|
|
|
.unwrap();
|
2021-12-21 17:40:01 +00:00
|
|
|
|
2022-02-21 17:58:24 +00:00
|
|
|
let milter = SpamAssassinMilter::spawn(LOCALHOST, config).await.unwrap();
|
2020-02-14 08:03:38 +00:00
|
|
|
|
2023-01-18 09:23:21 +00:00
|
|
|
let mut conn = TestConnection::open(milter.addr()).await.unwrap();
|
|
|
|
|
|
|
|
let status = conn.connect("client.gluet.ch", [123, 123, 123, 123]).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.helo("mail.gluet.ch").await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.mail(["<from@gluet.ch>"]).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.rcpt(["<to@gluet.ch>"]).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
conn.macros(
|
|
|
|
MacroStage::Data,
|
|
|
|
[
|
|
|
|
("i", "1234567ABC"),
|
|
|
|
("j", "localhost"),
|
|
|
|
("_", "client.gluet.ch [123.123.123.123]"),
|
|
|
|
("{tls_version}", "TLSv1.2"),
|
|
|
|
("v", "Postfix 3.3.0"),
|
|
|
|
],
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let status = conn.data().await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.header("From", "from@gluet.ch").await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.header("To", "to@gluet.ch").await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.header("Subject", "Test message").await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.header("Message-ID", rand_msg_id()).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.header("Date", current_date()).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.eoh().await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let status = conn.body(&b"Test message body"[..]).await.unwrap();
|
|
|
|
assert_eq!(status, Status::Continue);
|
|
|
|
|
|
|
|
let (_, status) = conn.eom().await.unwrap();
|
|
|
|
assert_eq!(
|
|
|
|
status,
|
|
|
|
Status::Reject {
|
|
|
|
message: Some(c_str!("554 5.7.1 Not allowed!").into()),
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
conn.close().await.unwrap();
|
2020-02-14 08:03:38 +00:00
|
|
|
|
2022-02-21 17:58:24 +00:00
|
|
|
milter.shutdown().await.unwrap();
|
2020-02-14 08:03:38 +00:00
|
|
|
|
2023-01-18 09:23:21 +00:00
|
|
|
server.await.unwrap().unwrap();
|
2020-02-14 08:03:38 +00:00
|
|
|
}
|