mirror of
https://github.com/lostisland/faraday.git
synced 2025-07-26 00:02:15 -04:00
Compare commits
4 Commits
824423ccbb
...
71dcb9cbc5
Author | SHA1 | Date | |
---|---|---|---|
|
71dcb9cbc5 | ||
|
6e5403613a | ||
|
eba6cd906a | ||
|
84eb2538e0 |
@ -12,6 +12,8 @@ AllCops:
|
|||||||
|
|
||||||
Inclusivity/Race:
|
Inclusivity/Race:
|
||||||
Enabled: true
|
Enabled: true
|
||||||
|
Exclude:
|
||||||
|
- 'lib/faraday/adapter/typhoeus.rb'
|
||||||
|
|
||||||
Metrics/BlockLength:
|
Metrics/BlockLength:
|
||||||
Exclude:
|
Exclude:
|
||||||
@ -59,4 +61,3 @@ Style/IfUnlessModifier:
|
|||||||
|
|
||||||
Style/SlicingWithRange: # (0.83)
|
Style/SlicingWithRange: # (0.83)
|
||||||
Enabled: true
|
Enabled: true
|
||||||
|
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'faraday/deprecate'
|
||||||
|
|
||||||
module Faraday
|
module Faraday
|
||||||
# Connection objects manage the default properties and the middleware
|
# Connection objects manage the default properties and the middleware
|
||||||
# stack for fulfilling an HTTP request.
|
# stack for fulfilling an HTTP request.
|
||||||
@ -297,14 +299,12 @@ module Faraday
|
|||||||
#
|
#
|
||||||
# @return [void]
|
# @return [void]
|
||||||
def basic_auth(login, pass)
|
def basic_auth(login, pass)
|
||||||
warn <<~TEXT
|
|
||||||
WARNING: `Faraday::Connection#basic_auth` is deprecated; it will be removed in version 2.0.
|
|
||||||
While initializing your connection, use `#request(:basic_auth, ...)` instead.
|
|
||||||
See https://lostisland.github.io/faraday/middleware/authentication for more usage info.
|
|
||||||
TEXT
|
|
||||||
set_authorization_header(:basic_auth, login, pass)
|
set_authorization_header(:basic_auth, login, pass)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
extend Faraday::Deprecate
|
||||||
|
deprecate :basic_auth, '#request(:basic_auth, ...)', '2.0'
|
||||||
|
|
||||||
# Sets up the Authorization header with the given token.
|
# Sets up the Authorization header with the given token.
|
||||||
#
|
#
|
||||||
# @param token [String]
|
# @param token [String]
|
||||||
|
109
lib/faraday/deprecate.rb
Normal file
109
lib/faraday/deprecate.rb
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Faraday
|
||||||
|
# @param new_klass [Class] new Klass to use
|
||||||
|
#
|
||||||
|
# @return [Class] A modified version of new_klass that warns on
|
||||||
|
# usage about deprecation.
|
||||||
|
# @see Faraday::Deprecate
|
||||||
|
module DeprecatedClass
|
||||||
|
def self.proxy_class(origclass, ver = '1.0')
|
||||||
|
proxy = Class.new(origclass) do
|
||||||
|
const_set('ORIG_CLASS', origclass)
|
||||||
|
|
||||||
|
class << self
|
||||||
|
extend Faraday::Deprecate
|
||||||
|
|
||||||
|
def ===(other)
|
||||||
|
(superclass == const_get('ORIG_CLASS') && other.is_a?(superclass)) || super
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
proxy.singleton_class.send(:deprecate, :new, "#{origclass}.new", ver)
|
||||||
|
proxy.singleton_class.send(:deprecate, :inherited, origclass.name, ver)
|
||||||
|
proxy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Deprecation using semver instead of date, based on Gem::Deprecate
|
||||||
|
# Provides a single method +deprecate+ to be used to declare when
|
||||||
|
# something is going away.
|
||||||
|
#
|
||||||
|
# class Legacy
|
||||||
|
# def self.klass_method
|
||||||
|
# # ...
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# def instance_method
|
||||||
|
# # ...
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# extend Faraday::Deprecate
|
||||||
|
# deprecate :instance_method, "X.z", '1.0'
|
||||||
|
#
|
||||||
|
# class << self
|
||||||
|
# extend Faraday::Deprecate
|
||||||
|
# deprecate :klass_method, :none, '1.0'
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
module Deprecate
|
||||||
|
def self.skip # :nodoc:
|
||||||
|
@skip ||= begin
|
||||||
|
case ENV['FARADAY_DEPRECATE'].to_s.downcase
|
||||||
|
when '1', 'warn' then :warn
|
||||||
|
else :skip
|
||||||
|
end
|
||||||
|
end
|
||||||
|
@skip == :skip
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.skip=(value) # :nodoc:
|
||||||
|
@skip = value ? :skip : :warn
|
||||||
|
end
|
||||||
|
|
||||||
|
# Temporarily turn off warnings. Intended for tests only.
|
||||||
|
def skip_during
|
||||||
|
original = Faraday::Deprecate.skip
|
||||||
|
Faraday::Deprecate.skip = true
|
||||||
|
yield
|
||||||
|
ensure
|
||||||
|
Faraday::Deprecate.skip = original
|
||||||
|
end
|
||||||
|
|
||||||
|
# Simple deprecation method that deprecates +name+ by wrapping it up
|
||||||
|
# in a dummy method. It warns on each call to the dummy method
|
||||||
|
# telling the user of +repl+ (unless +repl+ is :none) and the
|
||||||
|
# semver that it is planned to go away.
|
||||||
|
# @param name [Symbol] the method symbol to deprecate
|
||||||
|
# @param repl [#to_s, :none] the replacement to use, when `:none` it will
|
||||||
|
# alert the user that no replacement is present.
|
||||||
|
# @param ver [String] the semver the method will be removed.
|
||||||
|
def deprecate(name, repl, ver)
|
||||||
|
class_eval do
|
||||||
|
gem_ver = Gem::Version.new(ver)
|
||||||
|
old = "_deprecated_#{name}"
|
||||||
|
alias_method old, name
|
||||||
|
define_method name do |*args, &block|
|
||||||
|
mod = is_a? Module
|
||||||
|
target = mod ? "#{self}." : "#{self.class}#"
|
||||||
|
target_message = if name == :inherited
|
||||||
|
"Inheriting #{self}"
|
||||||
|
else
|
||||||
|
"#{target}#{name}"
|
||||||
|
end
|
||||||
|
|
||||||
|
msg = [
|
||||||
|
"NOTE: #{target_message} is deprecated",
|
||||||
|
repl == :none ? ' with no replacement' : "; use #{repl} instead. ",
|
||||||
|
"It will be removed in or after version #{gem_ver}",
|
||||||
|
"\n#{target}#{name} called from #{Gem.location_of_caller.join(':')}"
|
||||||
|
]
|
||||||
|
warn "#{msg.join}." unless Faraday::Deprecate.skip
|
||||||
|
send old, *args, &block
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
module_function :deprecate, :skip_during
|
||||||
|
end
|
||||||
|
end
|
@ -1,5 +1,5 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module Faraday
|
module Faraday
|
||||||
VERSION = '1.10.0'
|
VERSION = '1.10.1'
|
||||||
end
|
end
|
||||||
|
147
spec/faraday/deprecate_spec.rb
Normal file
147
spec/faraday/deprecate_spec.rb
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
RSpec.describe Faraday::DeprecatedClass do
|
||||||
|
class SampleClass < StandardError
|
||||||
|
attr_accessor :foo
|
||||||
|
|
||||||
|
def initialize(foo = nil)
|
||||||
|
@foo = foo || :foo
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
SampleDeprecatedClass = Faraday::DeprecatedClass.proxy_class(SampleClass)
|
||||||
|
|
||||||
|
it 'does not raise error for deprecated classes but prints an error message' do
|
||||||
|
error_message, foobar = with_warn_squelching { SampleDeprecatedClass.new(:foo_bar) }
|
||||||
|
expect(foobar).to be_a(SampleClass)
|
||||||
|
expect(foobar.foo).to eq(:foo_bar)
|
||||||
|
expect(error_message).to match(
|
||||||
|
Regexp.new(
|
||||||
|
'NOTE: SampleDeprecatedClass.new is deprecated; '\
|
||||||
|
'use SampleClass.new instead. It will be removed in or after version 1.0'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'does not raise an error for inherited error-namespaced classes but prints an error message' do
|
||||||
|
error_message, = with_warn_squelching { Class.new(SampleDeprecatedClass) }
|
||||||
|
|
||||||
|
expect(error_message).to match(
|
||||||
|
Regexp.new(
|
||||||
|
'NOTE: Inheriting SampleDeprecatedClass is deprecated; '\
|
||||||
|
'use SampleClass instead. It will be removed in or after version 1.0'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'allows backward-compatible class to be subclassed' do
|
||||||
|
expect do
|
||||||
|
with_warn_squelching { Class.new(SampleDeprecatedClass) }
|
||||||
|
end.not_to raise_error
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'allows rescuing of a current error with a deprecated error' do
|
||||||
|
expect { raise SampleClass, nil }.to raise_error(SampleDeprecatedClass)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'allows rescuing of a current error with a current error' do
|
||||||
|
expect { raise SampleClass, nil }.to raise_error(SampleClass)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'allows rescuing of a deprecated error with a deprecated error' do
|
||||||
|
expect { raise SampleDeprecatedClass, nil }.to raise_error(SampleDeprecatedClass)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'allows rescuing of a deprecated error with a current error' do
|
||||||
|
expect { raise SampleDeprecatedClass, nil }.to raise_error(SampleClass)
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'match behavior' do
|
||||||
|
class SampleDeprecatedClassA < SampleDeprecatedClass; end
|
||||||
|
class SampleDeprecatedClassB < SampleDeprecatedClass; end
|
||||||
|
|
||||||
|
class SampleDeprecatedClassAX < SampleDeprecatedClassA; end
|
||||||
|
|
||||||
|
class SampleClassA < SampleClass; end
|
||||||
|
|
||||||
|
describe 'undeprecated class' do
|
||||||
|
it 'is === to instance of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClass.new.is_a?(SampleClass)).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassA.new.is_a?(SampleClass)).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of subclass of subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassAX.new.is_a?(SampleClass)).to be true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'subclass of undeprecated class' do
|
||||||
|
it 'is not === to instance of undeprecated class' do
|
||||||
|
expect(SampleClass.new.is_a?(SampleClassA)).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is not === to instance of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClass.new.is_a?(SampleClassA)).to be false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'deprecated class' do
|
||||||
|
it 'is === to instance of undeprecated class' do
|
||||||
|
expect(SampleDeprecatedClass.new.is_a?(SampleClass)).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of subclass of undeprecated class' do
|
||||||
|
expect(SampleClassA.superclass == SampleDeprecatedClass.superclass).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassA.new.is_a?(SampleDeprecatedClass)).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of subclass of subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassAX.new.is_a?(SampleDeprecatedClass)).to be true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'subclass of deprecated class' do
|
||||||
|
it 'is not === to instance of subclass of undeprecated class' do
|
||||||
|
expect(SampleClass.new.is_a?(SampleDeprecatedClassA)).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is not === to instance of another subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassB.new.is_a?(SampleDeprecatedClassA)).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of its subclass' do
|
||||||
|
expect(SampleDeprecatedClassAX.new.is_a?(SampleDeprecatedClassA)).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is === to instance of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassB.new.is_a?(SampleDeprecatedClass)).to be true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'subclass of subclass of deprecated class' do
|
||||||
|
it 'is not === to instance of subclass of another subclass of deprecated class' do
|
||||||
|
expect(SampleDeprecatedClassB.new.is_a?(SampleDeprecatedClassAX)).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'is not === to instance of its superclass' do
|
||||||
|
expect(SampleDeprecatedClass.new.is_a?(SampleDeprecatedClassA)).to be false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def with_warn_squelching
|
||||||
|
stderr_catcher = StringIO.new
|
||||||
|
original_stderr = $stderr
|
||||||
|
$stderr = stderr_catcher
|
||||||
|
result = yield if block_given?
|
||||||
|
[stderr_catcher.tap(&:rewind).string, result]
|
||||||
|
ensure
|
||||||
|
$stderr = original_stderr
|
||||||
|
end
|
||||||
|
end
|
@ -38,6 +38,8 @@ require 'pry'
|
|||||||
|
|
||||||
Dir['./spec/support/**/*.rb'].sort.each { |f| require f }
|
Dir['./spec/support/**/*.rb'].sort.each { |f| require f }
|
||||||
|
|
||||||
|
Faraday::Deprecate.skip = false
|
||||||
|
|
||||||
RSpec.configure do |config|
|
RSpec.configure do |config|
|
||||||
# rspec-expectations config goes here. You can use an alternate
|
# rspec-expectations config goes here. You can use an alternate
|
||||||
# assertion/expectation library such as wrong or the stdlib/minitest
|
# assertion/expectation library such as wrong or the stdlib/minitest
|
||||||
|
Loading…
x
Reference in New Issue
Block a user