- Add test.dns-manager-creation.ts to verify DNS record creation - Test MX, SPF, DMARC, and DKIM record registration - Verify records are stored in StorageManager - Update readme.hints.md with DNS architecture refactoring notes
141 lines
4.9 KiB
TypeScript
141 lines
4.9 KiB
TypeScript
import { tap, expect } from '@git.zone/tstest/tapbundle';
|
|
import * as plugins from '../ts/plugins.js';
|
|
import * as paths from '../ts/paths.js';
|
|
import { DnsManager } from '../ts/mail/routing/classes.dns.manager.js';
|
|
import { DKIMCreator } from '../ts/mail/security/classes.dkimcreator.js';
|
|
import { StorageManager } from '../ts/storage/classes.storagemanager.js';
|
|
import type { IEmailDomainConfig } from '../ts/mail/routing/interfaces.js';
|
|
|
|
// Mock DcRouter with DNS server
|
|
class MockDcRouter {
|
|
public storageManager: StorageManager;
|
|
public dnsServer: any;
|
|
public options: any;
|
|
private dnsHandlers: Map<string, any> = new Map();
|
|
|
|
constructor(testDir: string, dnsDomain?: string) {
|
|
this.storageManager = new StorageManager({ fsPath: testDir });
|
|
this.options = { dnsDomain };
|
|
|
|
// Mock DNS server
|
|
this.dnsServer = {
|
|
registerHandler: (name: string, types: string[], handler: () => any) => {
|
|
const key = `${name}:${types.join(',')}`;
|
|
this.dnsHandlers.set(key, handler);
|
|
}
|
|
};
|
|
}
|
|
|
|
getDnsHandler(name: string, type: string): any {
|
|
const key = `${name}:${type}`;
|
|
return this.dnsHandlers.get(key);
|
|
}
|
|
}
|
|
|
|
tap.test('DnsManager - Create Internal DNS Records', async () => {
|
|
const testDir = plugins.path.join(paths.dataDir, '.test-dns-manager-creation');
|
|
const mockRouter = new MockDcRouter(testDir, 'ns.test.com') as any;
|
|
const dnsManager = new DnsManager(mockRouter);
|
|
|
|
const domainConfigs: IEmailDomainConfig[] = [
|
|
{
|
|
domain: 'test.example.com',
|
|
dnsMode: 'internal-dns',
|
|
dns: {
|
|
internal: {
|
|
mxPriority: 15,
|
|
ttl: 7200
|
|
}
|
|
},
|
|
dkim: {
|
|
selector: 'test2024',
|
|
keySize: 2048
|
|
}
|
|
}
|
|
];
|
|
|
|
// Create DNS records
|
|
await dnsManager.ensureDnsRecords(domainConfigs);
|
|
|
|
// Verify MX record was registered
|
|
const mxHandler = mockRouter.getDnsHandler('test.example.com', 'MX');
|
|
expect(mxHandler).toBeTruthy();
|
|
const mxRecord = mxHandler();
|
|
expect(mxRecord.type).toEqual('MX');
|
|
expect(mxRecord.data.priority).toEqual(15);
|
|
expect(mxRecord.data.exchange).toEqual('test.example.com');
|
|
expect(mxRecord.ttl).toEqual(7200);
|
|
|
|
// Verify SPF record was registered
|
|
const txtHandler = mockRouter.getDnsHandler('test.example.com', 'TXT');
|
|
expect(txtHandler).toBeTruthy();
|
|
const spfRecord = txtHandler();
|
|
expect(spfRecord.type).toEqual('TXT');
|
|
expect(spfRecord.data).toEqual('v=spf1 a mx ~all');
|
|
|
|
// Verify DMARC record was registered
|
|
const dmarcHandler = mockRouter.getDnsHandler('_dmarc.test.example.com', 'TXT');
|
|
expect(dmarcHandler).toBeTruthy();
|
|
const dmarcRecord = dmarcHandler();
|
|
expect(dmarcRecord.type).toEqual('TXT');
|
|
expect(dmarcRecord.data).toContain('v=DMARC1');
|
|
expect(dmarcRecord.data).toContain('p=none');
|
|
|
|
// Verify records were stored in StorageManager
|
|
const mxStored = await mockRouter.storageManager.getJSON('/email/dns/test.example.com/mx');
|
|
expect(mxStored).toBeTruthy();
|
|
expect(mxStored.priority).toEqual(15);
|
|
|
|
const spfStored = await mockRouter.storageManager.getJSON('/email/dns/test.example.com/spf');
|
|
expect(spfStored).toBeTruthy();
|
|
expect(spfStored.data).toEqual('v=spf1 a mx ~all');
|
|
|
|
// Clean up
|
|
await plugins.fs.promises.rm(testDir, { recursive: true, force: true }).catch(() => {});
|
|
});
|
|
|
|
tap.test('DnsManager - Create DKIM Records', async () => {
|
|
const testDir = plugins.path.join(paths.dataDir, '.test-dns-manager-dkim');
|
|
const keysDir = plugins.path.join(testDir, 'keys');
|
|
await plugins.fs.promises.mkdir(keysDir, { recursive: true });
|
|
|
|
const mockRouter = new MockDcRouter(testDir, 'ns.test.com') as any;
|
|
const dnsManager = new DnsManager(mockRouter);
|
|
const dkimCreator = new DKIMCreator(keysDir, mockRouter.storageManager);
|
|
|
|
const domainConfigs: IEmailDomainConfig[] = [
|
|
{
|
|
domain: 'dkim.example.com',
|
|
dnsMode: 'internal-dns',
|
|
dkim: {
|
|
selector: 'mail2024',
|
|
keySize: 2048
|
|
}
|
|
}
|
|
];
|
|
|
|
// Generate DKIM keys first
|
|
await dkimCreator.handleDKIMKeysForDomain('dkim.example.com');
|
|
|
|
// Create DNS records including DKIM
|
|
await dnsManager.ensureDnsRecords(domainConfigs, dkimCreator);
|
|
|
|
// Verify DKIM record was registered
|
|
const dkimHandler = mockRouter.getDnsHandler('mail2024._domainkey.dkim.example.com', 'TXT');
|
|
expect(dkimHandler).toBeTruthy();
|
|
const dkimRecord = dkimHandler();
|
|
expect(dkimRecord.type).toEqual('TXT');
|
|
expect(dkimRecord.data).toContain('v=DKIM1');
|
|
expect(dkimRecord.data).toContain('k=rsa');
|
|
expect(dkimRecord.data).toContain('p=');
|
|
|
|
// Verify DKIM record was stored
|
|
const dkimStored = await mockRouter.storageManager.getJSON('/email/dns/dkim.example.com/dkim');
|
|
expect(dkimStored).toBeTruthy();
|
|
expect(dkimStored.name).toEqual('mail2024._domainkey.dkim.example.com');
|
|
|
|
// Clean up
|
|
await plugins.fs.promises.rm(testDir, { recursive: true, force: true }).catch(() => {});
|
|
});
|
|
|
|
export default tap.start(); |