9

If my unit tests rely on the file system and I need to mock this, what is the best way to go about this?

Thanks

Torbjørn
  • 6,423
  • 5
  • 29
  • 42
theDeveloper
  • 209
  • 2
  • 5
  • 1
    If you're actually talking about Typemock you shouldn't have an issue as Typemock can mock any type, including sealed types. –  Feb 15 '10 at 14:38
  • 5
    Chanting "your filesystem is worthless and weak" is a good way to mock them... – Steven A. Lowe Feb 15 '10 at 14:52
  • I thought thatTypemock couldn't mock things in mscorlib, which a lot of this is in. Except maybe DateTime.Now. Maybe. – Sam Holder Feb 15 '10 at 14:56
  • @Sam - You're correct. TypeMock cannot mock objects in mscrolib, but they did find a way to mock DateTime during the research into the Racer product. – Jason Evans Feb 15 '10 at 14:58

4 Answers4

9

The file system is an excellent example of how TDD can drive you towards a better, more flexible design. Often, when you interact with the file system, you can deal with reading and writing files using Streams or TextWriters instead of actual files.

These are all abstract types and so are easy to mock.

Now you have a more flexible API because it's not tightly coupled to the file system, but still supports file operations.

Mark Seemann
  • 225,310
  • 48
  • 427
  • 736
3

You basically have two options: eiter abstract all file-system related logic behind a IFileSystemService, or use Stubs from Microsoft, which is

...a lightweight framework for .NET that provides test stubs. For interfaces and non-sealed classes, type-safe wrappers are generated that can be easily customized by attaching delegates.

Anton Gogolev
  • 113,561
  • 39
  • 200
  • 288
1

This Needed: File system interfaces and implementation in .NET might be useful

Community
  • 1
  • 1
Sam Holder
  • 32,535
  • 13
  • 101
  • 181
1

Disclaimer I work at Typemock.

I'm glad to say, that our last versions support the following types of System.IO to be mocked:

  • File
  • Directory
  • FileStream

There is a short example:

public void Test()
{
    string path = @"C:\TypemockCan.txt";

    Isolate.WhenCalled(() => File.Exists(null)).WillReturn(true);

    Assert.IsTrue(File.Exists(path));
}

See more examples.

Eva
  • 449
  • 2
  • 8