-
-
Notifications
You must be signed in to change notification settings - Fork 407
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
Deprecation warning handlers #65
Conversation
This should propose module names for this API |
I'd like to propose using dots to namespace deprecation ids, and allowing one to set levels for groups of related deprecations by specifying a substring of the path in So for example:
|
Why levels? Shouldn't specific warnings and deprecations be silenceable for during a section of code? Never mind, I didn't read all the way to the {id: ''} part |
As I mentioned over in I think "categories" of deprecations would be nice to have. That way I could selectively disable whole classes of deprecations as I am working through the upgrade process. Especially if I need to focus on time sensitive deprecations and defer more long range deprecations for later. My mental model looks like this, but I am sure there there are others. I would expect that every deprecation warning in the code base would be registered with at least 1 or more categories.
|
We have:
I am not crazy about adding four more levels of configuration and maintenance. I would like to consider how we can flag either a) the release a given thing is expected to be dropped in or b) the public/private nature of the API. In my mind these are coupled, since presuming we go with extended-support releases private API deprecations will be dropped on a minor release and public API deprecations only on majors. Having a way to include that expected removal release would be nice (though I'm sure sometimes the planned release would not pan out as expected). Basically I'd rather couple things to the release number than bike shed on when something is |
Number of categories is not so important I suppose. And if coupled to release version you could in theory even compute the relative urgency. The high order bit for me personally is the distinction between deprecation and SUGGESTION. A deprecation means some code or api is changing or being removed. Heads up! You could even be smart about with something like
That way if there is just one or a few places in the code base where that particular feature is used they could opt to refactor away. It might even serve as a powerful tool to assess whether I want to use a particular addon. The "suggestion" category is more nuanced. I would technically say it is not even a deprecation. But more like a warning when there is a particular code smell or known problematic code pattern. Like:
An example is the warning about mutating state within a As an app developer I might not actually care about the performance in some cases. Because if it works it works. But I really do care if the feature goes away and I need to consider upgrade path. |
👍 I Iike this a lot :) |
@mixonic I updated the RFC to use import statements... I think the actual issue/problem is to silence deprecations which are not relevant/important at the moment; since all deprecation messages should be addressed eventually. Having a possibility to silence specific deprecation messages using the API proposed by @bantic, is one way of dealing with deprecations. This could be useful in the Ember-Inspector where there might be the possibility to hide messages from a certain namespace ( Deciding which deprecation messages are important at the moment is crucial. One way could be to deprecate stuff as done now via
This would allow us to calculate the urgency of the hit deprecation. Say if Ember.js |
@pangratz Right. I actually think the removal version is more pertinent though.
Another valid It also seems to be agreed that there should be another level of logging for "urgent" deprecations, ones the break in the next release. I remain unsure this concept is practically useful (setting a flag that silenced all but urgent deprecations would seem to be an anti-pattern, setting up apps to continue to rely on a dead-end feature until the last minute), but I'm going to explore some options right now. |
Ok, like most things as soon as I thought we were done it became clear we had designed the wrong thing. It sounds like there are ambitious enough plans for the inspector that it requires more of a hook. You call: deprecate(
"some long and annoying message that is usually on a line alone",
condition,
{ id: 'view.some-thing', until: '3.0.0' }
); And Ember's test runner, or the inspector, or Ember-Data's test runner, or some addon @rwjblue cooks up can handle it like it chooses: import { registerDeprecationHandler } from "ember-debug";
registerDeprecationHandler((message, options, next) => {
if (nextVersion(options.until)) {
throw new Error(message);
}
next(...arguments);
}); The
This solution has the benefit of giving addon and app authors complete run-time control over how a deprecation is handled. And without needing to understand an overly complex log-level API. |
So I have about a handful of apps … when I upgrade to the current release we fix the deprecations. I tried an update from 1.11.3 to 1.12.1 today just to see if it was possible. Normally we don't merge in an updated version of Ember unless we actually fix the deprecations. This idea of silencing deprecations will help my team to upgrade then fix the deprecations. Some context: In one app, on the first page following login, there are 999+ messages in the console. And the console is not even usable. That is why we can't live with deprecations warnings. Who does development without a console? I do when I update Ember till I fix the deprecations. Literally, the volume of warnings I get is prohibitive toward merging in a current release - unless we can budget enough time to fix the code that we've been warned about. The updates from 1.10 to 1.11 took a week or two. So I'm at the point were I'd have to plan 4 weeks of work then 2 weeks of upgrades. So for kicks I tried a update from 1.12.1 to 1.13.2 including the stable 1.13.4 ember data and boom the app is broke, "Error: You can't call destroyElement on a view being destroyed" (our custom list views are broke we used I'll try the suggestion to redefine the methods as mentioned here http://discuss.emberjs.com/t/is-this-possible-to-turn-off-some-deprecations-warnings/8196/3 Just saying, I understand the deprecation warnings are important and that I should fix the issues raised. if I don't want to get left behind. But I can't have the warnings effectively disabling my console. Some how this looks appealing:
But seems silly to stick that in my application. I'll be very happy when I can set the log level and disable warnings that we can't afford to fix at the same time as upgrading or beta testing . Here is some more dialog https://twitter.com/ebryn/status/610997797530136576 "upgrading is easy" well the deprecations make it both easy and super hard it depends on how much code is in your project. |
@pixelhandler - I have felt this pain as well, and that is exactly what this RFC is trying to help us solve. Once we have the proper infrastructure in place, tooling will be able to selectively silence a blacklist or whitelist of "known" deprecations so that you can work through them (console clear) one at a time either via an Ember CLI addon (that I am working on) or via the Ember Inspector. I know these last round of deprecations (1.12 and 1.13) have been painful for folks (myself included), lets focus on making sure that we get the best API so that we can prevent it from happening again. |
@mixonic - I am 👍 on your latest proposal, this would allow maximum flexibility for tooling developers to fill the massive void that we have here at the moment. Tools like the inspector, or an ember-cli addon that helps manage deprecations can make much of the pain that @pixelhandler mentioned away. |
New RFC is in a PR pending review by @pangratz at https://github.com/pangratz/rfcs/pull/2. This PR should likely be renamed if/when it merges. |
@mixonic I very much like the newly proposed handler API 👏 . Having the |
@pangratz - I do not believe that the |
Ah, THAT helped a lot understanding the the reasoning behind it! Thank you sir. |
@rwjblue another thing that affects me regarding deprecations is that I get failures when I deploy using asset pipeline, precompiling fails for me (on 1.12.1)
I wonder how the deprecations break that, weird. So basically I can't merge an update to ember unless I fix all the deprecation warnings cause I can't precompile the assets for the apps. So can't deploy. |
Woah what is parsing stdout here? |
I'm not really sure what is going on with your precompilation process, but parsing stdout seems kinda bizarre. Happy to chat with you about it in slack when you have time. |
That seems like something an issue should be tracking. Maybe ember-rails or w/e the common library exists |
@rwjblue rake assets:precompile fails for me locally as well. It will be easier to fix the deprecation warning than to debug asset pipeline. I wonder if the ` back tics or curly braces in the warning have anything to do with it? oh well. |
@stefanpenner @rwjblue other deprecations like |
@pixelhandler - I am sorry you are having issues with template precompilation, but those issues are not really related to this RFC or deprecations in general. I would be more than happy to help you track things down in slack, but I'd like to keep this RFC on topic so we can fix the deprecation "spew" issue for folks... |
@rwjblue Ok I'll say it like this. How about SHUTTING OFF deprecations during template compilation too, please. |
@pixelhandler Again, that would be implementable by a consumer of the API described in this RFC, such as Ember-CLI. Compile time deprecations are incredibly useful, as they can provide very specific location information about where the legacy usage is found. Those deprecations still follow the code-path of any deprecation though, and could be handled as this RFC describes. |
@mixonic what is the benefit for deprecations during compilation of templates? for me it breaks the build depending on the deprecation message, e.g. maybe having back tics or curly braces - or something like that. We have a core lib with templates that need to be compiled and various apps that need to be compiled too. I'm not sure that a consumer API will actually handle that. For example the barber gem handles precompiling with asset pipeline (I think). So I would need a way for the barber gem to use the template compiler to also consume this consumer API. I think the issues I have are relevant to the motivation - the need to change how deprecations are handled. @rwjblue asked to to comment on this RFC so I did, hope it helps. |
This is a bug, plain and simple. I pinged you on a related issue in ember-rails (emberjs/ember-rails#479), and have potentially tracked down where it is happening.
Because we can tell you everything that you are using that is deprecated, as opposed to doing it at runtime where you will only see deprecations for the sections of templates that you happen to test (many people do not have 100% template test coverage for example). We can also give you the specific filename, line, and column of each deprecation which is not possible after precompilation (because the compiled templates do not retain source information). The difference is basically
Barber can plug into the tooling API that we are setting up here just as easily as ember-cli.
Without a doubt, but the fact that it just blows up is a bug and should definitely be fixed. This RFC is about making it possible to deal with deprecations in piecemeal fashion. We definitely do not need an RFC for new public API to fix a straight up bug in template compilation. |
@rwjblue @mixonic This is an RFC, sorry my comments include issues, from my perspective it was those issues that motivated me to comment here so the future would be brighter and maybe less gloomy than the present. So here is my comment... (or story if you will) As a developer I want to configure the deprecation warnings and have the ability to set when the deprecations are fired, either at runtime or compile time, so that I have the flexibly to deploy my applications without chasing bugs resulting from the deprecation warnings. I want the ambitions apps built with ember also to be sustainable with ember. ;) Hope the above comments are received here on this topic. That is my comment on what I think is needed for handing deprecations warnings. I will be happy to take the rest of any issue followup elsewhere. |
|
||
# Summary | ||
|
||
Deprecations and warnings in Ember.js should have configurable runtime handlers. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest also configurable compile time handlers too.
@pixelhandler - I hope that you have not taken my replies as negative or discouraging, as I mentioned earlier I want to make sure that the actual proposed API here can be used to solve the real problems that you have been describing. We absolutely appreciate your comments, and are definitely thinking of these exact scenarios you have been detailing when we decided to work on this proposal. |
@rwjblue it's all good, thanks for the dialog. After some research I think I found the perfect build scenario #trollo |
I've added a note about the meaning of "runtime" in this document. The suggested API should be viable for template-compile-time warnings and deprecations. I consider this vaguely +1 by core, but will add it to this week's agenda for a final 👍. If there are remaining concerns, please raise them! |
Merged! About a million years ago, several folks including @pangratz @bantic and @rwjblue offered to implement this feature. If anyone would like to dive in, I'm happy to provide context and do reviews along the way. Additionally, @rwjblue has suggested that this API could be back-ported to 1.13 (via overwriting Ember's deprecate function on the global namespace) and used by addons and tooling during the 1.13 -> 2.0 transition. |
Fixes an issue introduced by #11419 where the evaluation of `ENV.RAISE_ON_DEPRECATION` was moved to boot-time rather than run-time. Previously, it was possible to set `RAISE_ON_DEPRECATION` to true midway through running an app, and all deprecations after that would throw because `Ember.deprecate` would check the value of the env variable every time it was called. The code in #11419 changed to a [one-time evaulation at boot-time](https://github.com/emberjs/ember.js/blob/master/packages/ember-debug/lib/main.js#L279-L281), breaking that original behavior. This commit restores the old behavior while still allowing changing deprecation behavior for specific deprecations by id.
Just a little follow-up on this RFC:
|
[ember-debug-handlers-polyfill](https://github.com/ember-polyfills/ember-debug-handlers-polyfill) provides an implementation of [emberjs/rfcs#65](https://github.com/emberjs/rfcs/blob/master/text/0065-deprecation-warning-handlers.md) (added to Ember in [emberjs/ember.js#11833](emberjs/ember.js#11833) and released in Ember v2.1.0) that can be used with versions of Ember prior to v2.1.0.
[ember-debug-handlers-polyfill](https://github.com/ember-polyfills/ember-debug-handlers-polyfill) provides an implementation of [emberjs/rfcs#65](https://github.com/emberjs/rfcs/blob/master/text/0065-deprecation-warning-handlers.md) (added to Ember in [emberjs/ember.js#11833](emberjs/ember.js#11833) and released in Ember v2.1.0) that can be used with versions of Ember prior to v2.1.0.
Rendered