brew-gist-logs: make an internal command.
This commit is contained in:
parent
7989b2169f
commit
706e8abe29
@ -1,107 +0,0 @@
|
|||||||
require 'formula'
|
|
||||||
require 'cmd/config'
|
|
||||||
require 'net/http'
|
|
||||||
require 'net/https'
|
|
||||||
require 'stringio'
|
|
||||||
|
|
||||||
def gist_logs f
|
|
||||||
if ARGV.include? '--new-issue'
|
|
||||||
unless HOMEBREW_GITHUB_API_TOKEN
|
|
||||||
puts 'You need to create an API token: https://github.com/settings/applications'
|
|
||||||
puts 'and then set HOMEBREW_GITHUB_API_TOKEN to use --new-issue option.'
|
|
||||||
exit 1
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
files = load_logs(f.name)
|
|
||||||
|
|
||||||
s = StringIO.new
|
|
||||||
Homebrew.dump_verbose_config(s)
|
|
||||||
files["config.out"] = { :content => s.string }
|
|
||||||
files["doctor.out"] = { :content => `brew doctor 2>&1` }
|
|
||||||
|
|
||||||
url = create_gist(files)
|
|
||||||
|
|
||||||
if ARGV.include? '--new-issue'
|
|
||||||
url = new_issue(f.tap, "#{f.name} failed to build on #{MACOS_FULL_VERSION}", url)
|
|
||||||
end
|
|
||||||
|
|
||||||
ensure puts url if url
|
|
||||||
end
|
|
||||||
|
|
||||||
def load_logs name
|
|
||||||
logs = {}
|
|
||||||
dir = HOMEBREW_LOGS/name
|
|
||||||
dir.children.sort.each do |file|
|
|
||||||
contents = file.size? ? file.read : "empty log"
|
|
||||||
logs[file.basename.to_s] = { :content => contents }
|
|
||||||
end if dir.exist?
|
|
||||||
raise 'No logs.' if logs.empty?
|
|
||||||
logs
|
|
||||||
end
|
|
||||||
|
|
||||||
def create_gist files
|
|
||||||
post("/gists", "public" => true, "files" => files)["html_url"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def new_issue repo, title, body
|
|
||||||
post("/repos/#{repo}/issues", "title" => title, "body" => body)["html_url"]
|
|
||||||
end
|
|
||||||
|
|
||||||
def http
|
|
||||||
@http ||= begin
|
|
||||||
uri = URI.parse('https://api.github.com')
|
|
||||||
p = ENV['http_proxy'] ? URI.parse(ENV['http_proxy']) : nil
|
|
||||||
if p.class == URI::HTTP or p.class == URI::HTTPS
|
|
||||||
@http = Net::HTTP.new(uri.host, uri.port, p.host, p.port, p.user, p.password)
|
|
||||||
else
|
|
||||||
@http = Net::HTTP.new(uri.host, uri.port)
|
|
||||||
end
|
|
||||||
@http.use_ssl = true
|
|
||||||
@http
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def make_request(path, data)
|
|
||||||
headers = {
|
|
||||||
"User-Agent" => HOMEBREW_USER_AGENT,
|
|
||||||
"Accept" => "application/vnd.github.v3+json",
|
|
||||||
"Content-Type" => "application/json",
|
|
||||||
}
|
|
||||||
|
|
||||||
if HOMEBREW_GITHUB_API_TOKEN
|
|
||||||
headers["Authorization"] = "token #{HOMEBREW_GITHUB_API_TOKEN}"
|
|
||||||
end
|
|
||||||
|
|
||||||
request = Net::HTTP::Post.new(path, headers)
|
|
||||||
request.body = Utils::JSON.dump(data)
|
|
||||||
request
|
|
||||||
end
|
|
||||||
|
|
||||||
def post(path, data)
|
|
||||||
request = make_request(path, data)
|
|
||||||
|
|
||||||
case response = http.request(request)
|
|
||||||
when Net::HTTPCreated
|
|
||||||
Utils::JSON.load get_body(response)
|
|
||||||
else
|
|
||||||
raise "HTTP #{response.code} #{response.message} (expected 201)"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def get_body(response)
|
|
||||||
if !response.body.respond_to?(:force_encoding)
|
|
||||||
response.body
|
|
||||||
elsif response["Content-Type"].downcase == "application/json; charset=utf-8"
|
|
||||||
response.body.dup.force_encoding(Encoding::UTF_8)
|
|
||||||
else
|
|
||||||
response.body.encode(Encoding::UTF_8, :undef => :replace)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if ARGV.formulae.length != 1
|
|
||||||
puts "usage: brew gist-logs [--new-issue] <formula>"
|
|
||||||
exit 1
|
|
||||||
end
|
|
||||||
|
|
||||||
gist_logs(ARGV.formulae[0])
|
|
||||||
112
Library/Homebrew/cmd/gist-logs.rb
Executable file
112
Library/Homebrew/cmd/gist-logs.rb
Executable file
@ -0,0 +1,112 @@
|
|||||||
|
require 'formula'
|
||||||
|
require 'cmd/config'
|
||||||
|
require 'net/http'
|
||||||
|
require 'net/https'
|
||||||
|
require 'stringio'
|
||||||
|
|
||||||
|
module Homebrew
|
||||||
|
def gistify_logs f
|
||||||
|
if ARGV.include? '--new-issue'
|
||||||
|
unless HOMEBREW_GITHUB_API_TOKEN
|
||||||
|
puts 'You need to create an API token: https://github.com/settings/applications'
|
||||||
|
puts 'and then set HOMEBREW_GITHUB_API_TOKEN to use --new-issue option.'
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
files = load_logs(f.name)
|
||||||
|
|
||||||
|
s = StringIO.new
|
||||||
|
Homebrew.dump_verbose_config(s)
|
||||||
|
files["config.out"] = { :content => s.string }
|
||||||
|
files["doctor.out"] = { :content => `brew doctor 2>&1` }
|
||||||
|
|
||||||
|
url = create_gist(files)
|
||||||
|
|
||||||
|
if ARGV.include? '--new-issue'
|
||||||
|
url = new_issue(f.tap, "#{f.name} failed to build on #{MACOS_FULL_VERSION}", url)
|
||||||
|
end
|
||||||
|
|
||||||
|
ensure puts url if url
|
||||||
|
end
|
||||||
|
|
||||||
|
def load_logs name
|
||||||
|
logs = {}
|
||||||
|
dir = HOMEBREW_LOGS/name
|
||||||
|
dir.children.sort.each do |file|
|
||||||
|
contents = file.size? ? file.read : "empty log"
|
||||||
|
logs[file.basename.to_s] = { :content => contents }
|
||||||
|
end if dir.exist?
|
||||||
|
raise 'No logs.' if logs.empty?
|
||||||
|
logs
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_gist files
|
||||||
|
post("/gists", "public" => true, "files" => files)["html_url"]
|
||||||
|
end
|
||||||
|
|
||||||
|
def new_issue repo, title, body
|
||||||
|
post("/repos/#{repo}/issues", "title" => title, "body" => body)["html_url"]
|
||||||
|
end
|
||||||
|
|
||||||
|
def http
|
||||||
|
@http ||= begin
|
||||||
|
uri = URI.parse('https://api.github.com')
|
||||||
|
p = ENV['http_proxy'] ? URI.parse(ENV['http_proxy']) : nil
|
||||||
|
if p.class == URI::HTTP or p.class == URI::HTTPS
|
||||||
|
@http = Net::HTTP.new(uri.host, uri.port, p.host, p.port, p.user, p.password)
|
||||||
|
else
|
||||||
|
@http = Net::HTTP.new(uri.host, uri.port)
|
||||||
|
end
|
||||||
|
@http.use_ssl = true
|
||||||
|
@http
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def make_request(path, data)
|
||||||
|
headers = {
|
||||||
|
"User-Agent" => HOMEBREW_USER_AGENT,
|
||||||
|
"Accept" => "application/vnd.github.v3+json",
|
||||||
|
"Content-Type" => "application/json",
|
||||||
|
}
|
||||||
|
|
||||||
|
if HOMEBREW_GITHUB_API_TOKEN
|
||||||
|
headers["Authorization"] = "token #{HOMEBREW_GITHUB_API_TOKEN}"
|
||||||
|
end
|
||||||
|
|
||||||
|
request = Net::HTTP::Post.new(path, headers)
|
||||||
|
request.body = Utils::JSON.dump(data)
|
||||||
|
request
|
||||||
|
end
|
||||||
|
|
||||||
|
def post(path, data)
|
||||||
|
request = make_request(path, data)
|
||||||
|
|
||||||
|
case response = http.request(request)
|
||||||
|
when Net::HTTPCreated
|
||||||
|
Utils::JSON.load get_body(response)
|
||||||
|
else
|
||||||
|
raise "HTTP #{response.code} #{response.message} (expected 201)"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def get_body(response)
|
||||||
|
if !response.body.respond_to?(:force_encoding)
|
||||||
|
response.body
|
||||||
|
elsif response["Content-Type"].downcase == "application/json; charset=utf-8"
|
||||||
|
response.body.dup.force_encoding(Encoding::UTF_8)
|
||||||
|
else
|
||||||
|
response.body.encode(Encoding::UTF_8, :undef => :replace)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def gist_logs
|
||||||
|
if ARGV.formulae.length != 1
|
||||||
|
puts "usage: brew gist-logs [--new-issue] <formula>"
|
||||||
|
Homebrew.failed = true
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
gistify_logs(ARGV.formulae[0])
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
x
Reference in New Issue
Block a user