5

ここに、次のような受け入れランナープログラムがあります。

public Result Run(CommandParser parser)
{
    var result = new Result();
    var watch = new Stopwatch();

    watch.Start();

    try
    {
        _testConsole.Start();

        parser.ForEachInput(input =>
        {
            _testConsole.StandardInput.WriteLine(input);
            return _testConsole.TotalProcessorTime.TotalSeconds < parser.TimeLimit;
        });

        if (TimeLimitExceeded(parser.TimeLimit))
        {
            watch.Stop();
            _testConsole.Kill();
            ReportThatTestTimedOut(result);
        }
        else
        {
            result.Status = GetProgramOutput() == parser.Expected ? ResultStatus.Passed : ResultStatus.Failed;
            watch.Stop();
        }
    }
    catch (Exception)
    {
        result.Status = ResultStatus.Exception;
    }

    result.Elapsed = watch.Elapsed;
    return result;
}

_testConsole は、通常の .net プロセスをより実行可能なプロセスにラップするプロセス アダプターです。ただし、開始されたプロセスから例外をキャッチするのに苦労しています(つまり、catch ステートメントはここでは無意味です)。次のようなものを使用しています。

_process = new Process
                           {
                               StartInfo =
                                   {
                                       FileName = pathToProcess,
                                       UseShellExecute = false,
                                       CreateNoWindow = true,
                                       RedirectStandardInput = true,
                                       RedirectStandardOutput = true,
                                       RedirectStandardError = true,
                                       Arguments = arguments
                                   }
                           };

プロセスを設定します。何か案は?

4

1 に答える 1

17

例外は、あるプロセスから別のプロセスに流れません。最善の方法は、プロセスの終了コードを監視することです。通常、終了コード 0 は成功を表し、その他の終了コードはエラーを表します。

もちろん、起動しているプロセスがそうであるかどうかは別の問題です。

于 2008-11-26T14:02:52.630 に答える