From 24cc4b213b2f6c76278c37b8aa267ddcb94b05fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andrej=20=C4=8Ci=C5=BEm=C3=A1rik?= Date: Tue, 17 Jan 2023 10:21:49 +0100 Subject: [PATCH] Changed directives to be case-insensitive again --- .../Directives/MarkupDirectiveCompilerPipeline.cs | 4 +++- .../ViewModelDirectiveTest.cs | 11 +++++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/src/Framework/Framework/Compilation/Directives/MarkupDirectiveCompilerPipeline.cs b/src/Framework/Framework/Compilation/Directives/MarkupDirectiveCompilerPipeline.cs index 2475e84115..9c854e3f9b 100644 --- a/src/Framework/Framework/Compilation/Directives/MarkupDirectiveCompilerPipeline.cs +++ b/src/Framework/Framework/Compilation/Directives/MarkupDirectiveCompilerPipeline.cs @@ -24,7 +24,9 @@ public MarkupDirectiveCompilerPipeline(IAbstractTreeBuilder treeBuilder, IContro public MarkupPageMetadata Compile(DothtmlRootNode dothtmlRoot, string fileName) { - var directivesByName = dothtmlRoot.Directives.GroupBy(d => d.Name, StringComparer.OrdinalIgnoreCase).ToDictionary(d => d.Key, d => (IReadOnlyList)d.ToList()); + var directivesByName = dothtmlRoot.Directives + .GroupBy(d => d.Name, StringComparer.OrdinalIgnoreCase) + .ToDictionary(d => d.Key, d => (IReadOnlyList)d.ToList(), StringComparer.OrdinalIgnoreCase); var resolvedDirectives = new Dictionary>(); diff --git a/src/Tests/Runtime/ControlTree/DefaultControlTreeResolver/ViewModelDirectiveTest.cs b/src/Tests/Runtime/ControlTree/DefaultControlTreeResolver/ViewModelDirectiveTest.cs index fe9297ba56..4176eb21b9 100644 --- a/src/Tests/Runtime/ControlTree/DefaultControlTreeResolver/ViewModelDirectiveTest.cs +++ b/src/Tests/Runtime/ControlTree/DefaultControlTreeResolver/ViewModelDirectiveTest.cs @@ -88,5 +88,16 @@ public void ResolvedTree_ViewModel_TypeFromGlobalImportedNamespace() Assert.IsFalse(root.Directives.Any(d => d.Value.Any(dd => dd.DothtmlNode.HasNodeErrors))); Assert.AreEqual(typeof(TestViewModel), root.DataContextTypeStack.DataContextType); } + + [TestMethod] + [DataRow("@viewModel")] + [DataRow("@viewmodel")] + public void ResolvedTree_ViewModel_DirectiveIdentifier_CaseInsensitivity(string directive) + { + var root = ParseSource($"{directive} System.String"); + + Assert.IsFalse(root.Directives.Any(d => d.Value.Any(dd => dd.DothtmlNode.HasNodeErrors))); + Assert.AreEqual(typeof(string), root.DataContextTypeStack.DataContextType); + } } }