Backport upstream patch for ruby32 wrt method reference changes

This commit is contained in:
Mamoru TASAKA 2022-10-03 22:37:23 +09:00
parent e0d9afcb63
commit 2d7218ef19
2 changed files with 81 additions and 2 deletions

View File

@ -0,0 +1,71 @@
From 363c1e4a56f53ba3dbd00d50889250ab24f005a8 Mon Sep 17 00:00:00 2001
From: Benoit Daloze <eregontp@gmail.com>
Date: Thu, 21 Apr 2022 16:10:58 +0200
Subject: [PATCH] Use a better and more reliable check for whether a method is
the same as Class#new
* See https://bugs.ruby-lang.org/issues/18729#note-5
---
lib/rspec/mocks/method_reference.rb | 16 ++++++++++++++--
spec/rspec/mocks/partial_double_spec.rb | 18 ++++++++++++++++++
2 files changed, 32 insertions(+), 2 deletions(-)
diff --git a/lib/rspec/mocks/method_reference.rb b/lib/rspec/mocks/method_reference.rb
index 026c2c07d..276202563 100644
--- a/lib/rspec/mocks/method_reference.rb
+++ b/lib/rspec/mocks/method_reference.rb
@@ -185,11 +185,23 @@ class ClassNewMethodReference < ObjectMethodReference
def self.applies_to?(method_name)
return false unless method_name == :new
klass = yield
- return false unless klass.respond_to?(:new, true)
+ return false unless ::Class === klass && klass.respond_to?(:new, true)
# We only want to apply our special logic to normal `new` methods.
# Methods that the user has monkeyed with should be left as-is.
- ::RSpec::Support.method_handle_for(klass, :new).owner == ::Class
+ uses_class_new?(klass)
+ end
+
+ if RUBY_VERSION.to_i >= 3
+ CLASS_NEW = ::Class.singleton_class.instance_method(:new)
+
+ def self.uses_class_new?(klass)
+ ::RSpec::Support.method_handle_for(klass, :new) == CLASS_NEW.bind(klass)
+ end
+ else # Ruby 2's Method#== is too strict
+ def self.uses_class_new?(klass)
+ ::RSpec::Support.method_handle_for(klass, :new).owner == ::Class
+ end
end
def with_signature
diff --git a/spec/rspec/mocks/partial_double_spec.rb b/spec/rspec/mocks/partial_double_spec.rb
index 099b15517..ea327e101 100644
--- a/spec/rspec/mocks/partial_double_spec.rb
+++ b/spec/rspec/mocks/partial_double_spec.rb
@@ -622,6 +622,24 @@ class << self
end
end
+ context "on a class with a twice-aliased `new`" do
+ it 'uses the method signature from `#initialize` for arg verification' do
+ if RUBY_VERSION.to_i < 3
+ pending "Failing due to Ruby 2's Method#== being too strict"
+ end
+
+ subclass = Class.new(klass) do
+ class << self
+ alias_method :_new, :new
+ alias_method :new, :_new
+ end
+ end
+
+ prevents(/arguments/) { allow(subclass).to receive(:new).with(1) }
+ allow(subclass).to receive(:new).with(1, 2)
+ end
+ end
+
context 'on a class that has redefined `self.method`' do
it 'allows the stubbing of :new' do
subclass = Class.new(klass) do

View File

@ -3,7 +3,7 @@
%global rpmminorver .%(echo %preminorver | sed -e 's|^\\.\\.*||') %global rpmminorver .%(echo %preminorver | sed -e 's|^\\.\\.*||')
%global fullver %{majorver}%{?preminorver} %global fullver %{majorver}%{?preminorver}
%global fedorarel 1 %global fedorarel 2
%global gem_name rspec-mocks %global gem_name rspec-mocks
@ -14,7 +14,7 @@
Summary: RSpec's 'test double' framework (mocks and stubs) Summary: RSpec's 'test double' framework (mocks and stubs)
Name: rubygem-%{gem_name} Name: rubygem-%{gem_name}
Version: %{majorver} Version: %{majorver}
Release: %{?preminorver:0.}%{fedorarel}%{?preminorver:%{rpmminorver}}%{?dist}.1 Release: %{?preminorver:0.}%{fedorarel}%{?preminorver:%{rpmminorver}}%{?dist}
License: MIT License: MIT
URL: http://github.com/rspec/rspec-mocks URL: http://github.com/rspec/rspec-mocks
@ -23,6 +23,10 @@ Source0: https://rubygems.org/gems/%{gem_name}-%{fullver}.gem
Source1: rubygem-%{gem_name}-%{version}-full.tar.gz Source1: rubygem-%{gem_name}-%{version}-full.tar.gz
Source2: rspec-related-create-full-tarball.sh Source2: rspec-related-create-full-tarball.sh
# https://bugs.ruby-lang.org/issues/18729#note-5
# https://github.com/rspec/rspec-mocks/pull/1470
Patch1: %{name}-3.11.1-check_method_is_same_as_class_new.patch
#BuildRequires: ruby(release) #BuildRequires: ruby(release)
BuildRequires: rubygems-devel BuildRequires: rubygems-devel
%if %{without bootstrap} %if %{without bootstrap}
@ -54,6 +58,7 @@ This package contains documentation for %{name}.
gem unpack %{SOURCE0} gem unpack %{SOURCE0}
%setup -q -D -T -n %{gem_name}-%{version} -b 1 %setup -q -D -T -n %{gem_name}-%{version} -b 1
%patch1 -p1 -b .ruby32_new
# Cucumber 7 syntax change # Cucumber 7 syntax change
sed -i cucumber.yml -e "s|~@wip|not @wip|" sed -i cucumber.yml -e "s|~@wip|not @wip|"
@ -99,6 +104,9 @@ cucumber
%{gem_docdir} %{gem_docdir}
%changelog %changelog
* Mon Oct 3 2022 Mamoru TASAKA <mtasaka@fedoraproject.org> - 3.11.1-2
- Backport upstream patch for ruby32 wrt method reference changes
* Sat Jul 23 2022 Fedora Release Engineering <releng@fedoraproject.org> - 3.11.1-1.1 * Sat Jul 23 2022 Fedora Release Engineering <releng@fedoraproject.org> - 3.11.1-1.1
- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild - Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild