feat(UBL Encoder & Test Suite): Implement UBLEncoder and update corpus summary generation; adjust PDF timestamps in test outputs

This commit is contained in:
2025-04-04 13:28:27 +00:00
parent ef812f9230
commit cef11bcdf2
9 changed files with 574 additions and 217 deletions

View File

@ -9,22 +9,22 @@ tap.test('XInvoice should validate corpus files correctly', async () => {
const testDir = path.join(process.cwd(), 'test', 'assets');
// ZUGFeRD v2 correct files
const zugferdV2CorrectDir = path.join(testDir, 'zugferd', 'v2', 'correct');
const zugferdV2CorrectDir = path.join(testDir, 'corpus', 'ZUGFeRDv2', 'correct');
const zugferdV2CorrectFiles = await findFiles(zugferdV2CorrectDir, '.xml');
console.log(`Found ${zugferdV2CorrectFiles.length} ZUGFeRD v2 correct files for validation`);
// ZUGFeRD v2 fail files
const zugferdV2FailDir = path.join(testDir, 'zugferd', 'v2', 'fail');
const zugferdV2FailDir = path.join(testDir, 'corpus', 'ZUGFeRDv2', 'fail');
const zugferdV2FailFiles = await findFiles(zugferdV2FailDir, '.xml');
console.log(`Found ${zugferdV2FailFiles.length} ZUGFeRD v2 fail files for validation`);
// CII files
const ciiDir = path.join(testDir, 'cii');
const ciiDir = path.join(testDir, 'corpus', 'XML-Rechnung', 'CII');
const ciiFiles = await findFiles(ciiDir, '.xml');
console.log(`Found ${ciiFiles.length} CII files for validation`);
// UBL files
const ublDir = path.join(testDir, 'ubl');
const ublDir = path.join(testDir, 'corpus', 'XML-Rechnung', 'UBL');
const ublFiles = await findFiles(ublDir, '.xml');
console.log(`Found ${ublFiles.length} UBL files for validation`);
@ -47,12 +47,20 @@ tap.test('XInvoice should validate corpus files correctly', async () => {
// Calculate overall success rate for correct files
const totalCorrect = zugferdV2CorrectResults.success + ciiResults.success;
const totalCorrectFiles = zugferdV2CorrectFiles.length + ciiFiles.length;
const correctSuccessRate = totalCorrect / totalCorrectFiles;
console.log(`Overall success rate for correct files validation: ${(correctSuccessRate * 100).toFixed(2)}%`);
// Only calculate success rate if there are files to test
let correctSuccessRate = 0;
if (totalCorrectFiles > 0) {
correctSuccessRate = totalCorrect / totalCorrectFiles;
console.log(`Overall success rate for correct files validation: ${(correctSuccessRate * 100).toFixed(2)}%`);
// We should have a success rate of at least 65% for correct files
expect(correctSuccessRate).toBeGreaterThan(0.65);
// We should have a success rate of at least 65% for correct files
expect(correctSuccessRate).toBeGreaterThan(0.65);
} else {
console.log(`No files found for validation testing. This is a problem!`);
// Test should fail if no files are found - we expect to have files to test
expect(totalCorrectFiles).toBeGreaterThan(0);
}
});
/**