diff --git a/Source/Lib/Common/FileSystems/Models/IAbsolutePath.cs b/Source/Lib/Common/FileSystems/Models/IAbsolutePath.cs index bd8434b49..c76414393 100644 --- a/Source/Lib/Common/FileSystems/Models/IAbsolutePath.cs +++ b/Source/Lib/Common/FileSystems/Models/IAbsolutePath.cs @@ -4,4 +4,21 @@ public interface IAbsolutePath : IPath { public IFileSystemDrive? RootDrive { get; } public bool IsRootDirectory { get; } + + /// + /// One might prefer instead + /// of this method.

+ /// + /// This version adds an extra function invocation for no reason. To use + /// may be a negligible + /// optimization however.

+ /// + /// Keep this method here, it provides more clear documentation on how to create an instance + /// of . Having to invoke a method on the + /// is a bit hard to find. + ///
+ public static IAbsolutePath Factory(string path, bool isDirectory, IEnvironmentProvider environmentProvider) + { + return environmentProvider.AbsolutePathFactory(path, isDirectory); + } } diff --git a/Source/Lib/Common/FileSystems/Models/IRelativePath.cs b/Source/Lib/Common/FileSystems/Models/IRelativePath.cs index b8028d988..1c817d589 100644 --- a/Source/Lib/Common/FileSystems/Models/IRelativePath.cs +++ b/Source/Lib/Common/FileSystems/Models/IRelativePath.cs @@ -15,4 +15,21 @@ public interface IRelativePath : IPath /// Given "../../../Homework/math.txt". The count is 3. /// public int UpDirDirectiveCount { get; } + + /// + /// One might prefer instead + /// of this method.

+ /// + /// This version adds an extra function invocation for no reason. To use + /// may be a negligible + /// optimization however.

