Merge pull request #3289 from reitermarkus/cask-loader

Fix regexes in `CaskLoader`.
This commit is contained in:
Markus Reiter 2017-10-08 16:07:09 +02:00 committed by GitHub
commit 91ab116ace
3 changed files with 93 additions and 8 deletions

View File

@ -3,6 +3,18 @@ module Hbc
class FromContentLoader
attr_reader :content
def self.can_load?(ref)
return false unless ref.respond_to?(:to_str)
content = ref.to_str
token = /(?:"[^"]*"|'[^']*')/
curly = /\(\s*#{token}\s*\)\s*\{.*\}/
do_end = /\s+#{token}\s+do(?:\s*;\s*|\s+).*end/
regex = /\A\s*cask(?:#{curly.source}|#{do_end.source})\s*\Z/m
content.match?(regex)
end
def initialize(content)
@content = content
end
@ -56,7 +68,8 @@ module Hbc
class FromURILoader < FromPathLoader
def self.can_load?(ref)
ref.to_s.match?(::URI::DEFAULT_PARSER.make_regexp)
uri_regex = ::URI::DEFAULT_PARSER.make_regexp
ref.to_s.match?(Regexp.new('\A' + uri_regex.source + '\Z', uri_regex.options))
end
attr_reader :url
@ -156,15 +169,9 @@ module Hbc
end
def self.for(ref)
if ref.respond_to?(:to_str)
content = ref.to_str
if content.match?(/\A\s*cask\s+(?:"[^"]*"|'[^']*')\s+do(?:\s+.*\s+|;?\s+)end\s*\Z/)
return FromContentLoader.new(content)
end
end
[
FromInstanceLoader,
FromContentLoader,
FromURILoader,
FromTapLoader,
FromTapPathLoader,

View File

@ -0,0 +1,57 @@
describe Hbc::CaskLoader::FromContentLoader do
alias_matcher :be_able_to_load, :be_can_load
describe "::can_load?" do
it "returns true for Casks specified with `cask \"token\" do … end`" do
expect(described_class).to be_able_to_load <<~EOS
cask "token" do
end
EOS
end
it "returns true for Casks specified with `cask \"token\" do; end`" do
expect(described_class).to be_able_to_load <<~EOS
cask "token" do; end
EOS
end
it "returns true for Casks specified with `cask 'token' do … end`" do
expect(described_class).to be_able_to_load <<~EOS
cask 'token' do
end
EOS
end
it "returns true for Casks specified with `cask 'token' do; end`" do
expect(described_class).to be_able_to_load <<~EOS
cask 'token' do; end
EOS
end
it "returns true for Casks specified with `cask(\"token\") { … }`" do
expect(described_class).to be_able_to_load <<~EOS
cask("token") {
}
EOS
end
it "returns true for Casks specified with `cask(\"token\") {}`" do
expect(described_class).to be_able_to_load <<~EOS
cask("token") {}
EOS
end
it "returns true for Casks specified with `cask('token') { … }`" do
expect(described_class).to be_able_to_load <<~EOS
cask('token') {
}
EOS
end
it "returns true for Casks specified with `cask('token') {}`" do
expect(described_class).to be_able_to_load <<~EOS
cask('token') {}
EOS
end
end
end

View File

@ -0,0 +1,21 @@
describe Hbc::CaskLoader::FromURILoader do
alias_matcher :be_able_to_load, :be_can_load
describe "::can_load?" do
it "returns true when given an URI" do
expect(described_class).to be_able_to_load(URI("http://example.com/"))
end
it "returns true when given a String which can be parsed to a URI" do
expect(described_class).to be_able_to_load("http://example.com/")
end
it "returns false when given a String with Cask contents containing a URL" do
expect(described_class).not_to be_able_to_load <<~EOS
cask 'token' do
url 'http://example.com/'
end
EOS
end
end
end