diff --git a/Library/Homebrew/rubocops/urls.rb b/Library/Homebrew/rubocops/urls.rb index 5dbceeb83da1953dd0d252435bda3a1d0c88bf6e..b23883d0cda4cee9e2675e948d4b6261546c3ea3 100644 --- a/Library/Homebrew/rubocops/urls.rb +++ b/Library/Homebrew/rubocops/urls.rb @@ -316,23 +316,47 @@ module RuboCop end end - # This cop makes sure that git urls have both a `tag` and `revision`. + # This cop makes sure that git urls have both a `revision`. # # @api private class GitUrls < FormulaCop def audit_formula(_node, _class_node, _parent_class_node, body_node) + return unless formula_tap == "homebrew-core" + find_method_calls_by_name(body_node, :url).each do |url| next unless string_content(parameters(url).first).match?(/\.git$/) + next if url_has_revision?(parameters(url).last) + + offending_node(url) + problem "Formulae in homebrew/core should specify a revision for git urls" + end + end + + def_node_matcher :url_has_revision?, <<~EOS + (hash <(pair (sym :revision) str) ...>) + EOS + end + end + + module FormulaAuditStrict + # This cop makes sure that git urls have both a `tag`. + # + # @api private + class GitUrls < FormulaCop + def audit_formula(_node, _class_node, _parent_class_node, body_node) + return unless formula_tap == "homebrew-core" - next if url_has_tag_and_revision?(parameters(url).last) + find_method_calls_by_name(body_node, :url).each do |url| + next unless string_content(parameters(url).first).match?(/\.git$/) + next if url_has_tag?(parameters(url).last) offending_node(url) - problem "Specify a `tag` and `revision` for git urls" + problem "Formulae in homebrew/core should specify a tag for git urls" end end - def_node_matcher :url_has_tag_and_revision?, <<~EOS - (hash <(pair (sym :tag) str) (pair (sym :revision) str) ...>) + def_node_matcher :url_has_tag?, <<~EOS + (hash <(pair (sym :tag) str) ...>) EOS end end diff --git a/Library/Homebrew/test/rubocops/urls_spec.rb b/Library/Homebrew/test/rubocops/urls_spec.rb index 1d6e7e88e5bccb5fd6584c56a793515c638ebbb0..e36f40493a7240c82015dd723c9c0eadc756e35e 100644 --- a/Library/Homebrew/test/rubocops/urls_spec.rb +++ b/Library/Homebrew/test/rubocops/urls_spec.rb @@ -282,7 +282,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do context "when a git URL is used" do it "reports no offenses with a non-git url" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://foo.com" @@ -291,7 +291,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports no offenses with both a tag and a revision" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", @@ -302,7 +302,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports no offenses with both a tag, revision and `shallow` before" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", @@ -314,7 +314,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports no offenses with both a tag, revision and `shallow` after" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", @@ -326,45 +326,140 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports an offense with no `revision`" do - expect_offense(<<~RUBY) + expect_offense(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a revision for git urls tag: "v1.0.0" end RUBY end it "reports an offense with no `revision` and `shallow`" do - expect_offense(<<~RUBY) + expect_offense(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a revision for git urls shallow: false, tag: "v1.0.0" end RUBY end + it "reports no offenses with no `tag`" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git", + revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + end + RUBY + end + + it "reports no offenses with no `tag` and `shallow`" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git", + revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", + shallow: false + end + RUBY + end + + it "reports no offenses with missing arguments in `head`" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://foo.com" + head do + url "https://github.com/foo/bar.git" + end + end + RUBY + end + + it "reports no offenses with missing arguments in `devel`" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://foo.com" + devel do + url "https://github.com/foo/bar.git" + end + end + RUBY + end + + it "reports no offenses for non-core taps" do + expect_no_offenses(<<~RUBY) + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git" + end + RUBY + end + end +end + +describe RuboCop::Cop::FormulaAuditStrict::GitUrls do + subject(:cop) { described_class.new } + + context "when a git URL is used" do + it "reports no offenses with both a tag and a revision" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git", + tag: "v1.0.0", + revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + end + RUBY + end + + it "reports no offenses with both a tag, revision and `shallow` before" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git", + shallow: false, + tag: "v1.0.0", + revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" + end + RUBY + end + + it "reports no offenses with both a tag, revision and `shallow` after" do + expect_no_offenses(<<~RUBY, "/homebrew-core/") + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git", + tag: "v1.0.0", + revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", + shallow: false + end + RUBY + end + it "reports an offense with no `tag`" do - expect_offense(<<~RUBY) + expect_offense(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a tag for git urls revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" end RUBY end it "reports an offense with no `tag` and `shallow`" do - expect_offense(<<~RUBY) + expect_offense(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://github.com/foo/bar.git", - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a tag for git urls revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa", shallow: false end @@ -372,7 +467,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports no offenses with missing arguments in `head`" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://foo.com" @@ -384,7 +479,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end it "reports no offenses with missing arguments in `devel`" do - expect_no_offenses(<<~RUBY) + expect_no_offenses(<<~RUBY, "/homebrew-core/") class Foo < Formula desc "foo" url "https://foo.com" @@ -394,5 +489,14 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do end RUBY end + + it "reports no offenses for non-core taps" do + expect_no_offenses(<<~RUBY) + class Foo < Formula + desc "foo" + url "https://github.com/foo/bar.git" + end + RUBY + end end end