-
-
Notifications
You must be signed in to change notification settings - Fork 154
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Drop unsupported frameworks #784
Comments
Technically if you're looking to drop all unsupported frameworks, |
As someone who needs to support out of date framework versions, I totally get your pain, and understand the need to move forward. However as we can't drop out of support frameworks, that gives us a hard ceiling of where we can update to, and may mean we need to fork verify longer term or look for alternatives. Not saying you shouldn't do it obviously, just our position. That said, I think we're way behind on updates as IIRC we ran into too many breaking changes in earlier versions that couldn't be easily resolved (as dependency related) so may never make it up to date anyway 😅 |
My personal opinion, though it may be unpopular -- It is the responsibility of downstream software projects to update their frameworks if they want their software to move forward in time. Not undertaking this work is like freezing the project in time; your available options also may be frozen in time. I think there are 3 categories/themes:
The communication challenge comes when projects aren't clear about (or don't know) which bucket they're in. But regardless -- in my opinion these projects are chaining themselves to a baseline that lives in the past. The implicit trade-off there, IMO, is that these projects don't also get to use the latest and greatest things from the future. I wouldn't be able to get digital audio out of an old sound blaster card; I don't get 4K video from a graphics card that is 10 years old; I don't get to take advantage of multi-threading on a single core CPU. People respect the physical limitations of hardware but don't always translate that into the world of software where it seems like anything should be possible (and is -- if maintainers wreck themselves for it.) So in summary: do what works for you to help you be productive for those who are on the same timeline as you and not anchored to a past timeline. Maybe they'll move on from your tool, maybe they'll be upset. That's their prerogative. But I hope these points can help you frame that discussion when it comes up. Side thought: maybe if enough OSS projects can frame the conversation this way, the ecosystem-wide message will be driven home. And for those projects truly stuck in that second box of being unable to move forward, maybe the community or MS can step in in other ways to help them with that. |
I would update the project to v20, as a major version, and then support only .NET 6+. |
while i would like to. i think some period of grace is fair |
I would really prefer no one need to do this
are there any breaking change i need to do a better job of explaining? or writing better upgrade guides? do u need help upgrading? we could jump on a call, or if u need some more dedicated time, i could do a short term contract to do the upgrade for you.
|
as much as i would like to, i think it is a bit soon. I even work on a project that cant move off net48 because it targets on prem sharepoint |
@SimonCropp wrote:
That's 100% fair. I was being a bit pedantic is all. |
FWIW roslyn libraries (analyzers, source generators etc) are told to use NetStandard 2.0 (https://learn.microsoft.com/en-us/dotnet/csharp/roslyn-sdk/source-generators-overview#get-started-with-source-generators for example) This doesn't really affect the test libraries, as they can still be on current frameworks, but still, it's an odd case where MS still recommends using an old target framework. |
This would be bad news for Sentry which has the philosophy 'compatibility is king'. So far we managed to build (since 2018) with net461 and ns2.0 as a baseline, while adding new things. Verify was added (thanks for the contribution Simon) but we certainly can't drop all unsupported tfs because of it. Hope you can consider keeping them for longer. |
I think that the reason that |
but do you use Verify with either of those targets? |
I have several semi-alternative suggestions:
|
The whole point of having multiple branches is saying no to porting features, meaning almost all further work would happen on the mainline supporting net6+ only, and only the relatively small and less frequent security/bug fixes are back ported. If consuming projects are stuck on older frameworks then that generally means they are in maintenance mode and their users just need something to keep working the same as before, and just need security fixes. If they are not going to update their frameworks then why would they substantially need to update anything else, besides for security? So my suggestion minimizes how much actual work you have to do while letting you keep moving forward, and without abandoning any current users on older frameworks who need this to just keep working as well as before and securely. |
Speaking for myself personally, all .NET projects I create or maintain these days, which are relatively new, use only net6+, which is the best for combining the maximum feature set with cross-platform portability. |
Me too, obviously! 😄
I must have been mis-remembering the issue. I thought that you updated a reference to one of the
The trouble is, we (Datadog .NET Tracer team) produce a library that our customers consume. That means we can only upgrade as fast as they do.
We obviously also need to test against those frameworks (we actually test Obviously, we are a special case in many ways (sounds like Sentry may be similar) so I totally understand that you can't keep the ancient stuff around forever. It just means we'll either need to stick to old versions, which is fine generally IMO. The issue comes if we run into a bug we can't workaround. At that point we'd have to look into forking/alternatives. To be clear, I'm very much not suggesting you should keep support for older versions. I think it's actually libraries like Verify that have the power to drive the ecosystem forward as you can potentially force the laggards forward. And there's certainly precedent with how aggressively Microsoft are dropping older TFMs in their newer NuGet packages. Just know that "library vendors" don't fall neatly into the categories that Sean outlined - our customers do, but we can't upgrade even though we would love to. |
The suggestion I made before I can make to any library vendor, which is branch your library. The consumers who want most of the latest features update to net6+, and those who don't want to update can get an LTS branch which has the backwards compatibility and has updates limited to security fixes. I am also a library vendor, but because it is new libraries I am starting with net6+ as the base requirement, assuming that the majority of the time anyone who would adopt these new libraries would do so in a project that is either new or that has been uplifted to net6. And if I decided there was the market for supporting older .NET versions, I would do so as a second parallel version while keeping the mainline requiring relatively new .NET versions. I feel this is the best way for me to keep up to date and have older system support, which is exactly 2 and not more parallel versions optimized for those use cases. |
Ok. given the feedback in this issue (and directly to me), i am going to put this on hold for 6 months and then revisit. Thank you everyone for the feedback |
@bruno-garcia - Sentry wouldn't be impacted by this change. It doesn't affect which frameworks Sentry can use. But rather it only affects which frameworks Sentry's test projects can target - which currently are Also, just a note about running tests on .NET Framework targets - the target version actually only controls the SDK that's used to compile the test app - not the runtime that the tests run under. For example, if you make a test project targeting Similarly on Mac and Linux, it doesn't matter what framework version you target, the tests will run on whatever version of the Mono runtime installed on the machine. In other words, just because a library targets Contrast that with .NET Core and modern .NET. If you build a test project targeting This is why with Sentry, we're testing |
The more interesting discussion IMHO is |
@mattjohnsonpint yeah i left netcoreapp3.1 in there for that reason. i removed net5.0 since moving to net6 is pretty trivial |
so this is the approach you are using to test on .NET 461? |
Yeah exactly. We're targeting |
.NET Standard 2.0 is still pretty widely used - we use Verify in several Akka.NET projects that target .NET Standard 2.0. We're trying to work on dropping .NET Standard 2.0 support ourselves but it's taking a while to get our enterprise users to make the jump with us without a sufficiently large carrot on the end of the stick. |
@Aaronontheweb - Sure, but only the targets used by the test projects are relevant here. From Akka.API.Tests.csproj: <PropertyGroup>
<TargetFrameworks>$(NetFrameworkTestVersion);$(NetTestVersion);$(NetCoreTestVersion)</TargetFrameworks>
</PropertyGroup> From common.props: <NetCoreTestVersion>netcoreapp3.1</NetCoreTestVersion>
<NetTestVersion>net7.0</NetTestVersion>
<NetFrameworkTestVersion>net471</NetFrameworkTestVersion> So Verify could either target only |
@Aaronontheweb yeah i have already decided to put this on hold for for at least 6 months. i added an "Update" to the issue to clarify for the next person. but i think @mattjohnsonpint makes a valid point. although it is technically possible to "run only on netstandard" (i learned this last week), i dont think anyone does this. so in this context, only the top level targets u use for testing are relevant? or am i missing something? |
It's true, it's definitely better, I just still don't like it 😉 IMO if your package doesn't "support" netstandard2.0, it shouldn't target netstandard2.0. I realise there's subtelties, and this is as much a NuGet issue, but IMO it just makes an (already complex) thing even harder for anyone to understand.
In terms of "my concerns", if you're referring to my initial comment, then no, there's no solution, as I need to support EOL frameworks, so there's no solution forward there for me. If you're referring to the issue of |
Sorry for my ambiguous question. I meant the latter, yes.
By doing that, component authors would lock out customers that target netstandard2.0 but then run on a supported runtime. netstandard2.0 is one of the most popular target frameworks as it supports both .NET Framework and modern .NET and offers a large API set. By dropping support for targeting netstandard2.0 we would disrupt the entire .NET ecosystem. We talked about this internally (in the .NET team) and agreed upon that we aren't even near the point where dropping netstandard2.0 is appropriate. |
I wonder if anyone has proposed new TFMs to address this? Something like |
For business reasons, I can't release exact counts. However, I can release percentages: That reflects the runtime version of events we've received from our customers over the last 3 months. For .NET Framework, the version is the installed runtime where the app is executing, not the target version used at compile time. Likewise, I can't tell you how many of those are targeting .NET Standard. We'd have to collect values from The chart on the right is classifying .NET 6, 7, 8 and .NET Framework 4.6.2+ as supported, and everything else as unsupported. |
FYI, there's a few errors in that data I need to clean up. Also it does get better over time if I break it down version by version of our library. As we get to newer versions of our library, we find those that are on unsupported drops considerably. Specifically, I find that if I look at all versions, we have about 30% unsupported runtimes still in use. But remove versions of our library over a year old, it drops to about 16% on unsupported runtimes. If I go even further and remove versions more than 3 months old, it drops to 10%. I take away from this that those who choose to upgrade regularly, tend to stay on supported runtimes also. Those who choose to run on unsupported runtimes tend to be the same who don't update their libraries regularly anyway. I need to write a blog post to cover all the data and interpretation. There's too much to just dump it here. 😅 |
note that xunit.runner.visualstudio has dropped netcore3.1 support. moving to a min of net6 |
@SimonCropp do you have an update to share around the TFM deprecation plan for Verify? Just curious what your current thinking is on that. |
@ViktorHofer my current plan it re-evaluate in Jan 2024. |
In my case, tests are always running against the latest version of .NET (7.0 as of today) except a few projects where I test against legacy .NET Fx as well (usually when there's a lot of complex polyfilling in the project). So for me, and I imagine many other people, legacy .NET Fx is the primary anchor. I don't care about .NET Standard or older versions of .NET Core. That said, if libraries start a trend of dropping .NET Fx support completely, I will drop it from my libraries too, because the only reason I have it in the first place is because the effort it takes to maintain those targets is not too high currently. If I have to start pinning dependencies, I'd just drop .NET Fx support instead. I long for the day where we can all forget .NET Fx ever existed. |
@andrewlock @bruno-garcia @ViktorHofer any chance of Datadog, Sentry, or Microsoft sponsoring Verify? |
@SimonCropp do you see any chance to revisit set of supported .NET Framework versions? .NET Framework 4.6.2 will be supported till Jan 12,2027. It is the version supported also by OpenTelemetry (Automatic Instrumentation). The agreement on OTel side was to support all versions supported by Microsoft. Sorry for reopening topic post/merge release, but it was detected yesterday after debendabot opened this PR. |
@Kielek what is stopping you from updating to net472? |
OTel AutoInstrumentation can be used without code/build changes. It can be injected to .NET (Framework) process by env. variables. What is more OTel .NET SDK/API is also supporting all officially supported .NET versions.
|
Note that xunit will only support net472 and above as well: https://xunit.net/docs/v3-alpha. There are reasons why people drop support for older .NET Framework versions, even if they are officially still in support. I.e. issues with .NET Standard compatibility, limited API set, etc. |
@Kielek regarding the point by @ViktorHofer will you be moving off xunit when it drops net462? |
I do not have a clear answer for this. It depends on timeline of releasing xunit.v3 (based on what I see, it is in alpha stage). If drop support for net462 became a fact before official MS EOL we will probably stick with 2.* version. We will do the same probably with Verify, as long as there will be no information about security issues in dependencies/Verify itself. |
@Kielek would splunk consider consider supporting financially? so it is worth my time to keep net462 ? |
Unfortunately, I can't speak to that. We do have the FOSS program. Microsoft employees select open source projects to sponsor. Aside from, I don't know about other potentials. cc @jeffwilcox |
@SimonCropp, I am not in the position to make a response in the name of Splunk. Your support by bringing back .NET Fx 4.6.2 support is to support open source project, not the particular corporate. I can help you with creating PR which brings back support for .NET Framework 4.6.2. |
@Kielek given net462 was released in 2016, i think 7 years is enough time to expect people to upgrade. if OpenTelemetry is fully OSS, and has no monetary incentive, i suggest you also drop support for anything below net48 |
I nominated Verify and Polyfil, looks like it went through: Not sure about the amounts, Sentry I believe the blog post announcing this years sponsorship program is in the works. Btw sorry for the late replies, I skim GH notifications every few months these days |
Sponsorship program isn't done yet, it's tracked here: getsentry/team-ospo#108 |
@bruno-garcia thanks |
Drop
And only support
The text was updated successfully, but these errors were encountered: