390 lines
14 KiB
JavaScript
390 lines
14 KiB
JavaScript
// ========================================
|
|
// TESTS GÉNÉRÉS AUTOMATIQUEMENT - DigitalOceanWorkflow
|
|
// Module: DigitalOceanWorkflow.js
|
|
// Générés le: 2025-09-08T23:48:02.377Z
|
|
// ========================================
|
|
|
|
const assert = require('assert');
|
|
const { test, describe } = require('node:test');
|
|
const DigitalOceanWorkflow = require('../../DigitalOceanWorkflow.js');
|
|
const { AIContentValidator } = require('../validators/AIContentValidator');
|
|
|
|
describe('DigitalOceanWorkflow - Tests automatiques', () => {
|
|
|
|
// Setup avant les tests
|
|
let testContext = {};
|
|
|
|
test('Module loading', () => {
|
|
assert.ok(DigitalOceanWorkflow, 'Module should be loaded');
|
|
console.log('📦 Module DigitalOceanWorkflow loaded successfully');
|
|
});
|
|
|
|
|
|
test('deployArticle - Async Operation', async () => {
|
|
const input = ["test_value", "test_value", "test_value", "test_value"];
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.deployArticle(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ deployArticle: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ deployArticle: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('triggerAutonomousWorkflow - Async Operation', async () => {
|
|
const input = "test_value";
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.triggerAutonomousWorkflow(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ triggerAutonomousWorkflow: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ triggerAutonomousWorkflow: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('runAutonomousWorkflowFromTrigger - Async Operation', async () => {
|
|
const input = "test_value";
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.runAutonomousWorkflowFromTrigger(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ runAutonomousWorkflowFromTrigger: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ runAutonomousWorkflowFromTrigger: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('fetchXMLFromDigitalOceanSimple - Async Operation', async () => {
|
|
const input = "test_value";
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.fetchXMLFromDigitalOceanSimple(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ fetchXMLFromDigitalOceanSimple: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ fetchXMLFromDigitalOceanSimple: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('fetchXMLFromDigitalOcean - Async Operation', async () => {
|
|
const input = "test_value";
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.fetchXMLFromDigitalOcean(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ fetchXMLFromDigitalOcean: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ fetchXMLFromDigitalOcean: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('readCSVDataWithXMLFileName - Async Operation', async () => {
|
|
const input = "test_value";
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.readCSVDataWithXMLFileName(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ readCSVDataWithXMLFileName: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ readCSVDataWithXMLFileName: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('markRowAsProcessed - Async Operation', async () => {
|
|
const input = ["test_value", "test_value"];
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.markRowAsProcessed(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ markRowAsProcessed: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ markRowAsProcessed: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('markRowAsError - Async Operation', async () => {
|
|
const input = ["test_value", "test_value"];
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.markRowAsError(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ markRowAsError: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ markRowAsError: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('testDigitalOceanConnection - Async Operation', async () => {
|
|
const input = undefined;
|
|
|
|
try {
|
|
const startTime = Date.now();
|
|
const result = await DigitalOceanWorkflow.testDigitalOceanConnection(input);
|
|
const duration = Date.now() - startTime;
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(duration < 30000, 'Should complete within 30 seconds');
|
|
|
|
console.log(`✅ testDigitalOceanConnection: Completed in ${duration}ms`);
|
|
|
|
} catch (error) {
|
|
console.error('❌ testDigitalOceanConnection: Async operation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('shouldTriggerWorkflow - Basic Function', () => {
|
|
const input = ["test_value", "test_value"];
|
|
|
|
try {
|
|
const result = DigitalOceanWorkflow.shouldTriggerWorkflow(input);
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(typeof result !== 'undefined', 'Result should be defined');
|
|
|
|
console.log('✅ shouldTriggerWorkflow: Function executed successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ shouldTriggerWorkflow: Function failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('generateAWSSignature - Content Generation', async () => {
|
|
const mockInput = "test_value";
|
|
|
|
try {
|
|
const result = await DigitalOceanWorkflow.generateAWSSignature(mockInput);
|
|
|
|
// Validations de base
|
|
assert.ok(result, 'Should return a result');
|
|
assert.ok(typeof result === 'string' || typeof result === 'object', 'Should return content');
|
|
|
|
// Validation IA si contenu texte
|
|
if (typeof result === 'string' && result.length > 50) {
|
|
const validation = await AIContentValidator.quickValidate(result, {
|
|
context: 'Generated content test'
|
|
});
|
|
assert.ok(validation.overall >= 40, 'Content quality should be acceptable');
|
|
}
|
|
|
|
console.log('✅ generateAWSSignature: Content generated successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ generateAWSSignature: Generation failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('setupAutonomousTrigger - Basic Function', () => {
|
|
const input = undefined;
|
|
|
|
try {
|
|
const result = DigitalOceanWorkflow.setupAutonomousTrigger(input);
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(typeof result !== 'undefined', 'Result should be defined');
|
|
|
|
console.log('✅ setupAutonomousTrigger: Function executed successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ setupAutonomousTrigger: Function failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('if - Basic Function', () => {
|
|
const input = undefined;
|
|
|
|
try {
|
|
const result = DigitalOceanWorkflow.if(input);
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(typeof result !== 'undefined', 'Result should be defined');
|
|
|
|
console.log('✅ if: Function executed successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ if: Function failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('catch - Basic Function', () => {
|
|
const input = undefined;
|
|
|
|
try {
|
|
const result = DigitalOceanWorkflow.catch(input);
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(typeof result !== 'undefined', 'Result should be defined');
|
|
|
|
console.log('✅ catch: Function executed successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ catch: Function failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('for - Basic Function', () => {
|
|
const input = undefined;
|
|
|
|
try {
|
|
const result = DigitalOceanWorkflow.for(input);
|
|
|
|
// Validations de base
|
|
assert.ok(result !== undefined, 'Should return a result');
|
|
assert.ok(typeof result !== 'undefined', 'Result should be defined');
|
|
|
|
console.log('✅ for: Function executed successfully');
|
|
|
|
} catch (error) {
|
|
console.error('❌ for: Function failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
|
|
test('Export - triggerAutonomousWorkflow', () => {
|
|
assert.ok(DigitalOceanWorkflow.triggerAutonomousWorkflow !== undefined, 'Export triggerAutonomousWorkflow should be available');
|
|
console.log('✅ Export triggerAutonomousWorkflow: Available');
|
|
});
|
|
|
|
test('Export - runAutonomousWorkflowFromTrigger', () => {
|
|
assert.ok(DigitalOceanWorkflow.runAutonomousWorkflowFromTrigger !== undefined, 'Export runAutonomousWorkflowFromTrigger should be available');
|
|
console.log('✅ Export runAutonomousWorkflowFromTrigger: Available');
|
|
});
|
|
|
|
test('Export - fetchXMLFromDigitalOcean', () => {
|
|
assert.ok(DigitalOceanWorkflow.fetchXMLFromDigitalOcean !== undefined, 'Export fetchXMLFromDigitalOcean should be available');
|
|
console.log('✅ Export fetchXMLFromDigitalOcean: Available');
|
|
});
|
|
|
|
test('Export - fetchXMLFromDigitalOceanSimple', () => {
|
|
assert.ok(DigitalOceanWorkflow.fetchXMLFromDigitalOceanSimple !== undefined, 'Export fetchXMLFromDigitalOceanSimple should be available');
|
|
console.log('✅ Export fetchXMLFromDigitalOceanSimple: Available');
|
|
});
|
|
|
|
test('Export - readCSVDataWithXMLFileName', () => {
|
|
assert.ok(DigitalOceanWorkflow.readCSVDataWithXMLFileName !== undefined, 'Export readCSVDataWithXMLFileName should be available');
|
|
console.log('✅ Export readCSVDataWithXMLFileName: Available');
|
|
});
|
|
|
|
test('Export - markRowAsProcessed', () => {
|
|
assert.ok(DigitalOceanWorkflow.markRowAsProcessed !== undefined, 'Export markRowAsProcessed should be available');
|
|
console.log('✅ Export markRowAsProcessed: Available');
|
|
});
|
|
|
|
test('Export - markRowAsError', () => {
|
|
assert.ok(DigitalOceanWorkflow.markRowAsError !== undefined, 'Export markRowAsError should be available');
|
|
console.log('✅ Export markRowAsError: Available');
|
|
});
|
|
|
|
test('Export - testDigitalOceanConnection', () => {
|
|
assert.ok(DigitalOceanWorkflow.testDigitalOceanConnection !== undefined, 'Export testDigitalOceanConnection should be available');
|
|
console.log('✅ Export testDigitalOceanConnection: Available');
|
|
});
|
|
|
|
test('Export - setupAutonomousTrigger', () => {
|
|
assert.ok(DigitalOceanWorkflow.setupAutonomousTrigger !== undefined, 'Export setupAutonomousTrigger should be available');
|
|
console.log('✅ Export setupAutonomousTrigger: Available');
|
|
});
|
|
|
|
test('Export - DO_CONFIG', () => {
|
|
assert.ok(DigitalOceanWorkflow.DO_CONFIG !== undefined, 'Export DO_CONFIG should be available');
|
|
console.log('✅ Export DO_CONFIG: Available');
|
|
});
|
|
|
|
test('Export - deployArticle', () => {
|
|
assert.ok(DigitalOceanWorkflow.deployArticle !== undefined, 'Export deployArticle should be available');
|
|
console.log('✅ Export deployArticle: Available');
|
|
});
|
|
|
|
|
|
// Test d'intégration général
|
|
test('Integration - Module health check', async () => {
|
|
try {
|
|
// Vérification exports
|
|
const exports = Object.keys(DigitalOceanWorkflow);
|
|
assert.ok(exports.length > 0, 'Module should export functions');
|
|
|
|
console.log(`✅ DigitalOceanWorkflow: ${exports.length} exports available`);
|
|
console.log('📋 Exports:', exports.join(', '));
|
|
|
|
} catch (error) {
|
|
console.error('❌ Integration test failed:', error.message);
|
|
throw error;
|
|
}
|
|
});
|
|
}); |