DotVVM v2.5.0 Release Notes
Release Date: 2020-10-31 // almost 4 years ago-
๐ This release includes all changes from DotVVM 2.5 Preview 2, as well as a few additional improvements:
๐ Features
- ๐ #880 - Inline editing is now supported in nested
GridView
controls - 0๏ธโฃ #890 - DotVVM uses its own
JsonSerializerSettings
and doesn't rely onDefaultSettings
- #877 - Control developers now may create attached property groups (e. g.
<element MyExtensions.SomeGroup-SomeKey="something" />
) - 0๏ธโฃ #896 - The
AddDotVVM
andUseDotVVM
methods now allow passing a custom instance of theDotvvmStartup
class so it is possible to set its properties and so on. If you plan to use this feature, we recommend keeping a default constructor - otherwise, the DotVVM Compiler (used by the Visual Studio extension) will be unable to create the instance of this class.
๐ Fixes
- ๐ Fixed references to
netstandard
in view compilation - these didn't work on older versions of .NET Framework. - ๐ Fixed deadlock occurring on the first HTTP request on OWIN.
- ๐ Fixed incorrect invocation of the
beforePostback
event on static commands.
โจ Enhancements for framework developers
- โ #874 - Infrastructure for end-to-end testing without the need of using Selenium.
- ๐ All paths are using forward slashes so everything in the repo should work on non-Windows machines.
- ๐ #880 - Inline editing is now supported in nested
Previous changes from v2.5.0-preview02
-
๐ New Features
Experimental: Explicit assembly loading
Until now, DotVVM was searching all assemblies referenced by the application (including transitive references) to be able to find attached properties of controls (which may be declared in a different assembly than the controls),
@import
namespaces and other types. This was causing longer startup times as all assemblies were being searched.We've introduced the explicit assembly loading mode that loads and searches only the assemblies that you list explicitly in
DotvvmStartup
:config.Markup.Assemblies.Add("assemblyName");
This feature is experimental and must be turned on:
config.ExperimentalFeatures.ExplicitAssemblyLoading.Enable();
๐ We expect this feature to help a lot especially in the Web Forms modernization story - many legacy applications have unused references that are not even present in the
bin
directory. Without this feature, DotVVM was forcing the developers to fix all these issues first, which hurts the experience with getting DotVVM running.Redirection Helpers in the Route table
(#858)
We've added
AddUrlRedirection
andAddRouteRedirection
in the DotVVM route table to simplify creating URLs that redirect to another place.It can be used e. g. for preserving old links when you need to change the URL for your pages.
You can now register these old routes like this:// redirect from "article/15" to "content/article/15" config.RouteTable.AddUrlRedirection("ArticleRedirection", "article/{id}", c => "content/article/" + c.Parameters["id"]); // redirect from "calendar" to "calendar/{DateTime.Now.Year}/{DateTime.Now.Month}" config.RouteTable.Add("Calendar", "calendar/{year}/{month}", "Views/Calendar.dothtml"); config.RouteTable.AddRouteRedirection("CalendarRedirection", "calendar", "Calendar", parametersProvider: (context) => { var now = DateTime.Now; return new Dictionary<string, object>() { { "year", now.Year }, { "month", now.Month }, }; });
View compilation on startup or on background
Until now, all DotHTML files (views, master pages, and user controls) were compiled to their C# representation on the first HTTP request that needed them. Because of this, the first load of every DotVVM page took longer.
We've added two new options:
DuringApplicationStart
- this mode compiles all views and delays the startup of the application until the compilation is finished. The first HTTP request will be handled after all views have been compiled. This option is meant for production scenarios where you are using deployment slots (which will be switched once the application starts responding), or where downtime of a minute or two is not an issue.- ๐
AfterApplicationStart
- this mode doesn't delay the startup of the application but compiles all views on a background thread. It is possible to set a delay (configuration.Markup.ViewCompilation.BackgroundCompilationDelay
) so it doesn't stress the CPU when other app initialization (populating caches etc.) tasks may be in progress. This option is great for applications that prioritize the page load time and have enough compute power so the background compilation won't affect the overall server performance.
0๏ธโฃ For development scenarios, we recommend sticking to the default
Lazy
mode as it doesn't slow down the application startup and compiles only the views that are actually needed (in the typical dev loop, the developer is not working with all pages of the app at the same time).โฌ๏ธ REST API bindings upgraded to latest Swashbuckle.AspNetCore
(#855)
๐ ASP.NET Core 3.0 introduced the new
System.Text.Json
serializer that replacedNewtonsoft.Json
. This, and other changes, affected ourSwashbuckle
extensions for REST API bindings that helped DotVVM to generate better API clients based on Swagger / Open API metadata.๐ฆ The
DotVVM.Api.Swashbuckle.AspNetCore
package now referencesSwashbuckle.AspNetCore 5.4.1
which works with both ASP.NET Core 2.x and 3.x.๐ If the API consumed by DotVVM app is hosted in ASP.NET Core 2.x, or if it explicitly uses the
Newtonsoft.Json
serializer in 3.x, you'll need to installSwashbuckle.AspNetCore.NewtonsoftJson
package as well - otherwise the Open API metadata are not generated correctly.
๐ See the Swashbuckle 5.x release notes for more details.ValidationSummary improvement
- ๐
#838 The
ValidationSummary
control has now a new propertyHideWhenValid
that can hide the entire<ul>
element when no errors are present. It helps when you need to apply styles like padding or border on the<ul>
element.
CancellationToken
- ๐ป #857 We've added the
Context.GetCancellationToken()
which returns the request cancellation token. You can pass this token to async methods if you expect they'll take long - it will allow them to cancel the operation if the user cancels the HTTP request (e. g. by refreshing the page or closing the browser).
๐ Startup performance tool
- ๐ #851 We've created a command-line tool that helps with measuring the startup performance of (not only DotVVM) ASP.NET web apps. It is not very sophisticated, but it is easy to use.
It can be used like this:
DotVVM.Tools.StartupPerfTester.exe Path/To/The/MyApp.csproj -t owin|aspnetcore --verbose --repeat 10
๐ The tool will publish the project in Release mode and try to run it 10 times while measuring the time until the app responds to the first HTTP request.
Other small improvements
- #819 Added
AddRequiredResource
method toResourceManager
to allow adding any kinds of resources to the current page. - ๐ง #789 and #826 We've done some improvements of build and testing scenarios for developers who work with the DotVVM repo on Linux.
๐ Fixes
ViewModel Serialization
- ๐ #871 Until now, DotVVM didn't support nesting
[Protect]
attributes in the viewmodels. If you used the[Protect]
attribute on a complex object or array in the viewmodel, and the attribute was used inside too, DotVVM didn't serialize the viewmodel correctly. We've redesigned parts of the serializer so the nesting is now supported. There are some restrictions - basically, the protection is additive: if you protect the parent object e.g. bySignData
, the child cannot useNone
on any of its members. Also, if you useEncryptData
, the child object cannot use justSignData
. - ๐ #853 We've fixed serialization of
KeyValuePair
in viewmodels.
Race conditions and problems in the postback pipeline
- ๐ฆ #816 We've fixed several bugs in the postback pipeline that caused freezing of the page or skipping some postbacks, especially when using
PostBack.Concurrency="Queue"
. The issue was happening when multiple postbacks were invoked quickly (e. g. triggered by the incoming SignalR messages). - ๐ #816 When the client received the Redirect response from the server, the next postbacks from the queue were still being sent which could lead to unexpected behavior. We've fixed the issue so now when the client gets redirect response, subsequent postbacks in the queue are discarded. It was causing issues, especially in SPAs when the postback responses could arrive even after another page was loaded.
- #860 Another PR related to cleaning up the postback queues in SPA apps.
- ๐ #876 When the user navigated to another page in SPA and then triggered a postback, it canceled the SPA navigation and the page may stop working. We've fixed this so all postbacks during SPA navigation are ignored. In case the SPA navigation fails, the postbacks start working again so the user is able to repeat the action and continue using the old page.
DotVVM for Visual Studio compatibility issues
- #818 Cleaned the DotvvmConfiguration JSON representation (getting rid of freezable collection wrappers) to fix the behavior of the VS extension.
- ๐ #822 We've fixed several issues in the binding expression parser so IntelliSense now works better in the VS extension.
- #824 Added the
[PropertyGroup]
attribute (for properties likeclass-*
orParam-*
) that easies the discovery of the property groups for the VS extension IntelliSense.
Binding expression cache on OWIN
- ๐ #805 We've implemented a custom LRU (least recently used) cache for binding expressions that replaces the
System.Web.Caching.Cache
on OWIN. This fixes a memory leak that occurred in applications that generated a lot of binding expressions dynamically (e. g. by using DotVVM Dynamic Data). A temporary solution was to useConcurrentDictionary
-based cache, but this approach couldn't release unused bindings that weren't needed anymore.
Other issues
- ๐ #856 Fixed
NullReferenceException
when calling task-based methods withoutasync/await
statement. - ๐ #804 We've fixed passing non-primitive command arguments to methods (it was affecting mostly the
staticCommand
calls). - ๐ #859 Fixed the dependency cycle detection in the registration of resources in
DotvvmStartup
.