Skip to main content

Trabalhar com comentários

Ao usar a API REST, você pode acessar e gerenciar comentários nos seus pull requests, problemas ou commits.

Para qualquer solicitação de pull, o GitHub Enterprise Server fornece três tipos de exibições de comentários: comentários sobre a solicitação de pull como um todo, comentários sobre uma linha específica na solicitação de pull e comentários sobre um commit específico na solicitação de pull.

Cada um desses tipos de comentários passa por uma parte diferente da GitHub Enterprise Server API. Neste guia, vamos explorar como você pode acessar e manipular cada um. Para cada exemplo, usaremos este exemplo de solicitação de pull criado no repositório "octocat". Como sempre, os exemplos podem ser encontrados em nosso repositório platform-samples.

Comentários do Pull Request

Para acessar os comentários em uma solicitação de pull, use os pontos de extremidade para gerenciar problemas. A princípio, isso pode parecer contraintuitivo. No entanto, uma vez que você entende que uma solicitação de pull é somente um problema com um código, faz sentido usar esses pontos de extremidade para criar comentários nela.

Demonstraremos como buscar comentários de uma solicitação de pull criando um script do Ruby usando o Octokit.rb. Crie também um personal access token.

O seguinte código ajudará você a começar a acessar os comentários de uma solicitação de pull usando o Octokit.rb:

require 'octokit'

# !!! DO NOT EVER USE HARD-CODED VALUES IN A REAL APP !!!
# Instead, set and test environment variables, like below
client = Octokit::Client.new :access_token => ENV['MY_PERSONAL_TOKEN']

client.issue_comments("octocat/Spoon-Knife", 1176).each do |comment|
  username = comment[:user][:login]
  post_date = comment[:created_at]
  content = comment[:body]

  puts "#{username} made a comment on #{post_date}. It says:\n'#{content}'\n"
end

Aqui, você chama especificamente a API para obter os comentários (issue_comments), fornecendo o nome do repositório (octocat/Spoon-Knife) e a ID da solicitação de pull em que tem interesse (1176). Depois disso, é simplesmente uma questão de iterar pelos comentários para buscar informações sobre cada um.

Comentários em uma linha de Pull Request

Na exibição de comparação, você pode iniciar uma discussão sobre um aspecto específico de uma alteração singular feita na solicitação de pull. Esses comentários ocorrem nas linhas individuais de um arquivo alterado. A URL do ponto de extremidade dessa discussão é proveniente do ponto de extremidade para gerenciar revisões de solicitação de pull.

O código a seguir busca todos os comentários de pull request feitos em arquivos, dado um único número de pull request:

require 'octokit'

# !!! DO NOT EVER USE HARD-CODED VALUES IN A REAL APP !!!
# Instead, set and test environment variables, like below
client = Octokit::Client.new :access_token => ENV['MY_PERSONAL_TOKEN']

client.pull_request_comments("octocat/Spoon-Knife", 1176).each do |comment|
  username = comment[:user][:login]
  post_date = comment[:created_at]
  content = comment[:body]
  path = comment[:path]
  position = comment[:position]

  puts "#{username} made a comment on #{post_date} for the file called #{path}, on line #{position}. It says:\n'#{content}'\n"
end

Você perceberá que ele é incrivelmente semelhante ao exemplo acima. A diferença entre esta exibição e o comentário sobre a solicitação de pull é o foco da conversa. Um comentário feito em uma solicitação de pull deve ser reservado para discussão ou ideias sobre a orientação geral do código. Um comentário feito como parte de uma revisão de solicitação de pull deve lidar especificamente com a forma como determinada alteração foi implementada em um arquivo.

Comentários de commit

O último tipo de comentários ocorre especificamente nos commits individuais. Por esse motivo, eles usam o ponto de extremidade para gerenciar comentários de commit.

Para recuperar os comentários em um commit, você deverá usar o SHA1 do commit. Em outras palavras, você não usará nenhum identificador relacionado ao Pull Request. Veja um exemplo:

require 'octokit'

# !!! DO NOT EVER USE HARD-CODED VALUES IN A REAL APP !!!
# Instead, set and test environment variables, like below
client = Octokit::Client.new :access_token => ENV['MY_PERSONAL_TOKEN']

client.commit_comments("octocat/Spoon-Knife", "cbc28e7c8caee26febc8c013b0adfb97a4edd96e").each do |comment|
  username = comment[:user][:login]
  post_date = comment[:created_at]
  content = comment[:body]

  puts "#{username} made a comment on #{post_date}. It says:\n'#{content}'\n"
end

Observe que essa chamada à API vai recuperar os comentários de linha única, bem como os comentários feitos em todo o commit.