mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-15 19:56:59 +08:00
141 lines
4.8 KiB
Ruby
141 lines
4.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "rubocops/rubocop-cask"
|
|
|
|
RSpec.describe RuboCop::Cop::Cask::Variables, :config do
|
|
it "accepts when there are no variables" do
|
|
expect_no_offenses <<~CASK
|
|
cask "foo" do
|
|
version :latest
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "accepts when there is an `arch` stanza" do
|
|
expect_no_offenses <<~CASK
|
|
cask "foo" do
|
|
arch arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "accepts an `on_arch_conditional` variable" do
|
|
expect_no_offenses <<~CASK
|
|
cask "foo" do
|
|
folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for an `arch` variable using strings" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
arch = Hardware::CPU.intel? ? "darwin" : "darwin-arm64"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `arch arm: "darwin-arm64", intel: "darwin"` instead of `arch = Hardware::CPU.intel? ? "darwin" : "darwin-arm64"`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
arch arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for an `arch` variable using symbols" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
arch = Hardware::CPU.intel? ? :darwin : :darwin_arm64
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `arch arm: :darwin_arm64, intel: :darwin` instead of `arch = Hardware::CPU.intel? ? :darwin : :darwin_arm64`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
arch arm: :darwin_arm64, intel: :darwin
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for an `arch` variable with an empty string" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
arch = Hardware::CPU.intel? ? "" : "arm64"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `arch arm: "arm64"` instead of `arch = Hardware::CPU.intel? ? "" : "arm64"`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
arch arm: "arm64"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for a non-`arch` variable using strings" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
folder = Hardware::CPU.intel? ? "darwin" : "darwin-arm64"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"` instead of `folder = Hardware::CPU.intel? ? "darwin" : "darwin-arm64"`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for a non-`arch` variable with an empty string" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
folder = Hardware::CPU.intel? ? "amd64" : ""
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `folder = on_arch_conditional intel: "amd64"` instead of `folder = Hardware::CPU.intel? ? "amd64" : ""`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
folder = on_arch_conditional intel: "amd64"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for consecutive `arch` and non-`arch` variables" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
arch = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `arch arm: "darwin-arm64", intel: "darwin"` instead of `arch = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"`.
|
|
folder = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"` instead of `folder = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
arch arm: "darwin-arm64", intel: "darwin"
|
|
folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
|
|
it "reports an offense for two consecutive non-`arch` variables" do
|
|
expect_offense <<~CASK
|
|
cask 'foo' do
|
|
folder = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"` instead of `folder = Hardware::CPU.arm? ? "darwin-arm64" : "darwin"`.
|
|
platform = Hardware::CPU.intel? ? "darwin": "darwin-arm64"
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Use `platform = on_arch_conditional arm: "darwin-arm64", intel: "darwin"` instead of `platform = Hardware::CPU.intel? ? "darwin": "darwin-arm64"`.
|
|
end
|
|
CASK
|
|
|
|
expect_correction <<~CASK
|
|
cask 'foo' do
|
|
folder = on_arch_conditional arm: "darwin-arm64", intel: "darwin"
|
|
platform = on_arch_conditional arm: "darwin-arm64", intel: "darwin"
|
|
end
|
|
CASK
|
|
end
|
|
end
|