[英]Testing Process.Start?
我正在创建一个管理外部实用程序的多个实例的应用程序,为每个实例提供数据并获取结果。
但是我在编写单元测试时遇到了问题。
如何测试目标方法在调用时是否真的启动了一个进程(通过属性设置)?
我努力了:
GetProcessesByName()
检查它是否已启动。我觉得创建另一个.exe
来测试它是矫枉过正的。
代码:
public void Start()
{
if (!_isRunning)
{
var startInfo = new ProcessStartInfo() {
CreateNoWindow = true,
UseShellExecute = true,
FileName = _cmdLine,
Arguments = _args
};
_process = Process.Start(startInfo);
_isRunning = true;
}
else
{
throw new InvalidOperationException("Process already started");
}
}
我想对其进行单元测试,以便在没有任何运行时启动一个新进程( _isRunning == false
)。
我会使用依赖注入并使用模拟或假类来解决这个问题。 注意我使用的是实例方法而不是类方法。 在您的常规代码中,您可以使用默认构造函数,它将为您创建一个进程。 对于测试,您可以注入一个模拟或假进程,并简单地检查在您的模拟对象上调用了正确的方法,并且根本不需要实际启动一个进程。 您需要调整它以考虑我省略的属性。 前任。 以下:
public class UtilityManager
{
public Process UtilityProcess { get; private set; }
private bool _isRunning;
public UtilityManager() : this(null) {}
public UtilityManager( Process process )
{
this. UtilityProcess = process ?? new Process();
this._isRunning = false;
}
public void Start()
{
if (!_isRunning) {
var startInfo = new ProcessStartInfo() {
CreateNoWindow = true,
UseShellExecute = true,
FileName = _cmdLine,
Arguments = _args
};
this.UtilityProcess.Start(startInfo);
_isRunning = true;
} else {
throw new InvalidOperationException("Process already started");
}
}
测试代码...
[TestMethod]
public void StartTest()
{
Process proc = new FakeProcess(); // May need to use a wrapper class
UtilityManager manager = new UtilityManager( proc );
manager.CommandLine = "command";
...
manager.Start();
Assert.IsTrue( proc.StartCalled );
Assert.IsNotNull( proc.StartInfo );
Assert.AreEqual( "command", proc.StartInfo.FileName );
...
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.