dcrouter/test/suite/smtpclient_rfc-compliance/test.crfc-04.response-codes.ts

54 lines
1.8 KiB
TypeScript
Raw Normal View History

2025-05-24 18:12:08 +00:00
import { expect, tap } from '@git.zone/tstest/tapbundle';
import { createTestServer } from '../../helpers/server.loader.js';
2025-05-26 14:50:55 +00:00
import { createTestSmtpClient } from '../../helpers/smtp.client.js';
import { Email } from '../../../ts/mail/core/classes.email.js';
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
tap.test('CRFC-04: SMTP Response Code Handling', async () => {
console.log('\n📧 Testing SMTP Client Response Code Handling');
console.log('=' .repeat(60));
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
const testServer = await createTestServer({});
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
try {
const smtpClient = createTestSmtpClient({
2025-05-24 18:12:08 +00:00
host: testServer.hostname,
2025-05-26 14:50:55 +00:00
port: testServer.port
2025-05-24 18:12:08 +00:00
});
2025-05-26 14:50:55 +00:00
console.log('\nTest 1: Successful email (2xx responses)');
const email1 = new Email({
2025-05-24 18:12:08 +00:00
from: 'sender@example.com',
to: ['recipient@example.com'],
2025-05-26 14:50:55 +00:00
subject: 'Success test',
text: 'Testing successful response codes'
2025-05-24 18:12:08 +00:00
});
2025-05-26 14:50:55 +00:00
const result1 = await smtpClient.sendMail(email1);
console.log(' ✓ 2xx response codes handled correctly');
expect(result1).toBeDefined();
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
console.log('\nTest 2: Verify connection');
const verified = await smtpClient.verify();
console.log(' ✓ Connection verification successful');
expect(verified).toBeDefined();
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
console.log('\nTest 3: Multiple recipients (multiple 250 responses)');
const email2 = new Email({
2025-05-24 18:12:08 +00:00
from: 'sender@example.com',
2025-05-26 14:50:55 +00:00
to: ['user1@example.com', 'user2@example.com', 'user3@example.com'],
subject: 'Multiple recipients',
text: 'Testing multiple positive responses'
2025-05-24 18:12:08 +00:00
});
2025-05-26 14:50:55 +00:00
const result2 = await smtpClient.sendMail(email2);
console.log(' ✓ Multiple positive responses handled');
expect(result2).toBeDefined();
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
console.log('\n✅ CRFC-04: Response code handling tests completed');
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
} finally {
testServer.server.close();
}
});
2025-05-24 18:12:08 +00:00
2025-05-26 14:50:55 +00:00
tap.start();