diff --git a/src/Analyzers/Analyzers.Tests/Serializability/ViewModelSerializabilityTest.cs b/src/Analyzers/Analyzers.Tests/Serializability/ViewModelSerializabilityTest.cs index 1dda07a9a2..5c1baae28a 100644 --- a/src/Analyzers/Analyzers.Tests/Serializability/ViewModelSerializabilityTest.cs +++ b/src/Analyzers/Analyzers.Tests/Serializability/ViewModelSerializabilityTest.cs @@ -194,6 +194,8 @@ public class DefaultViewModel : DotvvmViewModelBase public object Object { get; set; } public string String { get; set; } public DateTime DateTime { get; set; } + public DateOnly DateOnly { get; set; } + public TimeOnly TimeOnly { get; set; } public TimeSpan TimeSpan { get; set; } public Guid Guid { get; set; } } diff --git a/src/Analyzers/Analyzers.Tests/Verifiers/CSharpAnalyzerVerifier`1.cs b/src/Analyzers/Analyzers.Tests/Verifiers/CSharpAnalyzerVerifier`1.cs index ec023f834b..f4ffa04877 100644 --- a/src/Analyzers/Analyzers.Tests/Verifiers/CSharpAnalyzerVerifier`1.cs +++ b/src/Analyzers/Analyzers.Tests/Verifiers/CSharpAnalyzerVerifier`1.cs @@ -29,6 +29,7 @@ public static async Task VerifyAnalyzerAsync(string source, params DiagnosticRes var test = new Test { TestCode = source, + ReferenceAssemblies = ReferenceAssemblies.Net.Net60 }; test.ExpectedDiagnostics.AddRange(expected); diff --git a/src/Analyzers/Analyzers/Serializability/TypeSymbolExtensions.cs b/src/Analyzers/Analyzers/Serializability/TypeSymbolExtensions.cs index 56a6f27384..eec4672a3a 100644 --- a/src/Analyzers/Analyzers/Serializability/TypeSymbolExtensions.cs +++ b/src/Analyzers/Analyzers/Serializability/TypeSymbolExtensions.cs @@ -82,6 +82,8 @@ private static ImmutableHashSet CreateTypesCache(Compilation compilatio cacheBuilder.Add(compilation.GetTypeByMetadataName("System.Guid")!); cacheBuilder.Add(compilation.GetTypeByMetadataName("System.TimeSpan")!); cacheBuilder.Add(compilation.GetTypeByMetadataName("System.DateTimeOffset")!); + cacheBuilder.Add(compilation.GetTypeByMetadataName("System.DateOnly")!); + cacheBuilder.Add(compilation.GetTypeByMetadataName("System.TimeOnly")!); return cacheBuilder.ToImmutableHashSet(SymbolEqualityComparer.Default); } diff --git a/src/Framework/Framework/Controls/Validator.cs b/src/Framework/Framework/Controls/Validator.cs index ffa5183f40..b824115b28 100644 --- a/src/Framework/Framework/Controls/Validator.cs +++ b/src/Framework/Framework/Controls/Validator.cs @@ -99,7 +99,15 @@ private static void AddValidatedValue(IHtmlWriter writer, IDotvvmRequestContext } else { - throw new DotvvmControlException($"Could not resolve {nameof(ValueProperty)} to a valid value binding."); + // Note: ValueProperty can sometimes contain null (BusinessPack depends on this behaviour) + // However, it certainly should not contain hard-coded values + + var valueRaw = control.GetValueRaw(ValueProperty); + if (valueRaw != null) + { + // There is a hard-coded value in the ValueProperty + throw new DotvvmControlException($"{nameof(ValueProperty)} can not contain a hard-coded value."); + } } // render options diff --git a/src/Framework/Framework/ViewModel/Serialization/ViewModelTypeMetadataSerializer.cs b/src/Framework/Framework/ViewModel/Serialization/ViewModelTypeMetadataSerializer.cs index 270b567537..3cc4fc524e 100644 --- a/src/Framework/Framework/ViewModel/Serialization/ViewModelTypeMetadataSerializer.cs +++ b/src/Framework/Framework/ViewModel/Serialization/ViewModelTypeMetadataSerializer.cs @@ -86,7 +86,7 @@ private JObject GetEnumTypeMetadataCopy(Type type) private ObjectMetadataWithDependencies GetObjectTypeMetadataCopy(ViewModelSerializationMap map) { var key = new ViewModelSerializationMapWithCulture(map, CultureInfo.CurrentUICulture.Name); - var obj = cachedObjectMetadata.GetOrAdd(key, BuildObjectTypeMetadata(map)); + var obj = cachedObjectMetadata.GetOrAdd(key, _ => BuildObjectTypeMetadata(map)); return new ObjectMetadataWithDependencies((JObject)obj.Metadata.DeepClone(), obj.DependentObjectTypes, obj.DependentEnumTypes); }