Pypi: Update strategy regex
livecheck is returning an `Unable to get versions` error for the `ansible-lint`, `aws-sam-cli`, and `pyqt-builder` formulae. These use the `Pypi` strategy without a `livecheck` block, so they use the generated regex from the strategy. The `Pypi` strategy matches the version from the tarball link on the pypi.org package page but this fails for these packages because the formula's `stable` tarball uses hyphens in the filename (e.g., `ansible-lint-...`) but the current tarball filename uses underscores (e.g., `ansible_lint-...`). This addresses the issue by updating the strategy regex to replace [escaped] `-` or `_` characters in the package name with `[_-]`, so the regex will match regardless of the delimiter used in the formula filename.
This commit is contained in:
parent
b4f214f325
commit
78c7ad747a
@ -67,7 +67,7 @@ module Homebrew
|
|||||||
regex_suffix = Regexp.escape(suffix).gsub("\\-", "-")
|
regex_suffix = Regexp.escape(suffix).gsub("\\-", "-")
|
||||||
|
|
||||||
# Example regex: `%r{href=.*?/packages.*?/example[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)\.t}i`
|
# Example regex: `%r{href=.*?/packages.*?/example[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)\.t}i`
|
||||||
regex_name = Regexp.escape(T.must(match[:package_name])).gsub("\\-", "-")
|
regex_name = Regexp.escape(T.must(match[:package_name])).gsub(/\\[_-]/, "[_-]")
|
||||||
values[:regex] =
|
values[:regex] =
|
||||||
%r{href=.*?/packages.*?/#{regex_name}[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)#{regex_suffix}}i
|
%r{href=.*?/packages.*?/#{regex_name}[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)#{regex_suffix}}i
|
||||||
|
|
||||||
|
|||||||
@ -5,13 +5,13 @@ require "livecheck/strategy"
|
|||||||
RSpec.describe Homebrew::Livecheck::Strategy::Pypi do
|
RSpec.describe Homebrew::Livecheck::Strategy::Pypi do
|
||||||
subject(:pypi) { described_class }
|
subject(:pypi) { described_class }
|
||||||
|
|
||||||
let(:pypi_url) { "https://files.pythonhosted.org/packages/ab/cd/efg/example-1.2.3.tar.gz" }
|
let(:pypi_url) { "https://files.pythonhosted.org/packages/ab/cd/efg/example-package-1.2.3.tar.gz" }
|
||||||
let(:non_pypi_url) { "https://brew.sh/test" }
|
let(:non_pypi_url) { "https://brew.sh/test" }
|
||||||
|
|
||||||
let(:generated) do
|
let(:generated) do
|
||||||
{
|
{
|
||||||
url: "https://pypi.org/project/example/#files",
|
url: "https://pypi.org/project/example-package/#files",
|
||||||
regex: %r{href=.*?/packages.*?/example[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)\.t}i,
|
regex: %r{href=.*?/packages.*?/example[_-]package[._-]v?(\d+(?:\.\d+)*(?:[._-]post\d+)?)\.t}i,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user