From 7bf9d6051239a20fd3dd75a566c3a899a86f6269 Mon Sep 17 00:00:00 2001 From: Peter Wagner <1559510+thepwagner@users.noreply.github.com> Date: Wed, 24 Mar 2021 15:48:45 -0400 Subject: [PATCH 1/3] codify binding !=, and that development is inverted --- .../requirements_updater_spec.rb | 20 ++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb b/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb index d0ca3660ca..67058377fb 100644 --- a/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb +++ b/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb @@ -324,14 +324,14 @@ context "and one is a != requirement" do context "that is binding" do - let(:gemspec_requirement_string) { "~> 1.4, != 1.8.0" } + let(:gemspec_requirement_string) { "~> 1.4, != #{latest_version}" } its([:requirement]) { is_expected.to eq("~> 1.4") } end context "that is not binding" do - let(:gemspec_requirement_string) { "~> 1.4.0, != 1.5.0" } + let(:gemspec_requirement_string) { "~> 1.4, != #{latest_resolvable_version}" } its([:requirement]) do - is_expected.to eq(">= 1.4, != 1.5.0, < 1.9") + is_expected.to eq("~> 1.4, != #{latest_resolvable_version}") end end end @@ -400,6 +400,20 @@ context "when there are multiple requirements" do let(:gemspec_requirement_string) { "> 1.0.0, <= 1.4.0" } its([:requirement]) { is_expected.to eq("> 1.0.0, <= 1.9.0") } + + context "and one is a != requirement" do + context "that is binding" do + let(:gemspec_requirement_string) { "~> 1.4, != #{latest_resolvable_version}" } + its([:requirement]) { is_expected.to eq("~> 1.4") } + end + + context "that is not binding" do + let(:gemspec_requirement_string) { "~> 1.4, != #{latest_version}" } + its([:requirement]) do + is_expected.to eq("~> 1.4, != #{latest_version}") + end + end + end end context "when a beta version was used in the old requirement" do From a6a608b5609d91cffb6296d49e59e4b317df99b4 Mon Sep 17 00:00:00 2001 From: Peter Wagner <1559510+thepwagner@users.noreply.github.com> Date: Wed, 24 Mar 2021 15:53:27 -0400 Subject: [PATCH 2/3] failing test case for discussion --- .../bundler/update_checker/requirements_updater_spec.rb | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb b/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb index 67058377fb..31599d1df3 100644 --- a/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb +++ b/bundler/spec/dependabot/bundler/update_checker/requirements_updater_spec.rb @@ -335,6 +335,14 @@ end end end + + context "when latest version is denied" do + let(:latest_version) { "2.0.4" } + let(:latest_resolvable_version) { "2.0.3" } + let(:gemspec_requirement_string) { ">= 2.0.0, != 2.0.4" } + + its([:requirement]) { is_expected.to eq(">= 2.0.0, != 2.0.4") } + end end context "when a beta version was used in the old requirement" do From c434b25cf734f0f73bd2120da7e14be4fb56180a Mon Sep 17 00:00:00 2001 From: Peter Wagner <1559510+thepwagner@users.noreply.github.com> Date: Thu, 25 Mar 2021 08:07:55 -0400 Subject: [PATCH 3/3] extract EQUALITY_OPERATOR const --- .../dependabot/bundler/file_updater/requirement_replacer.rb | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/bundler/lib/dependabot/bundler/file_updater/requirement_replacer.rb b/bundler/lib/dependabot/bundler/file_updater/requirement_replacer.rb index 8e9c8ca10a..5cb05e05a8 100644 --- a/bundler/lib/dependabot/bundler/file_updater/requirement_replacer.rb +++ b/bundler/lib/dependabot/bundler/file_updater/requirement_replacer.rb @@ -167,6 +167,8 @@ def space_after_specifier?(requirement_nodes) req_string.include?(" ") end + EQUALITY_OPERATOR = /(?!])=/.freeze + def use_equality_operator?(requirement_nodes) return true if requirement_nodes.none? @@ -178,7 +180,7 @@ def use_equality_operator?(requirement_nodes) requirement_nodes.first.children.first.loc.expression.source end - req_string.match?(/(?!])=/) + req_string.match?(EQUALITY_OPERATOR) end def new_requirement_string(quote_characters:, @@ -203,7 +205,7 @@ def serialized_req(req, use_equality_operator) # Gem::Requirement serializes exact matches as a string starting # with `=`. We may need to remove that equality operator if it # wasn't used originally. - tmp_req = tmp_req.gsub(/(?!])=/, "") unless use_equality_operator + tmp_req = tmp_req.gsub(EQUALITY_OPERATOR, "") unless use_equality_operator tmp_req.strip end