diff options
| author | Mike McQuaid | 2014-09-20 14:25:09 +0100 | 
|---|---|---|
| committer | Mike McQuaid | 2014-09-24 15:22:46 -0700 | 
| commit | 4a2cd8ab8e8c6a036e1c7b8173535ba2ebf68836 (patch) | |
| tree | 601334ac754c75618ff54fd400585729dae4c955 | |
| parent | 81c26e822f6c79ed98e7bd8fd3f9ffa2d684fe4d (diff) | |
| download | homebrew-4a2cd8ab8e8c6a036e1c7b8173535ba2ebf68836.tar.bz2 | |
brew-gist-logs: make an internal command.
| -rwxr-xr-x | Library/Contributions/cmd/brew-gist-logs.rb | 107 | ||||
| -rwxr-xr-x | Library/Homebrew/cmd/gist-logs.rb | 112 | 
2 files changed, 112 insertions, 107 deletions
| diff --git a/Library/Contributions/cmd/brew-gist-logs.rb b/Library/Contributions/cmd/brew-gist-logs.rb deleted file mode 100755 index 8c728aa84..000000000 --- a/Library/Contributions/cmd/brew-gist-logs.rb +++ /dev/null @@ -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]) diff --git a/Library/Homebrew/cmd/gist-logs.rb b/Library/Homebrew/cmd/gist-logs.rb new file mode 100755 index 000000000..53b4962e0 --- /dev/null +++ b/Library/Homebrew/cmd/gist-logs.rb @@ -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 | 