+ /// + /// Keep this method here, it provides more clear documentation on how to create an instance + /// of . Having to invoke a method on the + /// is a bit hard to find. + ///
+ public static IRelativePath Factory(string path, bool isDirectory, IEnvironmentProvider environmentProvider) + { + return environmentProvider.RelativePathFactory(path, isDirectory); + } } \ No newline at end of file diff --git a/Source/Tests/Ide/Basis/IdeTestBase.cs b/Source/Tests/Ide/Basis/IdeTestBase.cs new file mode 100644 index 000000000..62882e2fb --- /dev/null +++ b/Source/Tests/Ide/Basis/IdeTestBase.cs @@ -0,0 +1,122 @@ +using Fluxor; +using Luthetus.Common.RazorLib.BackgroundTasks.Models; +using Luthetus.Common.RazorLib.Installations.Models; +using Luthetus.Common.RazorLib.Misc; +using Microsoft.Extensions.DependencyInjection; +using Microsoft.JSInterop; +using Luthetus.Ide.RazorLib.Installations.Models; +using Luthetus.TextEditor.RazorLib.Installations.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Luthetus.Common.RazorLib.Exceptions; + +namespace Luthetus.Ide.Tests.Basis; + +public class IdeTestBase +{ + protected static void Test_RegisterServices(out ServiceProvider serviceProvider) + { + var backgroundTaskService = new BackgroundTaskServiceSynchronous(); + + var serviceCollection = new ServiceCollection() + .AddScoped() + .AddLuthetusIdeRazorLibServices(new LuthetusHostingInformation(LuthetusHostingKind.UnitTesting, backgroundTaskService)) + .AddFluxor(options => options.ScanAssemblies( + typeof(LuthetusCommonConfig).Assembly, + typeof(LuthetusTextEditorConfig).Assembly, + typeof(LuthetusIdeConfig).Assembly)); + + serviceProvider = serviceCollection.BuildServiceProvider(); + + var store = serviceProvider.GetRequiredService(); + store.InitializeAsync().Wait(); + + var environmentProvider = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + + if (environmentProvider.GetType() != typeof(InMemoryEnvironmentProvider)) + { + throw new LuthetusCommonException($"When unit testing one must use the {nameof(InMemoryEnvironmentProvider)} " + + $"implementation of {nameof(IEnvironmentProvider)}. This will avoid any side effects from running the tests."); + } + + if (fileSystemProvider.GetType() != typeof(InMemoryFileSystemProvider)) + { + throw new LuthetusCommonException($"When unit testing one must use the {nameof(InMemoryFileSystemProvider)} " + + $"implementation of {nameof(IFileSystemProvider)} This will avoid any side effects from running the tests."); + } + } + + /// + /// The files shown in the 'tree' below will be written to the in-memory filesystem. + /// ---------------------------------------------
+ /// Root
+ /// ∙└───Homework
+ /// ∙∙∙∙∙∙├───Math
+ /// ∙∙∙∙∙∙│∙∙∙∙├───addition.txt
+ /// ∙∙∙∙∙∙│∙∙∙∙└───subtraction.txt
+ /// ∙∙∙∙∙∙│
+ /// ∙∙∙∙∙∙└───Biology
+ /// ∙∙∙∙∙∙∙∙∙∙∙├───nervousSystem.txt
+ /// ∙∙∙∙∙∙∙∙∙∙∙└───skeletalSystem.txt
+ ///
+ protected static void Test_CreateFileSystem(IServiceProvider serviceProvider) + { + // Cast as the in-memory provider to ensure the actual filesystem will not be used. + InMemoryEnvironmentProvider environmentProvider = + (InMemoryEnvironmentProvider)serviceProvider.GetRequiredService(); + + // Cast as the in-memory provider to ensure the actual filesystem will not be used. + InMemoryFileSystemProvider fileSystemProvider = + (InMemoryFileSystemProvider)serviceProvider.GetRequiredService(); + + WriteToInMemoryFileSystem( + environmentProvider, + fileSystemProvider); + } + + private static void WriteToInMemoryFileSystem( + InMemoryEnvironmentProvider inMemoryEnvironmentProvider, + InMemoryFileSystemProvider inMemoryFileSystemProvider) + { + var dsc = inMemoryEnvironmentProvider.DirectorySeparatorChar; + + inMemoryFileSystemProvider.File.WriteAllTextAsync( + $"{dsc}Homework{dsc}Math{dsc}addition.txt", + "3 + 7 = 10"); + + inMemoryFileSystemProvider.File.WriteAllTextAsync( + $"{dsc}Homework{dsc}Math{dsc}subtraction.txt", + "10 - 3 = 7"); + + inMemoryFileSystemProvider.File.WriteAllTextAsync( + $"{dsc}Homework{dsc}Biology{dsc}nervousSystem.txt", + "The nervous system is..."); + + inMemoryFileSystemProvider.File.WriteAllTextAsync( + $"{dsc}Homework{dsc}Biology{dsc}skeletalSystem.txt", + "The skeletal system is..."); + } + + protected class Test_WellKnownPaths + { + public class Directories + { + public const string Root = "/"; + public const string Homework = "/Homework/"; + public const string Math = "/Homework/Math/"; + public const string Biology = "/Homework/Biology/"; + + public const string NonExistingDirectory = "/Homework/Hamburger/"; + } + + public class Files + { + public const string AdditionTxt = "/Homework/Math/addition.txt"; + public const string SubtractionTxt = "/Homework/Math/subtraction.txt"; + public const string NervousSystemTxt = "/Homework/Biology/nervousSystem.txt"; + public const string SkeletalSystemTxt = "/Homework/Biology/skeletalSystem.txt"; + + public const string NonExistingFile = "/Homework/Hamburger/recipe.txt"; + } + } +} diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewAbsolutePathTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewAbsolutePathTests.cs index 0fa628bea..6024e1374 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewAbsolutePathTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewAbsolutePathTests.cs @@ -3,13 +3,14 @@ using Luthetus.Common.RazorLib.TreeViews.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewAbsolutePathTests +public class TreeViewAbsolutePathTests : IdeTestBase { /// /// @@ -22,7 +23,35 @@ public class TreeViewAbsolutePathTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var absolutePath = environmentProvider.AbsolutePathFactory(Test_WellKnownPaths.Files.NervousSystemTxt, false); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewAbsolutePath( + absolutePath, + ideComponentRenderers, + commonComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, absolutePath); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectDependenciesTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectDependenciesTests.cs index 8b668517f..ffba0d340 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectDependenciesTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectDependenciesTests.cs @@ -3,13 +3,16 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCSharpProjectDependenciesTests +public class TreeViewCSharpProjectDependenciesTests : IdeTestBase { /// /// @@ -21,7 +24,36 @@ public class TreeViewCSharpProjectDependenciesTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var cSharpProjectDependencies = new CSharpProjectDependencies( + new NamespacePath( + "ProjectOne", + environmentProvider.AbsolutePathFactory("/ProjectOne/ProjectOne.csproj", false))); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCSharpProjectDependencies( + cSharpProjectDependencies, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, cSharpProjectDependencies); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferenceTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferenceTests.cs index f83ec0758..eac1e8958 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferenceTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferenceTests.cs @@ -3,13 +3,17 @@ using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.Nugets.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCSharpProjectNugetPackageReferenceTests +public class TreeViewCSharpProjectNugetPackageReferenceTests : IdeTestBase { /// /// @@ -21,7 +25,35 @@ public class TreeViewCSharpProjectNugetPackageReferenceTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var cSharpProjectNugetPackageReference = new CSharpProjectNugetPackageReference( + "/ProjectOne/ProjectOne.csproj", + new LightWeightNugetPackageRecord(string.Empty, string.Empty, string.Empty)); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCSharpProjectNugetPackageReference( + cSharpProjectNugetPackageReference, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, cSharpProjectNugetPackageReference); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferencesTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferencesTests.cs index d5ca151d4..f0d02c7b9 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferencesTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectNugetPackageReferencesTests.cs @@ -3,13 +3,16 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Microsoft.Extensions.DependencyInjection; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCSharpProjectNugetPackageReferencesTests +public class TreeViewCSharpProjectNugetPackageReferencesTests : IdeTestBase { /// /// @@ -21,7 +24,36 @@ public class TreeViewCSharpProjectNugetPackageReferencesTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var cSharpProjectNugetPackageReferences = new CSharpProjectNugetPackageReferences( + new NamespacePath( + "ProjectOne", + environmentProvider.AbsolutePathFactory("/ProjectOne/ProjectOne.csproj", false))); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCSharpProjectNugetPackageReferences( + cSharpProjectNugetPackageReferences, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, cSharpProjectNugetPackageReferences); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferenceTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferenceTests.cs index 7d7a4b3e3..a4bb662ad 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferenceTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferenceTests.cs @@ -3,13 +3,17 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Ide.RazorLib.Gits.Models; +using Microsoft.Extensions.DependencyInjection; +using Luthetus.Common.RazorLib.Namespaces.Models; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCSharpProjectToProjectReferenceTests +public class TreeViewCSharpProjectToProjectReferenceTests : IdeTestBase { /// /// @@ -21,7 +25,37 @@ public class TreeViewCSharpProjectToProjectReferenceTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var cSharpProjectToProjectReference = new CSharpProjectToProjectReference( + new NamespacePath( + "ProjectOne", + environmentProvider.AbsolutePathFactory("/ProjectOne/ProjectOne.csproj", false)), + environmentProvider.AbsolutePathFactory("/ProjectTwo/ProjectTwo.csproj", false)); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCSharpProjectToProjectReference( + cSharpProjectToProjectReference, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, cSharpProjectToProjectReference); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferencesTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferencesTests.cs index 393d0e292..2cde15e44 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferencesTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCSharpProjectToProjectReferencesTests.cs @@ -3,13 +3,16 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCSharpProjectToProjectReferencesTests +public class TreeViewCSharpProjectToProjectReferencesTests : IdeTestBase { /// /// @@ -21,7 +24,36 @@ public class TreeViewCSharpProjectToProjectReferencesTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var cSharpProjectToProjectReferences = new CSharpProjectToProjectReferences( + new NamespacePath( + "ProjectOne", + environmentProvider.AbsolutePathFactory("/ProjectOne/ProjectOne.csproj", false))); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCSharpProjectToProjectReferences( + cSharpProjectToProjectReferences, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, cSharpProjectToProjectReferences); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCompilerServiceTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCompilerServiceTests.cs index 5a0eaf05a..0bf0731f4 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCompilerServiceTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewCompilerServiceTests.cs @@ -2,13 +2,19 @@ using Luthetus.TextEditor.RazorLib.CompilerServices.Interfaces; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; +using Microsoft.Extensions.DependencyInjection; +using Luthetus.CompilerServices.Lang.CSharp.CompilerServiceCase; +using Luthetus.TextEditor.RazorLib; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewCompilerServiceTests +public class TreeViewCompilerServiceTests : IdeTestBase { /// /// @@ -19,7 +25,32 @@ public class TreeViewCompilerServiceTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var compilerService = new CSharpCompilerService( + serviceProvider.GetRequiredService()); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewCompilerService( + compilerService, + ideComponentRenderers, + commonComponentRenderers, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, compilerService); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewGitFileTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewGitFileTests.cs index f54da1cce..a0a20041f 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewGitFileTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewGitFileTests.cs @@ -2,13 +2,17 @@ using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; using Luthetus.Ide.RazorLib.Gits.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Microsoft.AspNetCore.Components; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewGitFileTests +public class TreeViewGitFileTests : IdeTestBase { /// /// @@ -18,7 +22,31 @@ public class TreeViewGitFileTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var gitFile = new GitFile( + environmentProvider.AbsolutePathFactory("/unitTesting.txt", false), + GitDirtyReason.Untracked); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewGitFile( + gitFile, + ideComponentRenderers, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, gitFile); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewMarkupStringTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewMarkupStringTests.cs index a8568f2b2..63957c9c5 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewMarkupStringTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewMarkupStringTests.cs @@ -3,13 +3,16 @@ using Luthetus.Common.RazorLib.TreeViews.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; +using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.Namespaces.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewMarkupStringTests +public class TreeViewMarkupStringTests : IdeTestBase { /// /// @@ -21,7 +24,33 @@ public class TreeViewMarkupStringTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var markupString = new MarkupString("
Abc123
"); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewMarkupString( + markupString, + ideComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, markupString); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewNamespacePathTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewNamespacePathTests.cs index f2f4c104c..d79b0d781 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewNamespacePathTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewNamespacePathTests.cs @@ -4,13 +4,15 @@ using Luthetus.Common.RazorLib.FileSystems.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Ide.RazorLib.TestExplorers.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewNamespacePathTests +public class TreeViewNamespacePathTests : IdeTestBase { /// /// @@ -23,7 +25,37 @@ public class TreeViewNamespacePathTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var namespacePath = new NamespacePath( + "MyNamespace", + environmentProvider.AbsolutePathFactory("/unitTesting.cs", false)); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewNamespacePath( + namespacePath, + ideComponentRenderers, + commonComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, namespacePath); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewProjectTestModelTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewProjectTestModelTests.cs index 21be55c69..a10814985 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewProjectTestModelTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewProjectTestModelTests.cs @@ -2,13 +2,17 @@ using Luthetus.Common.RazorLib.TreeViews.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.TestExplorers.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Luthetus.Common.RazorLib.WatchWindows.Models; +using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewProjectTestModelTests +public class TreeViewProjectTestModelTests : IdeTestBase { /// /// @@ -18,7 +22,33 @@ public class TreeViewProjectTestModelTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var projectTestModel = new ProjectTestModel( + Guid.NewGuid(), + environmentProvider.AbsolutePathFactory("/unitTesting.txt", false), + callback => Task.CompletedTask, + callback => { }); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewProjectTestModel( + projectTestModel, + commonComponentRenderers, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, projectTestModel); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewReflectionWithViewTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewReflectionWithViewTests.cs index b13f879fd..7ed6df5bc 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewReflectionWithViewTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewReflectionWithViewTests.cs @@ -2,13 +2,18 @@ using Luthetus.Common.RazorLib.WatchWindows.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; +using Luthetus.TextEditor.RazorLib.CompilerServices.Syntax.Tokens; +using Luthetus.TextEditor.RazorLib.Lexes.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewReflectionWithViewTests +public class TreeViewReflectionWithViewTests : IdeTestBase { /// /// @@ -19,7 +24,32 @@ public class TreeViewReflectionWithViewTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var item = "abc123"; + var watchWindowObject = new WatchWindowObject(item, item.GetType(), nameof(item), false); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewReflectionWithView( + watchWindowObject, + isExpandable, + isExpanded, + ideComponentRenderers, + commonComponentRenderers); + + Assert.Equal(treeView.Item, watchWindowObject); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionFolderTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionFolderTests.cs index f899d98e2..ba3795b89 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionFolderTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionFolderTests.cs @@ -4,13 +4,18 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.CompilerServices.Lang.DotNetSolution.Models; +using System.Collections.Immutable; +using Microsoft.Extensions.DependencyInjection; +using Luthetus.TextEditor.RazorLib.CompilerServices.Syntax.Tokens; +using Luthetus.TextEditor.RazorLib.Lexes.Models; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewSolutionFolderTests +public class TreeViewSolutionFolderTests : IdeTestBase { /// /// @@ -23,7 +28,42 @@ public class TreeViewSolutionFolderTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var dotNetSolutionFolder = new SolutionFolder( + "Tests", + Guid.NewGuid(), + string.Empty, + Guid.NewGuid(), + new OpenAssociatedGroupToken(TextEditorTextSpan.FabricateTextSpan(string.Empty)), + new CloseAssociatedGroupToken(TextEditorTextSpan.FabricateTextSpan(string.Empty)), + environmentProvider.AbsolutePathFactory(string.Empty, false)); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewSolutionFolder( + dotNetSolutionFolder, + ideComponentRenderers, + commonComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, dotNetSolutionFolder); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionTests.cs index 7d6f07d94..11691acef 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSolutionTests.cs @@ -4,13 +4,16 @@ using Luthetus.CompilerServices.Lang.DotNetSolution.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Microsoft.Extensions.DependencyInjection; +using System.Collections.Immutable; +using Luthetus.CompilerServices.Lang.DotNetSolution.Models.Project; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewSolutionTests +public class TreeViewSolutionTests : IdeTestBase { /// /// @@ -23,7 +26,42 @@ public class TreeViewSolutionTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var dotNetSolutionModel = new DotNetSolutionModel( + environmentProvider.AbsolutePathFactory("/unitTesting.sln", false), + new DotNetSolutionHeader(), + ImmutableArray.Empty, + ImmutableArray.Empty, + ImmutableArray.Empty, + new DotNetSolutionGlobal(), + string.Empty); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewSolution( + dotNetSolutionModel, + ideComponentRenderers, + commonComponentRenderers, + fileSystemProvider, + environmentProvider, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, dotNetSolutionModel); + Assert.Equal(treeView.IdeComponentRenderers, ideComponentRenderers); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.FileSystemProvider, fileSystemProvider); + Assert.Equal(treeView.EnvironmentProvider, environmentProvider); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSpinnerTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSpinnerTests.cs index c2c720a78..aa9aca437 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSpinnerTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewSpinnerTests.cs @@ -1,13 +1,17 @@ using Luthetus.Common.RazorLib.ComponentRenderers.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; using Luthetus.Common.RazorLib.TreeViews.Models; +using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Luthetus.Ide.RazorLib.TestExplorers.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewSpinnerTests +public class TreeViewSpinnerTests : IdeTestBase { /// /// @@ -17,7 +21,29 @@ public class TreeViewSpinnerTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var guid = Guid.NewGuid(); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewSpinner( + guid, + commonComponentRenderers, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, guid); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } /// diff --git a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewStringFragmentTests.cs b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewStringFragmentTests.cs index c8de26bfa..08edffa56 100644 --- a/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewStringFragmentTests.cs +++ b/Source/Tests/Ide/Basis/TreeViewImplementations/Models/TreeViewStringFragmentTests.cs @@ -2,13 +2,16 @@ using Luthetus.Common.RazorLib.TreeViews.Models; using Luthetus.Ide.RazorLib.TreeViewImplementations.Models; using Luthetus.Ide.RazorLib.TestExplorers.Models; +using Luthetus.Common.RazorLib.FileSystems.Models; +using Luthetus.Ide.RazorLib.ComponentRenderers.Models; +using Microsoft.Extensions.DependencyInjection; namespace Luthetus.Ide.Tests.Basis.TreeViewImplementations.Models; /// /// /// -public class TreeViewStringFragmentTests +public class TreeViewStringFragmentTests : IdeTestBase { /// /// @@ -18,7 +21,29 @@ public class TreeViewStringFragmentTests [Fact] public void Constructor() { - throw new NotImplementedException(); + Test_RegisterServices(out var serviceProvider); + Test_CreateFileSystem(serviceProvider); + + var ideComponentRenderers = serviceProvider.GetRequiredService(); + var commonComponentRenderers = serviceProvider.GetRequiredService(); + var fileSystemProvider = serviceProvider.GetRequiredService(); + var environmentProvider = serviceProvider.GetRequiredService(); + + var stringFragment = new StringFragment("abc.123"); + + var isExpandable = true; + var isExpanded = true; + + var treeView = new TreeViewStringFragment( + stringFragment, + commonComponentRenderers, + isExpandable, + isExpanded); + + Assert.Equal(treeView.Item, stringFragment); + Assert.Equal(treeView.CommonComponentRenderers, commonComponentRenderers); + Assert.Equal(treeView.IsExpandable, isExpandable); + Assert.Equal(treeView.IsExpanded, isExpanded); } ///