feat:优化了enhancedmultiFileRunner.ts的逻辑,使其能兼容其他功能

This commit is contained in:
fly6516 2025-02-25 11:29:14 +08:00
parent 7ea49fb495
commit 76eab0ff6c
2 changed files with 55 additions and 18 deletions

View File

@ -183,17 +183,11 @@ export const runMultiFileCodeWithOptionalTestData = async (params: {
return { error: `Execution failed with exit code ${exitCode.StatusCode}. Output: ${output}` };
}
// 如果指定了结果输出文件和正确答案文件,执行比较
if (resultOutputFile && expectedAnswerFiles && expectedAnswerFiles.length > 0) {
// 如果指定了结果输出文件,读取其内容
if (resultOutputFile) {
const resultFilePath = path.join(tempDir, resultOutputFile);
const comparisonResults = await Promise.all(expectedAnswerFiles.map(async (expectedFile) => {
const expectedFilePath = path.join(tempDir, testDataPath, expectedFile);
const isMatch = await compareResults(resultFilePath, expectedFilePath);
return { expectedFile, isMatch };
}));
return { output, comparisonResults };
const resultFileContent = await fs.readFile(resultFilePath, 'utf-8');
return { output, resultFileContent };
}
return { output };

View File

@ -1,19 +1,21 @@
'use client';
import React, { useState } from 'react';
import path from 'path';
import fs from 'fs';
import { runMultiFileCodeWithOptionalTestData } from '@/actions/enhancedmultiFileRunner';
const TestPage = () => {
const [code, setCode] = useState<string>('');
const [language, setLanguage] = useState<string>('c');
const [result, setResult] = useState<string>('');
const [consoleOutput, setConsoleOutput] = useState<string>('');
const [loading, setLoading] = useState<boolean>(false);
const [resultFileContent, setResultFileContent] = useState<string>('');
const handleRun = async () => {
setLoading(true);
setResult('');
setConsoleOutput('');
setResultFileContent('');
const testFiles = [
{ name: 'input1.txt', content: '1 2 3' },
@ -39,10 +41,21 @@ const TestPage = () => {
resultOutputFile: 'result.txt',
});
setResult(JSON.stringify(result, null, 2));
if (result.error) {
setConsoleOutput(result.error);
} else {
setConsoleOutput(result.output);
if (result.comparisonResults) {
setResult(JSON.stringify(result.comparisonResults, null, 2));
}
// 设置 result.txt 的内容
if (result.resultFileContent) {
setResultFileContent(result.resultFileContent);
}
}
} catch (error) {
// 使用类型断言确保 error 是 Error 类型
setResult(`Error: ${(error as Error).message}`);
setConsoleOutput(`Error: ${(error as Error).message}`);
} finally {
setLoading(false);
}
@ -90,6 +103,20 @@ const TestPage = () => {
>
{loading ? 'Running...' : 'Run Code'}
</button>
<div style={{ marginTop: '20px' }}>
<h2>Console Output</h2>
<pre
style={{
background: '#f4f4f4',
padding: '10px',
border: '1px solid #ddd',
borderRadius: '5px',
}}
>
{consoleOutput || 'No console output yet.'}
</pre>
</div>
{result && (
<div style={{ marginTop: '20px' }}>
<h2>Result</h2>
<pre
@ -103,6 +130,22 @@ const TestPage = () => {
{result || 'No results yet.'}
</pre>
</div>
)}
{resultFileContent && (
<div style={{ marginTop: '20px' }}>
<h2>Result File Content (result.txt)</h2>
<pre
style={{
background: '#f4f4f4',
padding: '10px',
border: '1px solid #ddd',
borderRadius: '5px',
}}
>
{resultFileContent || 'No result file content yet.'}
</pre>
</div>
)}
</div>
);
};