Skip to content

Commit

Permalink
Merge pull request #12648 from bevanjkay/cask-comma-separator-style
Browse files Browse the repository at this point in the history
rubocops (cask/url): add rubocop to use csv instead of before|after_comma
  • Loading branch information
MikeMcQuaid authored Jan 12, 2022
2 parents 1b5caa5 + 8c82ec9 commit 3ba6afb
Show file tree
Hide file tree
Showing 6 changed files with 174 additions and 2 deletions.
29 changes: 29 additions & 0 deletions Library/Homebrew/rubocops/cask/mixin/on_url_stanza.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
# typed: false
# frozen_string_literal: true

module RuboCop
module Cop
module Cask
# Common functionality for checking url stanzas.
module OnUrlStanza
extend Forwardable
include CaskHelp

def on_cask(cask_block)
@cask_block = cask_block

toplevel_stanzas.select(&:url?).each do |stanza|
on_url_stanza(stanza)
end
end

private

attr_reader :cask_block

def_delegators :cask_block,
:toplevel_stanzas
end
end
end
end
38 changes: 38 additions & 0 deletions Library/Homebrew/rubocops/cask/url_legacy_comma_separators.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# typed: true
# frozen_string_literal: true

require "forwardable"
require "uri"

module RuboCop
module Cop
module Cask
# This cop checks for version.before_comma and version.after_comma
class UrlLegacyCommaSeparators < Base
include OnUrlStanza
extend AutoCorrector

MSG_CSV = "Use 'version.csv.first' instead of 'version.before_comma' " \
"and 'version.csv.second' instead of 'version.after_comma'"

def on_url_stanza(stanza)
return if stanza.stanza_node.type == :block

url_node = stanza.stanza_node.first_argument

legacy_comma_separator_pattern = /version\.(before|after)_comma/

url = url_node.source

return unless url.match?(legacy_comma_separator_pattern)

corrected_url = url.sub("before_comma", "csv.first")&.sub("after_comma", "csv.second")

add_offense(url_node.loc.expression, message: format(MSG_CSV, url: url)) do |corrector|
corrector.replace(url_node.source_range, corrected_url)
end
end
end
end
end
end
2 changes: 2 additions & 0 deletions Library/Homebrew/rubocops/rubocop-cask.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,10 @@
require_relative "cask/extend/node"
require_relative "cask/mixin/cask_help"
require_relative "cask/mixin/on_homepage_stanza"
require_relative "cask/mixin/on_url_stanza"
require_relative "cask/desc"
require_relative "cask/homepage_url_trailing_slash"
require_relative "cask/no_dsl_version"
require_relative "cask/stanza_order"
require_relative "cask/stanza_grouping"
require_relative "cask/url_legacy_comma_separators"
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
# typed: false
# frozen_string_literal: true

require "rubocops/rubocop-cask"
require "test/rubocops/cask/shared_examples/cask_cop"

describe RuboCop::Cop::Cask::UrlLegacyCommaSeparators do
include CaskCop

subject(:cop) { described_class.new }

context "when url version interpolation does not include version.before_comma or version.after_comma" do
let(:source) do
<<-CASK.undent
cask 'foo' do
version '1.1'
url 'https://foo.brew.sh/foo-\#{version}.dmg'
end
CASK
end

include_examples "does not report any offenses"
end

context "when the url uses csv" do
let(:source) do
<<-CASK.undent
cask 'foo' do
version '1.1,111'
url 'https://foo.brew.sh/foo-\#{version.csv.first}.dmg'
end
CASK
end

include_examples "does not report any offenses"
end

context "when the url uses version.before_comma" do
let(:source) do
<<-CASK.undent
cask 'foo' do
version '1.1,111'
url 'https://foo.brew.sh/foo-\#{version.before_comma}.dmg'
end
CASK
end
let(:correct_source) do
<<-CASK.undent
cask 'foo' do
version '1.1,111'
url 'https://foo.brew.sh/foo-\#{version.csv.first}.dmg'
end
CASK
end
let(:expected_offenses) do
[{
message: "Use 'version.csv.first' instead of 'version.before_comma' "\
"and 'version.csv.second' instead of 'version.after_comma'",
severity: :convention,
line: 3,
column: 6,
source: "'https://foo.brew.sh/foo-\#{version.before_comma}.dmg'",
}]
end

include_examples "reports offenses"

include_examples "autocorrects source"
end

context "when the url uses version.after_comma" do
let(:source) do
<<-CASK.undent
cask 'foo' do
version '1.1,111'
url 'https://foo.brew.sh/foo-\#{version.after_comma}.dmg'
end
CASK
end
let(:correct_source) do
<<-CASK.undent
cask 'foo' do
version '1.1,111'
url 'https://foo.brew.sh/foo-\#{version.csv.second}.dmg'
end
CASK
end
let(:expected_offenses) do
[{
message: "Use 'version.csv.first' instead of 'version.before_comma' "\
"and 'version.csv.second' instead of 'version.after_comma'",
severity: :convention,
line: 3,
column: 6,
source: "'https://foo.brew.sh/foo-\#{version.after_comma}.dmg'",
}]
end

include_examples "reports offenses"

include_examples "autocorrects source"
end
end
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
sha256 "a69e7357bea014f4c14ac9699274f559086844ffa46563c4619bf1addfd72ad9"

# rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1 was verified as official when first introduced to the cask
url "https://rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1/app_versions/#{version.after_comma}?format=zip"
url "https://rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1/app_versions/#{version.csv.second}?format=zip"
appcast "https://rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1"
name "HockeyApp"
homepage "https://www.brew.sh/"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
sha256 "a69e7357bea014f4c14ac9699274f559086844ffa46563c4619bf1addfd72ad9"

# rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1 was verified as official when first introduced to the cask
url "https://rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1/app_versions/#{version.after_comma}?format=zip"
url "https://rink.hockeyapp.net/api/2/apps/67503a7926431872c4b6c1549f5bd6b1/app_versions/#{version.csv.second}?format=zip"
name "HockeyApp"
homepage "https://www.brew.sh/"

Expand Down

0 comments on commit 3ba6afb

Please sign in to comment.