FEATURE: Improved deprecation warnings (#6722)
* FEATURE: Discourse.deprecate can report version * Ember counterpart for deprecation
This commit is contained in:
parent
1d649e147b
commit
7ec124fc89
|
@ -1,3 +1,15 @@
|
||||||
export default function deprecated(msg) {
|
export default function deprecated(msg, opts = {}) {
|
||||||
console.warn(`DEPRECATION: ${msg}`); // eslint-disable-line no-console
|
msg = ["Deprecation notice:", msg];
|
||||||
|
if (opts.since) {
|
||||||
|
msg.push(`(deprecated since Discourse ${opts.since})`);
|
||||||
|
}
|
||||||
|
if (opts.dropFrom) {
|
||||||
|
msg.push(`(removal in Discourse ${opts.dropFrom})`);
|
||||||
|
}
|
||||||
|
msg = msg.join(" ");
|
||||||
|
|
||||||
|
if (opts.raiseError) {
|
||||||
|
throw msg;
|
||||||
|
}
|
||||||
|
console.warn(msg); // eslint-disable-line no-console
|
||||||
}
|
}
|
||||||
|
|
|
@ -602,9 +602,18 @@ module Discourse
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.deprecate(warning)
|
def self.deprecate(warning, drop_from: nil, since: nil, raise_error: false)
|
||||||
location = caller_locations[1]
|
location = caller_locations[1].yield_self { |l| "#{l.path}:#{l.lineno}:in \`#{l.label}\`" }
|
||||||
warning = "Deprecation Notice: #{warning}\nAt: #{location.label} #{location.path}:#{location.lineno}"
|
warning = ["Deprecation notice:", warning]
|
||||||
|
warning << "(deprecated since Discourse #{since})" if since
|
||||||
|
warning << "(removal in Discourse #{drop_from})" if drop_from
|
||||||
|
warning << "\nAt #{location}"
|
||||||
|
warning = warning.join(" ")
|
||||||
|
|
||||||
|
if raise_error
|
||||||
|
raise Deprecation.new(warning)
|
||||||
|
end
|
||||||
|
|
||||||
if Rails.env == "development"
|
if Rails.env == "development"
|
||||||
STDERR.puts(warning)
|
STDERR.puts(warning)
|
||||||
end
|
end
|
||||||
|
|
|
@ -300,6 +300,24 @@ describe Discourse do
|
||||||
|
|
||||||
expect(Rails.logger.warnings).to eq([old_method_caller(k)])
|
expect(Rails.logger.warnings).to eq([old_method_caller(k)])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'can report the deprecated version' do
|
||||||
|
Discourse.deprecate(SecureRandom.hex, since: "2.1.0.beta1")
|
||||||
|
|
||||||
|
expect(Rails.logger.warnings[0]).to include("(deprecated since Discourse 2.1.0.beta1)")
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'can report the drop version' do
|
||||||
|
Discourse.deprecate(SecureRandom.hex, drop_from: "2.3.0")
|
||||||
|
|
||||||
|
expect(Rails.logger.warnings[0]).to include("(removal in Discourse 2.3.0)")
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'can raise deprecation error' do
|
||||||
|
expect {
|
||||||
|
Discourse.deprecate(SecureRandom.hex, raise_error: true)
|
||||||
|
}.to raise_error(Discourse::Deprecation)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue