mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
59 lines
1.9 KiB
Ruby
59 lines
1.9 KiB
Ruby
# typed: true
|
|
# frozen_string_literal: true
|
|
|
|
require "rspec/core"
|
|
require "rspec/core/formatters/base_formatter"
|
|
|
|
# TODO: Replace with `rspec-github` when https://github.com/Drieam/rspec-github/pull/4 is merged.
|
|
module RSpec
|
|
module Github
|
|
class Formatter < RSpec::Core::Formatters::BaseFormatter
|
|
RSpec::Core::Formatters.register self, :example_failed, :example_pending
|
|
|
|
def self.escape(string)
|
|
# See https://github.community/t/set-output-truncates-multiline-strings/16852/3.
|
|
string.gsub("%", "%25")
|
|
.gsub("\n", "%0A")
|
|
.gsub("\r", "%0D")
|
|
end
|
|
|
|
def self.relative_path(path)
|
|
if (workspace = ENV["GITHUB_WORKSPACE"])
|
|
workspace = "#{File.realpath(workspace)}#{File::SEPARATOR}"
|
|
absolute_path = File.realpath(path)
|
|
|
|
return absolute_path.delete_prefix(workspace) if absolute_path.start_with?(workspace)
|
|
end
|
|
|
|
path
|
|
end
|
|
|
|
def example_failed(failure)
|
|
file, line = failure.example.location.split(":")
|
|
file = self.class.relative_path(file)
|
|
|
|
description = failure.example.full_description
|
|
message = failure.message_lines.join("\n")
|
|
annotation = "#{description}\n\n#{message}"
|
|
|
|
output.puts "\n::error file=#{file},line=#{line}::#{self.class.escape(annotation)}"
|
|
end
|
|
|
|
def example_pending(pending)
|
|
file, line = pending.example.location.split(":")
|
|
file = self.class.relative_path(file)
|
|
|
|
description = pending.example.full_description
|
|
message = if pending.example.skip
|
|
"Skipped: #{pending.example.execution_result.pending_message}"
|
|
else
|
|
"Pending: #{pending.example.execution_result.pending_message}"
|
|
end
|
|
annotation = "#{description}\n\n#{message}"
|
|
|
|
output.puts "\n::warning file=#{file},line=#{line}::#{self.class.escape(annotation)}"
|
|
end
|
|
end
|
|
end
|
|
end
|