diff --git a/.pipelines/ESRPSigning_core.json b/.pipelines/ESRPSigning_core.json index b4ee89fcf06b..5319bdc55fd9 100644 --- a/.pipelines/ESRPSigning_core.json +++ b/.pipelines/ESRPSigning_core.json @@ -321,6 +321,10 @@ "WinUI3Apps\\ReverseMarkdown.dll", "WinUI3Apps\\SharpCompress.dll", "WinUI3Apps\\ZstdSharp.dll", + "TestableIO.System.IO.Abstractions.dll", + "WinUI3Apps\\TestableIO.System.IO.Abstractions.dll", + "TestableIO.System.IO.Abstractions.Wrappers.dll", + "WinUI3Apps\\TestableIO.System.IO.Abstractions.Wrappers.dll", "ColorCode.Core.dll", "ColorCode.UWP.dll", "UnitsNet.dll", diff --git a/Directory.Packages.props b/Directory.Packages.props index a103ca59a84d..db4de0da4de0 100644 --- a/Directory.Packages.props +++ b/Directory.Packages.props @@ -73,8 +73,8 @@ - - + + diff --git a/NOTICE.md b/NOTICE.md index 38c961a11619..ea5e811bb0f4 100644 --- a/NOTICE.md +++ b/NOTICE.md @@ -1354,8 +1354,8 @@ EXHIBIT A -Mozilla Public License. - System.Data.SqlClient 4.8.6 - System.Diagnostics.EventLog 8.0.1 - System.Drawing.Common 8.0.7 -- System.IO.Abstractions 17.2.3 -- System.IO.Abstractions.TestingHelpers 17.2.3 +- System.IO.Abstractions 21.0.29 +- System.IO.Abstractions.TestingHelpers 21.0.29 - System.Management 8.0.0 - System.Reactive 6.0.1 - System.Runtime.Caching 8.0.1 diff --git a/src/common/ManagedCommon/LanguageHelper.cs b/src/common/ManagedCommon/LanguageHelper.cs index 90791a03bc5f..85cdcd1c335e 100644 --- a/src/common/ManagedCommon/LanguageHelper.cs +++ b/src/common/ManagedCommon/LanguageHelper.cs @@ -4,7 +4,6 @@ using System; using System.IO; -using System.IO.Abstractions; using System.Text.Json; using System.Text.Json.Serialization; @@ -23,15 +22,14 @@ internal sealed class OutGoingLanguageSettings public static string LoadLanguage() { - FileSystem fileSystem = new FileSystem(); var localAppDataDir = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData); var file = localAppDataDir + SettingsFilePath + SettingsFile; - if (fileSystem.File.Exists(file)) + if (File.Exists(file)) { try { - Stream inputStream = fileSystem.File.Open(file, FileMode.Open); + var inputStream = File.Open(file, FileMode.Open); StreamReader reader = new StreamReader(inputStream); string data = reader.ReadToEnd(); inputStream.Close(); diff --git a/src/common/ManagedCommon/Logger.cs b/src/common/ManagedCommon/Logger.cs index bbc2637fd956..367480d293a2 100644 --- a/src/common/ManagedCommon/Logger.cs +++ b/src/common/ManagedCommon/Logger.cs @@ -5,7 +5,7 @@ using System; using System.Diagnostics; using System.Globalization; -using System.IO.Abstractions; +using System.IO; using System.Reflection; using PowerToys.Interop; @@ -14,7 +14,6 @@ namespace ManagedCommon { public static class Logger { - private static readonly IFileSystem _fileSystem = new FileSystem(); private static readonly Assembly Assembly = Assembly.GetExecutingAssembly(); private static readonly string Version = FileVersionInfo.GetVersionInfo(Assembly.Location).ProductVersion; @@ -41,12 +40,12 @@ public static void InitializeLogger(string applicationLogPath, bool isLocalLow = applicationLogPath = Constants.AppDataPath() + applicationLogPath + "\\" + Version; } - if (!_fileSystem.Directory.Exists(applicationLogPath)) + if (!Directory.Exists(applicationLogPath)) { - _fileSystem.Directory.CreateDirectory(applicationLogPath); + Directory.CreateDirectory(applicationLogPath); } - var logFilePath = _fileSystem.Path.Combine(applicationLogPath, "Log_" + DateTime.Now.ToString(@"yyyy-MM-dd", CultureInfo.InvariantCulture) + ".txt"); + var logFilePath = Path.Combine(applicationLogPath, "Log_" + DateTime.Now.ToString(@"yyyy-MM-dd", CultureInfo.InvariantCulture) + ".txt"); Trace.Listeners.Add(new TextWriterTraceListener(logFilePath)); diff --git a/src/common/ManagedCommon/ManagedCommon.csproj b/src/common/ManagedCommon/ManagedCommon.csproj index 164df854eb0b..f3b149616c4c 100644 --- a/src/common/ManagedCommon/ManagedCommon.csproj +++ b/src/common/ManagedCommon/ManagedCommon.csproj @@ -15,7 +15,6 @@ - diff --git a/src/modules/Hosts/Hosts.Tests/HostsServiceTest.cs b/src/modules/Hosts/Hosts.Tests/HostsServiceTest.cs index b57fbf42ed0f..8eaa37a34811 100644 --- a/src/modules/Hosts/Hosts.Tests/HostsServiceTest.cs +++ b/src/modules/Hosts/Hosts.Tests/HostsServiceTest.cs @@ -276,7 +276,7 @@ public void Remove_ReadOnly_Attribute() service.RemoveReadOnlyAttribute(); - var readOnly = fileSystem.FileInfo.FromFileName(service.HostsFilePath).Attributes.HasFlag(FileAttributes.ReadOnly); + var readOnly = fileSystem.FileInfo.New(service.HostsFilePath).Attributes.HasFlag(FileAttributes.ReadOnly); Assert.IsFalse(readOnly); } @@ -295,7 +295,7 @@ public async Task Save_Hidden_Hosts() await service.WriteAsync("# Empty hosts file", Enumerable.Empty()); - var hidden = fileSystem.FileInfo.FromFileName(service.HostsFilePath).Attributes.HasFlag(FileAttributes.Hidden); + var hidden = fileSystem.FileInfo.New(service.HostsFilePath).Attributes.HasFlag(FileAttributes.Hidden); Assert.IsTrue(hidden); } } diff --git a/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcher.cs b/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcher.cs index 0cbabd217b63..5061a6d815c6 100644 --- a/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcher.cs +++ b/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcher.cs @@ -2,6 +2,7 @@ // The Microsoft Corporation licenses this file to you under the MIT license. // See the LICENSE file in the project root for more information. +using System; using System.Collections.ObjectModel; using System.ComponentModel; using System.IO; @@ -9,7 +10,7 @@ namespace Hosts.Tests.Mocks { - public class MockFileSystemWatcher : FileSystemWatcherBase + public partial class MockFileSystemWatcher : FileSystemWatcherBase { public override bool IncludeSubdirectories { get; set; } @@ -27,26 +28,35 @@ public class MockFileSystemWatcher : FileSystemWatcherBase public override ISynchronizeInvoke SynchronizingObject { get; set; } - public override Collection Filters => throw new System.NotImplementedException(); + public override Collection Filters => throw new NotImplementedException(); - public override WaitForChangedResult WaitForChanged(WatcherChangeTypes changeType) => default; + public override IFileSystem FileSystem => throw new NotImplementedException(); - public override WaitForChangedResult WaitForChanged(WatcherChangeTypes changeType, int timeout) => default; + public override IContainer Container => throw new NotImplementedException(); - public MockFileSystemWatcher(string path) => Path = path; + public override void BeginInit() => throw new NotImplementedException(); - public MockFileSystemWatcher(string path, string filter) + public override void EndInit() => throw new NotImplementedException(); + + public override IWaitForChangedResult WaitForChanged(WatcherChangeTypes changeType, TimeSpan timeout) => throw new NotImplementedException(); + + public override IWaitForChangedResult WaitForChanged(WatcherChangeTypes changeType) => throw new NotImplementedException(); + + public override IWaitForChangedResult WaitForChanged(WatcherChangeTypes changeType, int timeout) => throw new NotImplementedException(); + + public MockFileSystemWatcher() { - Path = path; - Filter = filter; } - public override void BeginInit() + public MockFileSystemWatcher(string path) { + Path = path; } - public override void EndInit() + public MockFileSystemWatcher(string path, string filter) { + Path = path; + Filter = filter; } } } diff --git a/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcherFactory.cs b/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcherFactory.cs index 3e0b4de140b4..bef93daf2b49 100644 --- a/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcherFactory.cs +++ b/src/modules/Hosts/Hosts.Tests/Mocks/MockFileSystemWatcherFactory.cs @@ -2,18 +2,22 @@ // The Microsoft Corporation licenses this file to you under the MIT license. // See the LICENSE file in the project root for more information. +using System; +using System.IO; using System.IO.Abstractions; namespace Hosts.Tests.Mocks { public class MockFileSystemWatcherFactory : IFileSystemWatcherFactory { - public IFileSystemWatcher CreateNew() => new MockFileSystemWatcher(null); + public IFileSystem FileSystem => throw new NotImplementedException(); - public IFileSystemWatcher CreateNew(string path) => new MockFileSystemWatcher(path); + public IFileSystemWatcher New() => new MockFileSystemWatcher(); - public IFileSystemWatcher CreateNew(string path, string filter) => new MockFileSystemWatcher(path, filter); + public IFileSystemWatcher New(string path) => new MockFileSystemWatcher(path); - public IFileSystemWatcher FromPath(string path) => new MockFileSystemWatcher(path); + public IFileSystemWatcher New(string path, string filter) => new MockFileSystemWatcher(path, filter); + + public IFileSystemWatcher Wrap(FileSystemWatcher fileSystemWatcher) => throw new NotImplementedException(); } } diff --git a/src/modules/Hosts/HostsUILib/Helpers/HostsService.cs b/src/modules/Hosts/HostsUILib/Helpers/HostsService.cs index a6c1981a82bc..3270681c5e90 100644 --- a/src/modules/Hosts/HostsUILib/Helpers/HostsService.cs +++ b/src/modules/Hosts/HostsUILib/Helpers/HostsService.cs @@ -52,7 +52,7 @@ public HostsService( _hostsFilePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Windows), @"System32\drivers\etc\hosts"); - _fileSystemWatcher = _fileSystem.FileSystemWatcher.CreateNew(); + _fileSystemWatcher = _fileSystem.FileSystemWatcher.New(); _fileSystemWatcher.Path = _fileSystem.Path.GetDirectoryName(HostsFilePath); _fileSystemWatcher.Filter = _fileSystem.Path.GetFileName(HostsFilePath); _fileSystemWatcher.NotifyFilter = NotifyFilters.LastWrite; @@ -130,7 +130,7 @@ public async Task WriteAsync(string additionalLines, IEnumerable entries) throw new NotRunningElevatedException(); } - if (_fileSystem.FileInfo.FromFileName(HostsFilePath).IsReadOnly) + if (_fileSystem.FileInfo.New(HostsFilePath).IsReadOnly) { throw new ReadOnlyHostsException(); } @@ -200,7 +200,7 @@ public async Task WriteAsync(string additionalLines, IEnumerable entries) } // FileMode.OpenOrCreate is necessary to prevent UnauthorizedAccessException when the hosts file is hidden - using var stream = _fileSystem.FileStream.Create(HostsFilePath, FileMode.OpenOrCreate, FileAccess.Write, FileShare.Read, _defaultBufferSize, FileOptions.Asynchronous); + using var stream = _fileSystem.FileStream.New(HostsFilePath, FileMode.OpenOrCreate, FileAccess.Write, FileShare.Read, _defaultBufferSize, FileOptions.Asynchronous); using var writer = new StreamWriter(stream, Encoding); foreach (var line in lines) { @@ -305,7 +305,7 @@ public void OpenHostsFile() public void RemoveReadOnlyAttribute() { - var fileInfo = _fileSystem.FileInfo.FromFileName(HostsFilePath); + var fileInfo = _fileSystem.FileInfo.New(HostsFilePath); if (fileInfo.IsReadOnly) { fileInfo.IsReadOnly = false; diff --git a/src/modules/Workspaces/WorkspacesEditor/Utils/IOUtils.cs b/src/modules/Workspaces/WorkspacesEditor/Utils/IOUtils.cs index 1ec08a79ff45..075067cb142b 100644 --- a/src/modules/Workspaces/WorkspacesEditor/Utils/IOUtils.cs +++ b/src/modules/Workspaces/WorkspacesEditor/Utils/IOUtils.cs @@ -31,7 +31,7 @@ public string ReadFile(string fileName) { try { - using (Stream inputStream = _fileSystem.File.Open(fileName, FileMode.Open)) + using (FileSystemStream inputStream = _fileSystem.File.Open(fileName, FileMode.Open)) using (StreamReader reader = new StreamReader(inputStream)) { string data = reader.ReadToEnd(); diff --git a/src/modules/fancyzones/FancyZonesEditorCommon/Utils/IOUtils.cs b/src/modules/fancyzones/FancyZonesEditorCommon/Utils/IOUtils.cs index f48a34169557..f11e0a2d0e64 100644 --- a/src/modules/fancyzones/FancyZonesEditorCommon/Utils/IOUtils.cs +++ b/src/modules/fancyzones/FancyZonesEditorCommon/Utils/IOUtils.cs @@ -31,7 +31,7 @@ public string ReadFile(string fileName) { try { - using (Stream inputStream = _fileSystem.File.Open(fileName, FileMode.Open)) + using (FileSystemStream inputStream = _fileSystem.File.Open(fileName, FileMode.Open)) using (StreamReader reader = new StreamReader(inputStream)) { string data = reader.ReadToEnd(); diff --git a/src/modules/fancyzones/UITests-FancyZonesEditor/Utils/IOTestHelper.cs b/src/modules/fancyzones/UITests-FancyZonesEditor/Utils/IOTestHelper.cs index d472154ac578..7c52ca0c95ad 100644 --- a/src/modules/fancyzones/UITests-FancyZonesEditor/Utils/IOTestHelper.cs +++ b/src/modules/fancyzones/UITests-FancyZonesEditor/Utils/IOTestHelper.cs @@ -27,7 +27,11 @@ public IOTestHelper(string file) } else { - _fileSystem.Directory.CreateDirectory(Path.GetDirectoryName(file)); + var path = Path.GetDirectoryName(file); + if (path != null) + { + _fileSystem.Directory.CreateDirectory(path); + } } } diff --git a/src/modules/imageresizer/ui/Properties/Settings.cs b/src/modules/imageresizer/ui/Properties/Settings.cs index 6beceeb0820e..3150f9768fb7 100644 --- a/src/modules/imageresizer/ui/Properties/Settings.cs +++ b/src/modules/imageresizer/ui/Properties/Settings.cs @@ -421,7 +421,7 @@ public void Save() string jsonData = JsonSerializer.Serialize(new SettingsWrapper() { Properties = this }, _jsonSerializerOptions); // Create directory if it doesn't exist - IFileInfo file = _fileSystem.FileInfo.FromFileName(SettingsPath); + IFileInfo file = _fileSystem.FileInfo.New(SettingsPath); file.Directory.Create(); // write string to file diff --git a/src/modules/launcher/Plugins/Microsoft.Plugin.Folder.UnitTests/InternalQueryFolderTests.cs b/src/modules/launcher/Plugins/Microsoft.Plugin.Folder.UnitTests/InternalQueryFolderTests.cs index 4bece3c81c71..db4fc8f2a1b0 100644 --- a/src/modules/launcher/Plugins/Microsoft.Plugin.Folder.UnitTests/InternalQueryFolderTests.cs +++ b/src/modules/launcher/Plugins/Microsoft.Plugin.Folder.UnitTests/InternalQueryFolderTests.cs @@ -51,7 +51,7 @@ public void Query_ThrowsException_WhenCalledNull() [DataRow(@"c:", 2, 1, false, DisplayName = "Root without \\")] [DataRow(@"c:\", 2, 1, false, DisplayName = "Normal root")] [DataRow(@"c:\Test", 2, 2, false, DisplayName = "Select yourself")] - [DataRow(@"c:\not-exist", 2, 1, false, DisplayName = "Folder not exist, return root")] + [DataRow(@"c:\not-exist", 2, 0, false, DisplayName = "Folder not exist, return root")] [DataRow(@"c:\not-exist\not-exist2", 0, 0, false, DisplayName = "Folder not exist, return root")] [DataRow(@"c:\bla.t", 2, 1, false, DisplayName = "Partial match file")] [DataRow(@"c:/bla.t", 2, 1, false, DisplayName = "Partial match file with /")] @@ -88,8 +88,8 @@ public void Query_WhenCalled(string search, int folders, int files, bool truncat [DataTestMethod] [DataRow(@"c:\>", 3, 3, true, DisplayName = "Max Folder test recursive")] - [DataRow(@"c:\Test>", 3, 3, true, DisplayName = "2 Folders recursive")] - [DataRow(@"c:\not-exist>", 3, 3, true, DisplayName = "Folder not exist, return root recursive")] + [DataRow(@"c:\Test>", 3, 0, true, DisplayName = "2 Folders recursive")] + [DataRow(@"c:\not-exist>", 3, 0, true, DisplayName = "Folder not exist, return root recursive")] [DataRow(@"c:\not-exist\not-exist2>", 0, 0, false, DisplayName = "Folder not exist, return root recursive")] public void Query_Recursive_WhenCalled(string search, int folders, int files, bool truncated) { diff --git a/src/modules/launcher/Plugins/Microsoft.Plugin.Folder/Sources/QueryFileSystemInfo.cs b/src/modules/launcher/Plugins/Microsoft.Plugin.Folder/Sources/QueryFileSystemInfo.cs index b67a329c84db..ec9a1e28f318 100644 --- a/src/modules/launcher/Plugins/Microsoft.Plugin.Folder/Sources/QueryFileSystemInfo.cs +++ b/src/modules/launcher/Plugins/Microsoft.Plugin.Folder/Sources/QueryFileSystemInfo.cs @@ -25,7 +25,7 @@ public QueryFileSystemInfo(IDirectoryInfoFactory directoryInfoFactory, MatchType public IEnumerable MatchFileSystemInfo(string search, string incompleteName, bool isRecursive) { // search folder and add results - var directoryInfo = _directoryInfoFactory.FromDirectoryName(search); + var directoryInfo = _directoryInfoFactory.New(search); var fileSystemInfos = directoryInfo.EnumerateFileSystemInfos(incompleteName, new EnumerationOptions { MatchType = _matchType, diff --git a/src/modules/launcher/Plugins/Microsoft.Plugin.Program/ProgramSource.cs b/src/modules/launcher/Plugins/Microsoft.Plugin.Program/ProgramSource.cs index 8406bd8bc842..de87652ed88a 100644 --- a/src/modules/launcher/Plugins/Microsoft.Plugin.Program/ProgramSource.cs +++ b/src/modules/launcher/Plugins/Microsoft.Plugin.Program/ProgramSource.cs @@ -22,7 +22,7 @@ public class ProgramSource public string Location { get; set; } - public string Name { get => name ?? FileSystem.DirectoryInfo.FromDirectoryName(Location).Name; set => name = value; } + public string Name { get => name ?? FileSystem.DirectoryInfo.New(Location).Name; set => name = value; } public bool Enabled { get; set; } = true; diff --git a/src/modules/launcher/Wox.Infrastructure/Helper.cs b/src/modules/launcher/Wox.Infrastructure/Helper.cs index 40026d35b9ec..96313e60b565 100644 --- a/src/modules/launcher/Wox.Infrastructure/Helper.cs +++ b/src/modules/launcher/Wox.Infrastructure/Helper.cs @@ -71,8 +71,8 @@ public static void ValidateDataDirectory(string bundledDataDirectory, string dat } else { - var time1 = FileInfo.FromFileName(bundledDataPath).LastWriteTimeUtc; - var time2 = FileInfo.FromFileName(dataPath).LastWriteTimeUtc; + var time1 = FileInfo.New(bundledDataPath).LastWriteTimeUtc; + var time2 = FileInfo.New(dataPath).LastWriteTimeUtc; if (time1 != time2) { File.Copy(bundledDataPath, dataPath, true); diff --git a/src/settings-ui/Settings.UI.Library/LanguageModel.cs b/src/settings-ui/Settings.UI.Library/LanguageModel.cs index 1e9ef82ec658..63652aba73e5 100644 --- a/src/settings-ui/Settings.UI.Library/LanguageModel.cs +++ b/src/settings-ui/Settings.UI.Library/LanguageModel.cs @@ -30,7 +30,7 @@ public static string LoadSetting() { try { - Stream inputStream = fileSystem.File.Open(file, FileMode.Open); + FileSystemStream inputStream = fileSystem.File.Open(file, FileMode.Open); StreamReader reader = new StreamReader(inputStream); string data = reader.ReadToEnd(); inputStream.Close(); diff --git a/src/settings-ui/Settings.UI.Library/UpdatingSettings.cs b/src/settings-ui/Settings.UI.Library/UpdatingSettings.cs index 16e9e50ab760..b5244bbc0085 100644 --- a/src/settings-ui/Settings.UI.Library/UpdatingSettings.cs +++ b/src/settings-ui/Settings.UI.Library/UpdatingSettings.cs @@ -102,7 +102,7 @@ public static UpdatingSettings LoadSettings() { try { - Stream inputStream = fileSystem.File.Open(file, FileMode.Open); + FileSystemStream inputStream = fileSystem.File.Open(file, FileMode.Open); StreamReader reader = new StreamReader(inputStream); string data = reader.ReadToEnd(); inputStream.Close(); diff --git a/src/settings-ui/Settings.UI.Library/Utilities/Helper.cs b/src/settings-ui/Settings.UI.Library/Utilities/Helper.cs index fc1f8d6f7cf3..58d1f5f46927 100644 --- a/src/settings-ui/Settings.UI.Library/Utilities/Helper.cs +++ b/src/settings-ui/Settings.UI.Library/Utilities/Helper.cs @@ -7,7 +7,6 @@ using System.IO; using System.IO.Abstractions; using System.Linq; -using System.Net.NetworkInformation; using System.Security.Principal; using Microsoft.PowerToys.Settings.UI.Library.CustomAction; @@ -63,7 +62,7 @@ public static IFileSystemWatcher GetFileWatcher(string moduleName, string fileNa FileSystem.Directory.CreateDirectory(path); } - var watcher = FileSystem.FileSystemWatcher.CreateNew(); + var watcher = FileSystem.FileSystemWatcher.New(); watcher.Path = path; watcher.Filter = fileName; watcher.NotifyFilter = NotifyFilters.LastWrite; diff --git a/src/settings-ui/Settings.UI/SettingsXAML/Views/AwakePage.xaml.cs b/src/settings-ui/Settings.UI/SettingsXAML/Views/AwakePage.xaml.cs index b30ff668443d..49861c3c0b49 100644 --- a/src/settings-ui/Settings.UI/SettingsXAML/Views/AwakePage.xaml.cs +++ b/src/settings-ui/Settings.UI/SettingsXAML/Views/AwakePage.xaml.cs @@ -54,7 +54,7 @@ public AwakePage() var settingsPath = _settingsUtils.GetSettingsFilePath(_appName); - _fileSystemWatcher = _fileSystem.FileSystemWatcher.CreateNew(); + _fileSystemWatcher = _fileSystem.FileSystemWatcher.New(); _fileSystemWatcher.Path = _fileSystem.Path.GetDirectoryName(settingsPath); _fileSystemWatcher.Filter = _fileSystem.Path.GetFileName(settingsPath); _fileSystemWatcher.NotifyFilter = NotifyFilters.LastWrite | NotifyFilters.CreationTime;