System.IO.Abstractions 19.2.1

System.IO.Abstractions NuGet Continuous Integration Codacy Badge Renovate enabled FOSSA Status

At the core of the library is IFileSystem and FileSystem. Instead of calling methods like File.ReadAllText directly, use IFileSystem.File.ReadAllText. We have exactly the same API, except that ours is injectable and testable.

Usage

dotnet add package TestableIO.System.IO.Abstractions

Note: This NuGet package is also published as System.IO.Abstractions but we suggest to use the prefix to make clear that this is not an official .NET package.

public class MyComponent
{
    readonly IFileSystem fileSystem;

    // <summary>Create MyComponent with the given fileSystem implementation</summary>
    public MyComponent(IFileSystem fileSystem)
    {
        this.fileSystem = fileSystem;
    }
    /// <summary>Create MyComponent</summary>
    public MyComponent() : this(
        fileSystem: new FileSystem() //use default implementation which calls System.IO
    )
    {
    }

    public void Validate()
    {
        foreach (var textFile in fileSystem.Directory.GetFiles(@"c:\", "*.txt", SearchOption.TopDirectoryOnly))
        {
            var text = fileSystem.File.ReadAllText(textFile);
            if (text != "Testing is awesome.")
                throw new NotSupportedException("We can't go on together. It's not me, it's you.");
        }
    }
}

Test helpers

The library also ships with a series of test helpers to save you from having to mock out every call, for basic scenarios. They are not a complete copy of a real-life file system, but they'll get you most of the way there.

dotnet add package TestableIO.System.IO.Abstractions.TestingHelpers

Note: This NuGet package is also published as System.IO.Abstractions.TestingHelpers but we suggest to use the prefix to make clear that this is not an official .NET package.

[Test]
public void MyComponent_Validate_ShouldThrowNotSupportedExceptionIfTestingIsNotAwesome()
{
    // Arrange
    var fileSystem = new MockFileSystem(new Dictionary<string, MockFileData>
    {
        { @"c:\myfile.txt", new MockFileData("Testing is meh.") },
        { @"c:\demo\jQuery.js", new MockFileData("some js") },
        { @"c:\demo\image.gif", new MockFileData(new byte[] { 0x12, 0x34, 0x56, 0xd2 }) }
    });
    var component = new MyComponent(fileSystem);

    try
    {
        // Act
        component.Validate();
    }
    catch (NotSupportedException ex)
    {
        // Assert
        Assert.AreEqual("We can't go on together. It's not me, it's you.", ex.Message);
        return;
    }

    Assert.Fail("The expected exception was not thrown.");
}

We even support casting from the .NET Framework's untestable types to our testable wrappers:

FileInfo SomeApiMethodThatReturnsFileInfo()
{
    return new FileInfo("a");
}

void MyFancyMethod()
{
    var testableFileInfo = (FileInfoBase)SomeApiMethodThatReturnsFileInfo();
    ...
}

Mock support

Since version 4.0 the top-level APIs expose interfaces instead of abstract base classes (these still exist, though), allowing you to completely mock the file system. Here's a small example, using Moq:

[Test]
public void Test1()
{
    var watcher = Mock.Of<IFileSystemWatcher>();
    var file = Mock.Of<IFile>();

    Mock.Get(file).Setup(f => f.Exists(It.IsAny<string>())).Returns(true);
    Mock.Get(file).Setup(f => f.ReadAllText(It.IsAny<string>())).Throws<OutOfMemoryException>();

    var unitUnderTest = new SomeClassUsingFileSystemWatcher(watcher, file);

    Assert.Throws<OutOfMemoryException>(() => {
        Mock.Get(watcher).Raise(w => w.Created += null, new System.IO.FileSystemEventArgs(System.IO.WatcherChangeTypes.Created, @"C:\Some\Directory", "Some.File"));
    });

    Mock.Get(file).Verify(f => f.Exists(It.IsAny<string>()), Times.Once);

    Assert.True(unitUnderTest.FileWasCreated);
}

public class SomeClassUsingFileSystemWatcher
{
    private readonly IFileSystemWatcher _watcher;
    private readonly IFile _file;

    public bool FileWasCreated { get; private set; }

    public SomeClassUsingFileSystemWatcher(IFileSystemWatcher watcher, IFile file)
    {
        this._file = file;
        this._watcher = watcher;
        this._watcher.Created += Watcher_Created;
    }

    private void Watcher_Created(object sender, System.IO.FileSystemEventArgs e)
    {
        FileWasCreated = true;

        if(_file.Exists(e.FullPath))
        {
            var text = _file.ReadAllText(e.FullPath);
        }
    }
}

Showing the top 20 packages that depend on System.IO.Abstractions.

Packages Downloads
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
43
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
36
System.IO.Abstractions.TestingHelpers
A set of pre-built mocks to help when testing file system interactions.
34
System.IO.Abstractions.TestingHelpers
A set of pre-built mocks to help when testing file system interactions.
33
System.IO.Abstractions.TestingHelpers
A set of pre-built mocks to help when testing file system interactions.
32
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
32
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
31
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
29
System.IO.Abstractions.TestingHelpers
A set of pre-built mocks to help when testing file system interactions.
29
Glob.cs
File system path globbing library (wildcards like in bash).
29
KubernetesClient
Client library for the Kubernetes open source container orchestrator.
28
System.IO.Abstractions.TestingHelpers
A set of pre-built mocks to help when testing file system interactions.
28

Version Downloads Last updated
22.1.1 16 04/13/2026
22.1.0 17 12/21/2025
22.0.16 21 12/12/2025
22.0.16-pre.2 16 12/12/2025
22.0.16-pre.1 19 12/12/2025
22.0.15 18 12/12/2025
22.0.14 15 12/13/2025
22.0.13 17 12/20/2025
22.0.12 17 12/11/2025
22.0.11 19 12/10/2025
22.0.10 18 12/20/2025
22.0.10-beta.1 20 12/13/2025
22.0.9 18 12/11/2025
21.3.1 17 12/20/2025
21.2.12 21 12/20/2025
21.2.8 20 12/10/2025
21.2.1 17 12/13/2025
21.1.7 17 12/20/2025
21.1.3 21 12/13/2025
21.1.2 17 12/20/2025
21.1.1 20 12/13/2025
21.0.29 19 12/13/2025
21.0.26 22 12/16/2025
21.0.22 15 12/09/2025
21.0.2 15 12/20/2025
20.0.34 18 12/10/2025
20.0.28 17 12/13/2025
20.0.15 17 12/10/2025
20.0.4 12 12/13/2025
20.0.1 19 12/10/2025
19.2.91 22 12/13/2025
19.2.87 19 12/13/2025
19.2.69 18 12/14/2025
19.2.67 13 12/14/2025
19.2.66 18 12/20/2025
19.2.64 21 12/13/2025
19.2.63 17 12/20/2025
19.2.61 16 12/14/2025
19.2.51 22 12/15/2025
19.2.50 19 12/11/2025
19.2.29 25 12/13/2025
19.2.26 15 12/11/2025
19.2.25 18 12/14/2025
19.2.22 16 12/13/2025
19.2.18 17 12/13/2025
19.2.17 20 12/13/2025
19.2.16 19 12/09/2025
19.2.15 16 12/13/2025
19.2.13 14 12/20/2025
19.2.12 15 12/13/2025
19.2.11 18 12/18/2025
19.2.9 18 12/20/2025
19.2.8 18 12/09/2025
19.2.4 19 12/13/2025
19.2.1 19 12/12/2025
19.1.18 19 12/13/2025
19.1.14 14 12/16/2025
19.1.13 17 12/13/2025
19.1.5 18 12/09/2025
19.1.1 19 12/13/2025
19.0.1 14 12/11/2025
18.0.1 19 12/13/2025
17.2.26 17 12/15/2025
17.2.3 21 12/13/2025
17.2.1 19 12/09/2025
17.1.1 18 12/13/2025
17.0.28 24 12/09/2025
17.0.24 22 12/10/2025
17.0.23 15 12/11/2025
17.0.21 24 12/13/2025
17.0.18 18 12/16/2025
17.0.15 17 12/11/2025
17.0.14 24 12/13/2025
17.0.13 19 12/09/2025
17.0.12 20 12/15/2025
17.0.11 23 12/09/2025
17.0.10 20 12/13/2025
17.0.9 19 12/15/2025
17.0.8 19 12/20/2025
17.0.7 19 12/15/2025
17.0.6 14 12/17/2025
17.0.5 19 12/20/2025
17.0.4 16 12/20/2025
17.0.3 21 12/17/2025
17.0.2 18 12/20/2025
17.0.1 12 12/13/2025
16.1.26 18 12/13/2025
16.1.25 19 12/13/2025
16.1.24 18 12/09/2025
16.1.23 17 12/20/2025
16.1.22 17 12/13/2025
16.1.21 22 12/09/2025
16.1.20 22 12/09/2025
16.1.19 19 12/15/2025
16.1.18 23 12/11/2025
16.1.17 18 12/15/2025
16.1.16 17 12/15/2025
16.1.15 18 12/13/2025
16.1.14 19 12/10/2025
16.1.13 21 12/13/2025
16.1.12 13 12/13/2025
16.1.11 17 12/16/2025
16.1.10 27 12/10/2025
16.1.9 18 12/15/2025
16.1.8 20 12/09/2025
16.1.7 19 12/13/2025
16.1.6 13 12/13/2025
16.1.5 17 12/20/2025
16.1.4 18 12/15/2025
16.1.2 16 12/20/2025
16.1.1 19 12/13/2025
16.0.8 15 12/20/2025
16.0.7 18 12/13/2025
16.0.6 17 12/13/2025
16.0.5 19 12/15/2025
16.0.4 14 12/13/2025
16.0.3 17 12/11/2025
16.0.2 17 12/13/2025
16.0.1 19 01/01/2026
15.0.1 20 01/02/2026
14.0.13 21 12/10/2025
14.0.12 18 12/20/2025
14.0.11 18 12/20/2025
14.0.10 21 12/09/2025
14.0.9 21 12/09/2025
14.0.8 19 12/10/2025
14.0.7 17 12/17/2025
14.0.6 16 12/10/2025
14.0.5 22 12/11/2025
14.0.4 18 12/13/2025
14.0.3 19 12/09/2025
14.0.2 24 12/09/2025
14.0.1 14 12/13/2025
13.2.47 19 12/13/2025
13.2.46 17 12/16/2025
13.2.45 21 12/11/2025
13.2.43 17 12/16/2025
13.2.42 14 12/20/2025
13.2.41 15 12/18/2025
13.2.40 18 12/09/2025
13.2.39 19 12/20/2025
13.2.38 17 12/20/2025
13.2.37 17 12/20/2025
13.2.36 22 12/13/2025
13.2.35 20 12/10/2025
13.2.34 18 12/17/2025
13.2.33 21 12/09/2025
13.2.32 16 12/15/2025
13.2.31 17 12/13/2025
13.2.30 17 12/20/2025
13.2.29 17 12/09/2025
13.2.28 22 12/10/2025
13.2.27 17 12/18/2025
13.2.25 18 12/10/2025
13.2.24 16 12/17/2025
13.2.23 16 12/20/2025
13.2.22 17 12/09/2025
13.2.20 17 12/20/2025
13.2.19 18 12/17/2025
13.2.18 21 12/17/2025
13.2.17 17 12/20/2025
13.2.16 21 12/11/2025
13.2.15 17 12/20/2025
13.2.14 15 12/11/2025
13.2.13 18 12/20/2025
13.2.12 19 12/10/2025
13.2.11 20 12/16/2025
13.2.10 17 12/15/2025
13.2.9 16 12/20/2025
13.2.8 18 12/20/2025
13.2.7 20 12/15/2025
13.2.6 14 12/20/2025
13.2.5 17 12/15/2025
13.2.4 17 12/13/2025
13.2.3 20 12/09/2025
13.2.2 15 12/16/2025
13.2.1 15 12/16/2025
13.1.2 17 12/20/2025
13.1.1 16 12/16/2025
13.0.1 18 12/10/2025
12.2.27 19 12/20/2025
12.2.26 15 12/20/2025
12.2.25 15 12/20/2025
12.2.24 18 12/13/2025
12.2.23 19 12/09/2025
12.2.22 21 12/09/2025
12.2.21 15 12/15/2025
12.2.20 18 12/15/2025
12.2.19 20 12/13/2025
12.2.7 19 12/15/2025
12.2.6 12 12/20/2025
12.2.5 14 12/20/2025
12.2.4 16 12/21/2025
12.2.3 17 12/10/2025
12.2.2 17 12/21/2025
12.2.1 19 12/26/2025
12.1.11 20 12/09/2025
12.1.10 18 12/15/2025
12.1.9 17 12/20/2025
12.1.2 19 12/19/2025
12.1.1 17 12/22/2025
12.0.13 19 12/10/2025
12.0.10 14 12/10/2025
12.0.9 15 12/20/2025
12.0.8 18 12/20/2025
12.0.7 16 12/31/2025
12.0.6 24 12/11/2025
12.0.5 15 12/20/2025
12.0.4 17 12/13/2025
12.0.3 19 12/13/2025
12.0.2 18 12/15/2025
12.0.1 21 12/13/2025
11.0.18 18 12/16/2025
11.0.17 16 12/20/2025
11.0.16 17 12/10/2025
11.0.15 15 12/20/2025
11.0.14 21 12/13/2025
11.0.13 18 12/20/2025
11.0.12 15 12/15/2025
11.0.11 16 12/14/2025
11.0.10 17 12/20/2025
11.0.9 20 12/13/2025
11.0.8 19 12/13/2025
11.0.7 16 12/20/2025
11.0.6 16 01/02/2026
11.0.5 24 12/13/2025
11.0.4 17 12/12/2025
11.0.3 19 12/13/2025
11.0.2 14 12/20/2025
11.0.1 16 12/10/2025
10.0.10 22 12/09/2025
10.0.9 17 12/13/2025
10.0.8 19 12/13/2025
10.0.7 15 12/20/2025
10.0.6 18 12/13/2025
10.0.5 19 12/10/2025
10.0.4 17 12/16/2025
10.0.1 18 12/10/2025
9.0.6 17 12/16/2025
9.0.5 24 12/13/2025
9.0.4 16 12/15/2025
9.0.3 16 12/09/2025
9.0.2 20 12/15/2025
9.0.1 17 12/23/2025
8.1.1 14 01/01/2026
8.0.6 16 12/09/2025
8.0.5 15 12/13/2025
8.0.4 15 12/16/2025
8.0.3 19 12/15/2025
7.1.10 20 12/15/2025
7.1.8 19 01/01/2026
7.1.4 18 12/15/2025
7.1.3 17 12/15/2025
7.1.1 15 12/09/2025
7.0.16 19 12/13/2025
7.0.15 13 12/20/2025
7.0.7 17 12/15/2025
7.0.5 16 12/15/2025
7.0.4 20 12/13/2025
6.0.38 17 12/09/2025
6.0.36 14 12/20/2025
6.0.34 20 12/09/2025
6.0.32 10 01/01/2026
6.0.27 17 12/13/2025
6.0.25 19 12/09/2025
6.0.23 15 12/13/2025
6.0.21 18 12/24/2025
6.0.19 16 12/10/2025
6.0.17 18 12/17/2025
6.0.15 16 12/20/2025
6.0.14 18 12/15/2025
6.0.13 20 12/11/2025
6.0.11 14 12/20/2025
6.0.9 14 01/01/2026
6.0.7 15 12/15/2025
6.0.6 16 12/25/2025
6.0.5 15 12/13/2025
6.0.3 14 01/02/2026
6.0.1 15 01/02/2026
5.0.1 16 12/20/2025
4.2.17 20 12/17/2025
4.2.15 12 12/17/2025
4.2.13 15 12/10/2025
4.2.12 17 12/14/2025
4.2.10 18 12/09/2025
4.2.9 16 12/15/2025
4.2.8 15 12/15/2025
4.2.4 15 12/15/2025
4.1.6 18 12/13/2025
4.0.11 18 12/09/2025
3.1.1 16 12/16/2025
3.0.10 19 12/13/2025
3.0.2 14 01/01/2026
2.2.18-beta 26 12/20/2025
2.2.17-beta 20 12/10/2025
2.2.16-beta 15 12/20/2025
2.2.15-beta 16 12/09/2025
2.2.14-beta 18 12/20/2025
2.2.13-beta 18 12/20/2025
2.2.12-beta 16 12/20/2025
2.2.11-beta 17 12/20/2025
2.2.10-beta 16 12/20/2025
2.2.9-beta 14 12/15/2025
2.2.8-beta 17 12/13/2025
2.2.7-beta 20 12/10/2025
2.2.6-beta 14 01/01/2026
2.2.5-beta 20 12/21/2025
2.2.4-beta 16 12/13/2025
2.2.3-beta 20 12/29/2025
2.2.2-beta 13 01/02/2026
2.1.0.256 19 12/20/2025
2.1.0.247 15 12/20/2025
2.1.0.237 18 12/15/2025
2.1.0.236 19 12/18/2025
2.1.0.235 17 12/20/2025
2.1.0.234 14 12/15/2025
2.1.0.233 13 12/09/2025
2.1.0.232 17 12/20/2025
2.1.0.231 16 12/09/2025
2.1.0.230 18 12/20/2025
2.1.0.229 16 12/15/2025
2.1.0.228 16 12/15/2025
2.1.0.227 18 12/20/2025
2.1.0.226 18 12/19/2025
2.1.0.217 13 12/13/2025
2.1.0.216 14 12/12/2025
2.1.0.215 16 12/11/2025
2.1.0.214 16 12/13/2025
2.1.0.213 15 12/15/2025
2.1.0.211 18 12/20/2025
2.1.0.210 20 12/20/2025
2.1.0.209 13 12/15/2025
2.1.0.208 19 12/13/2025
2.1.0.207 14 12/13/2025
2.1.0.206 13 12/20/2025
2.1.0.205 16 12/15/2025
2.1.0.204 18 12/20/2025
2.1.0.203 13 12/13/2025
2.1.0.202 16 12/20/2025
2.1.0.201 20 12/20/2025
2.1.0.200 18 12/13/2025
2.1.0.199 12 12/20/2025
2.1.0.198 15 12/20/2025
2.1.0.197 17 12/20/2025
2.1.0.196 15 12/20/2025
2.1.0.195 19 12/14/2025
2.1.0.194 15 12/09/2025
2.1.0.193 15 12/15/2025
2.1.0.192 20 12/13/2025
2.1.0.191 16 12/20/2025
2.1.0.190 16 12/11/2025
2.1.0.189 19 12/09/2025
2.1.0.188 15 12/20/2025
2.1.0.187 19 12/10/2025
2.1.0.186 15 12/20/2025
2.1.0.185 14 12/13/2025
2.1.0.184 13 12/20/2025
2.1.0.183 15 12/20/2025
2.1.0.182 14 12/13/2025
2.1.0.181 13 12/16/2025
2.1.0.180 16 12/13/2025
2.1.0.179 16 12/20/2025
2.1.0.178 15 12/13/2025
2.1.0.177 20 12/13/2025
2.1.0.176 15 12/10/2025
2.1.0.175 14 12/20/2025
2.1.0.174 15 12/13/2025
2.1.0.173 19 12/12/2025
2.1.0.172 14 12/20/2025
2.1.0.171 16 12/20/2025
2.1.0.170 19 12/19/2025
2.1.0.169 19 12/20/2025
2.1.0.168 21 12/10/2025
2.1.0.166 13 12/20/2025
2.1.0.164 26 12/09/2025
2.1.0.163 14 12/15/2025
2.1.0.159 18 12/20/2025
2.0.0.144 15 12/20/2025
2.0.0.143 21 12/18/2025
2.0.0.142 13 12/13/2025
2.0.0.141 22 12/10/2025
2.0.0.140 19 12/13/2025
2.0.0.139 16 12/20/2025
2.0.0.138 23 12/13/2025
2.0.0.137 19 12/13/2025
2.0.0.136 14 12/13/2025
2.0.0.124 17 12/14/2025
2.0.0.123 16 12/09/2025
2.0.0.122 13 12/20/2025
2.0.0.121 19 12/09/2025
2.0.0.120 19 12/16/2025
2.0.0.119 19 12/16/2025
2.0.0.118 16 12/20/2025
2.0.0.117 15 12/20/2025
2.0.0.116 19 12/20/2025
2.0.0.115 15 12/11/2025
2.0.0.114 15 12/09/2025
2.0.0.113 20 12/20/2025
2.0.0.112 18 12/11/2025
2.0.0.111 19 12/09/2025
2.0.0.110 16 12/20/2025
2.0.0.109 18 12/13/2025
2.0.0.108 16 12/15/2025
2.0.0.107 16 12/14/2025
2.0.0.106 17 12/13/2025
2.0.0.105 16 12/13/2025
2.0.0.104 13 12/20/2025
2.0.0.103 15 12/20/2025
2.0.0.102 15 12/15/2025
2.0.0.101 16 12/10/2025
2.0.0.100 18 12/09/2025
2.0.0.99 15 12/13/2025
2.0.0.98 21 12/11/2025
1.4.0.93 15 12/13/2025
1.4.0.92 21 12/10/2025
1.4.0.89 17 12/20/2025
1.4.0.88 16 12/20/2025
1.4.0.87 15 12/20/2025
1.4.0.86 19 12/13/2025
1.4.0.85 19 12/15/2025
1.4.0.84 19 12/10/2025
1.4.0.83 16 12/13/2025
1.4.0.82 20 12/10/2025
1.4.0.81 16 12/13/2025
1.4.0.80 16 12/20/2025
1.4.0.79 15 12/15/2025
1.4.0.78 16 12/15/2025
1.4.0.77 18 12/15/2025
1.4.0.76 21 12/15/2025
1.4.0.75 15 12/20/2025
1.4.0.74 20 12/12/2025
1.4.0.73 18 12/13/2025
1.4.0.72 18 12/20/2025
1.4.0.71 18 12/13/2025
1.4.0.70 17 12/09/2025
1.4.0.69 18 12/15/2025
1.4.0.68 19 12/20/2025
1.4.0.67 18 12/15/2025
1.4.0.66 15 12/13/2025
1.4.0.65 13 12/20/2025
1.4.0.64 15 12/20/2025
1.4.0.63 17 12/13/2025
1.4.0.62 19 12/15/2025
1.4.0.61 17 12/20/2025
1.4.0.60 17 12/20/2025
1.4.0.59 15 12/20/2025
1.4.0.58 13 12/20/2025
1.4.0.57 21 12/13/2025
1.4.0.56 15 12/09/2025
1.4.0.55 21 12/16/2025
1.4.0.54 16 12/13/2025
1.4.0.53 24 12/20/2025
1.4.0.52 20 12/10/2025
1.4.0.51 18 12/13/2025
1.4.0.50 15 12/09/2025
1.4.0.49 16 12/16/2025
1.4.0.48 13 12/20/2025
1.4.0.47 19 12/15/2025
1.4.0.46 21 12/20/2025
1.4.0.45 18 01/01/2026
1.4.0.44 14 12/15/2025
1.4.0.43 14 12/21/2025
1.4.0.42 23 12/17/2025
1.4.0.41 17 12/13/2025
1.4.0.40 16 12/11/2025
1.4.0.39 15 12/13/2025
1.4.0.38 14 12/13/2025
1.4.0.37 15 12/13/2025
1.4.0.36 18 12/13/2025
1.4.0.35 16 12/20/2025
1.4.0.34 22 12/09/2025
1.4.0.33 18 12/18/2025
1.4.0.32 17 12/20/2025
1.4.0.31 15 12/20/2025
1.4.0.30 21 12/09/2025
1.4.0.29 15 12/09/2025
1.4.0.28 13 12/20/2025
1.4.0.27 13 12/11/2025
1.4.0.26 15 12/12/2025
1.4.0.25 18 12/13/2025
1.4.0.24 16 12/13/2025
1.4.0.23 18 12/20/2025
1.4.0.22 20 12/13/2025
1.4.0.21 14 12/20/2025
1.4.0.20 17 12/17/2025
1.4.0.19 17 12/15/2025
1.4.0.18 14 12/16/2025
1.4.0.17 17 12/17/2025
1.4.0.14 19 12/14/2025
1.4.0.13 16 12/20/2025
1.4.0.12 24 12/12/2025
1.4.0.11 21 12/17/2025
1.3.0 23 12/11/2025
1.2.0 13 12/16/2025