From 7f6eb69a1d9121fc314bb4fbd333627a989b6305 Mon Sep 17 00:00:00 2001 From: Roberto T <61755417+RobertGlobant20@users.noreply.github.com> Date: Thu, 5 Oct 2023 13:37:20 -0700 Subject: [PATCH] DYN-6010 Enable Node Help Docs Sharing DYN files (#14441) * DYN-6010 Enable Node Help Docs Sharing DYN files The NodeHelpSharedDocs folder already exists then I just modified the DynamoCore.csproj so the dyn files will be copied to the shared folder NodeHelpSharedDocs (then the en-US/fallbacks_docs folder won't contain dyn files anymore). So when inserting a graph DocumentationBrowser will be using the dyn files stored in the NodeHelpSharedDocs folder. * DYN-6010 Enable Node Help Docs Sharing DYN files Code Review Adding Unit Test that will be validating the result of the GetGraphLinkFromMDLocation( method. --- .../DocumentationBrowserView.xaml.cs | 2 +- .../DocumentationBrowserViewModel.cs | 4 +- src/DynamoCore/DynamoCore.csproj | 2 +- .../DocumentationBrowserViewExtensionTests.cs | 38 +++++++++++++++++++ 4 files changed, 43 insertions(+), 3 deletions(-) diff --git a/src/DocumentationBrowserViewExtension/DocumentationBrowserView.xaml.cs b/src/DocumentationBrowserViewExtension/DocumentationBrowserView.xaml.cs index b02e30c05dd..75dcee02c63 100644 --- a/src/DocumentationBrowserViewExtension/DocumentationBrowserView.xaml.cs +++ b/src/DocumentationBrowserViewExtension/DocumentationBrowserView.xaml.cs @@ -27,7 +27,7 @@ public partial class DocumentationBrowserView : UserControl, IDisposable internal string WebBrowserUserDataFolder { get; set; } internal string FallbackDirectoryName { get; set; } //This folder will be used to store images and dyn files previosuly located in /rootDirectory/en-US/fallback_docs so we don't need to copy all those files per each language - internal const string SharedDocsDirectoryName = "NodeHelpSharedDocs"; + internal static readonly string SharedDocsDirectoryName = "NodeHelpSharedDocs"; //Path in which the virtual folder for loading images will be created internal string VirtualFolderPath { get; set; } diff --git a/src/DocumentationBrowserViewExtension/DocumentationBrowserViewModel.cs b/src/DocumentationBrowserViewExtension/DocumentationBrowserViewModel.cs index afb55ae768f..07dd12fad5d 100644 --- a/src/DocumentationBrowserViewExtension/DocumentationBrowserViewModel.cs +++ b/src/DocumentationBrowserViewExtension/DocumentationBrowserViewModel.cs @@ -446,7 +446,9 @@ internal void InsertGraph() private string DynamoGraphFromMDFilePath(string path) { path = HttpUtility.UrlDecode(path); - return Path.Combine(Path.GetDirectoryName(path), Path.GetFileNameWithoutExtension(path)) + ".dyn"; + var rootLevelDir = Path.GetDirectoryName(path); + var imagesLocation = Path.Combine(new DirectoryInfo(rootLevelDir).Parent.Parent.FullName, DocumentationBrowserView.SharedDocsDirectoryName); + return Path.Combine(imagesLocation, Path.GetFileNameWithoutExtension(path)) + ".dyn"; } diff --git a/src/DynamoCore/DynamoCore.csproj b/src/DynamoCore/DynamoCore.csproj index fb7e67be4e3..73bb1d1763a 100644 --- a/src/DynamoCore/DynamoCore.csproj +++ b/src/DynamoCore/DynamoCore.csproj @@ -138,7 +138,7 @@ - + diff --git a/test/DynamoCoreWpfTests/ViewExtensions/DocumentationBrowserViewExtensionTests.cs b/test/DynamoCoreWpfTests/ViewExtensions/DocumentationBrowserViewExtensionTests.cs index 8079cfe37a1..2aeb2ef082c 100644 --- a/test/DynamoCoreWpfTests/ViewExtensions/DocumentationBrowserViewExtensionTests.cs +++ b/test/DynamoCoreWpfTests/ViewExtensions/DocumentationBrowserViewExtensionTests.cs @@ -763,6 +763,44 @@ public void AddGraphInSpecificLocationToWorkspace() Assert.AreEqual(ViewModel.Model.CurrentWorkspace.Nodes.Count(), 5); } + [Test] + public void Validate_GetGraphLinkFromMDLocation() + { + var nodeName = "Number"; + this.ViewModel.ExecuteCommand( + new DynamoModel.CreateNodeCommand( + Guid.NewGuid().ToString(), nodeName, 0, 0, false, false) + ); + + //Validates that we have just one node in the CurrentWorkspace + Assert.AreEqual(ViewModel.Model.CurrentWorkspace.Nodes.Count(), 1); + + var node = ViewModel.Model.CurrentWorkspace.Nodes.FirstOrDefault(); + + //In this call the GetGraphLinkFromMDLocation() method is executed internally + RequestNodeDocs(node); + + // Show the DocumentationBrowser so we can get the DocumentationBrowserViewModel + ShowDocsBrowser(); + var docsView = GetDocsTabItem().Content as DocumentationBrowserView; + var docsViewModel = docsView.DataContext as DocumentationBrowserViewModel; + + //Due that graphPath is a private we use reflection to get the value. + FieldInfo type = typeof(DocumentationBrowserViewModel).GetField("graphPath", BindingFlags.NonPublic | BindingFlags.Instance); + var graphPathValue = type.GetValue(docsViewModel); + + var dynFileName = Path.GetFileNameWithoutExtension(docsViewModel.Link.AbsolutePath) + ".dyn"; + + //This will return a path with the NodeHelpSharedDocs + dyn file name + var sharedFilesPath = Path.Combine(DocumentationBrowserView.SharedDocsDirectoryName, dynFileName); + + Assert.IsNotNull(graphPathValue); + Assert.IsTrue(!string.IsNullOrEmpty(graphPathValue.ToString())); + + //Chech that the pathPath contains "NodeHelpSharedDocs//dynfilename" + Assert.That(graphPathValue.ToString().Contains(sharedFilesPath)); + } + #region Helpers private DocumentationBrowserViewExtension SetupNewViewExtension(bool runLoadedMethod = false)