Предполагая интерфейс IReader, реализацию интерфейса IReader ReaderImplementation и класс ReaderConsumer, который потребляет и обрабатывает данные из считывателя.
public interface IReader
{
object Read()
}
Реализация
public class ReaderImplementation
{
...
public object Read()
{
...
}
}
Потребитель:
public class ReaderConsumer()
{
public string location
// constructor
public ReaderConsumer()
{
...
}
// read some data
public object ReadData()
{
IReader reader = new ReaderImplementation(this.location)
data = reader.Read()
...
return processedData
}
}
Для тестирования ReaderConsumer и обработки я использую макет IReader. Так ReaderConsumer становится:
public class ReaderConsumer()
{
private IReader reader = null
public string location
// constructor
public ReaderConsumer()
{
...
}
// mock constructor
public ReaderConsumer(IReader reader)
{
this.reader = reader
}
// read some data
public object ReadData()
{
try
{
if(this.reader == null)
{
this.reader = new ReaderImplementation(this.location)
}
data = reader.Read()
...
return processedData
}
finally
{
this.reader = null
}
}
}
В этом решении mocking вводит предложение if для производственного кода, поскольку только конструктор mocking предоставляет экземпляры интерфейса.
Во время написания этого я понимаю, что блок try-finally несколько не связан, так как он предназначен для того, чтобы обрабатывать изменение пользователем местоположения во время выполнения приложения.
В целом он чувствует себя вонючим, как с ним можно справиться лучше?
ReaderConsumer
независимостиReaderImplementation
?