Conectar o Azure Boards ao GitHub (nuvem)
Azure DevOps Services
Use os repositórios do GitHub.com para seu desenvolvimento de software e seu projeto do Azure Boards para planejar e acompanhar seu trabalho. Conecte seu projeto e repositório para que seus commits e pull requests do GitHub sejam vinculados aos seus itens de trabalho no Azure Boards.
Observação
O Azure Boards e o Azure DevOps Services dão suporte à integração com GitHub.com e repositórios do GitHub Enterprise Server. Se você quiser se conectar de um Azure DevOps Server local, confira Conectar o Servidor do Azure DevOps ao GitHub Enterprise Server.
Requisitos do projeto: ter um projeto do Azure DevOps. Se você não tiver um projeto, crie um..
Permissões:
- Seja um membro do grupo Administradores do projeto. Se você criou o projeto, tem permissões.
- Seja um administrador ou proprietário do repositório do GitHub ao qual deseja se conectar. Você pode se conectar a vários repositórios do GitHub desde que seja administrador desses repositórios.
As opções de autenticação a seguir têm suporte com base na plataforma GitHub à qual você deseja se conectar.
GitHub.com
GitHub Enterprise Server
Observação
Se você optar por conectar o Github com o PAT, configure o logon único (SSO) para o PAT em sua conta do GitHub. Essa configuração é necessária para recuperar uma lista de repositórios de uma organização com a autenticação SAML (Security Assertion Markup Language) SSO habilitada.
Entre no projeto (
https://dev.azure.com/{Your_Organization/Your_Project}
).Selecione Configurações do projeto>Conexões do GitHub.
Se esta for a primeira vez que você se conecta a partir do projeto, selecione Conectar sua conta do GitHub para usar suas credenciais de conta do GitHub.
Caso contrário, escolha Nova conexão e selecione o método de autenticação na caixa de diálogo Nova Conexão.
Ao se conectar com sua conta do GitHub, use suas credenciais de conta do GitHub para se autenticar. Para usar um PAT, consulte Adicionar uma conexão do GitHub usando PAT. Para se conectar a um GitHub Enterprise Server, consulte Registrar o Azure DevOps no GitHub como um aplicativo OAuth.
Você pode conectar até 500 repositórios GitHub a um projeto do Azure Boards.
Se esta for a primeira vez que você se conecta ao GitHub pelo Azure Boards, entre usando suas credenciais do GitHub. Escolha uma conta da qual você seja administrador do repositório.
Selecione a conta ou organização do GitHub que você deseja se conectar. Apenas as organizações das quais você é proprietário ou administrador são listadas.
Se todos os repositórios de uma organização já estiverem conectados ao Azure Boards, você verá a seguinte mensagem:
Insira suas credenciais do GitHub. Se você tiver a autenticação de dois fatores habilitada, insira o código de autenticação enviado pelo GitHub e selecione Verificar. Caso contrário, o sistema reconhecerá automaticamente sua organização do GitHub, pois sua conta do GitHub está associada à sua conta do Azure DevOps Services.
Uma vez autenticado, você pode selecionar os repositórios que deseja conectar.
A caixa de diálogo Adicionar repositórios do GitHub é exibida automaticamente e seleciona todos os repositórios GitHub.com para os quais você é administrador na organização selecionada. Desmarque os repositórios que você não deseja incluir na integração.
Dica
Para evitar a vinculação inesperada da menção AB#, recomendamos conectar um repositório GitHub a projetos em uma única organização do Azure DevOps. Conectar o mesmo repositório do GitHub a projetos em várias organizações do Azure DevOps pode causar problemas. Para obter mais informações, consulte Solução de problemas de integração do GitHub e Azure Boards.
Se todos os repositórios já estiverem conectados à organização atual ou a outra organização, a seguinte mensagem será exibida:
Depois de fazer suas seleções, selecione Salvar.
Examine a página do GitHub exibida e escolha Aprovar, Instalar e autorizar.
Forneça suas credenciais do GitHub para confirmar.
Quando terminar, você deverá ver a nova conexão com os repositórios selecionados listados.
Para alterar a configuração ou gerenciar o aplicativo Azure Boards para GitHub, confira Alterar o acesso do repositório ao Azure Boards.
Importante
É recomendável usar tokens do Microsoft Entra. Para obter mais informações sobre nossos esforços para reduzir o uso do PAT, consulte nosso blog. Examine nossas diretrizes de autenticação para escolher o mecanismo de autenticação apropriado para suas necessidades.
Recomendamos usar as credenciais de sua conta do GitHub para se conectar ao seu repositório do GitHub.
Dica
Ao criar seu PAT do GitHub, inclua estes escopos: repo, read:user, user:email, admin:repo_hook
.
Escolha Token de acesso pessoal.
Para criar um PAT do GitHub, acesse Configurações de Desenvolvedor do GitHub > tokens de acesso pessoal.
Insira o PAT e selecione Conectar.
Selecione os repositórios que você deseja conectar ao projeto em Escolher os repositórios seguindo os procedimentos descritos anteriormente neste artigo.
Se for a primeira vez que você se conecta a uma conta ou organização do GitHub pelo Azure Boards, instale o aplicativo Azure Boards para GitHub. Confirme a conexão anteriormente neste artigo.
Para usar o OAuth para conectar o Azure DevOps ao seu GitHub Enterprise Server, primeiro registre o aplicativo como um aplicativo OAuth. Para obter mais informações, consulte Criar um Aplicativo OAuth.
Entre no portal da Web para o servidor GitHub Enterprise.
Abra Configurações>Configurações do desenvolvedor>Aplicativos OAuth>Novo aplicativo OAuth.
Digite as informações de registro.
Para URL da página inicial, especifique o URL da Organização da sua organização.
Para a URL de retorno de chamada de autorização, use o padrão a seguir para construir a URL.{Azure DevOps Services Organization URL}/_admin/oauth2/callback
Por exemplo:
https://dev.azure.com/fabrikam/_admin/oauth2/callback
Selecione Registrar aplicativo.
O ID do Cliente e Segredo do Cliente para seu aplicativo OAuth registrado.
Entre no portal da Web para o Azure DevOps Services.
Adicione a configuração do GitHub Enterprise Oauth à sua organização.
Em Configurações da organização, selecione Configurações do Oauth>Adicionar configuração Oauth.
Insira as informações, selecione Criar.
Importante
Para conectar o Azure DevOps Services ao seu GitHub Enterprise Server, certifique-se de que o GitHub Enterprise Server esteja acessível pela Internet. Certifique-se de que o DNS do Azure possa resolver o nome do GitHub Enterprise Server e que seu firewall permita o acesso a partir dos endereços IP do Azure Data Center. Para determinar o intervalo de endereços IP, confira Intervalos de IP do Datacenter do Microsoft Azure. Uma mensagem de erro comum para problemas de conectividade é:
O nome remoto não pôde ser resolvido: 'github-enterprise-server.contoso.com'
Se você encontrar esse erro, verifique a acessibilidade do seu servidor. Para obter mais informações, confira Perguntas Frequentes sobre o DNS do Azure.
Selecione Configurações do projeto>Conexões GitHub>GitHub Enterprise Server para uma conexão pela primeira vez.
Ou, na caixa de diálogo Nova Conexão do GitHub, selecione GitHub Enterprise Server.
Selecione o método de autenticação.
Conectar-se ao OAuth
Escolha a configuração que você configurou na Etapa 4 de Registrar sua configuração do OAuth no Azure DevOps Servicese escolha Conectar.
Conectar-se por meio de um Token de Acesso Pessoal
Insira a URL do servidor GitHub Enterprise e as credenciais de token de acesso pessoal reconhecidas por esse servidor. Escolha Conectar.
Conecte-se com as credenciais do GitHub
Insira a URL do servidor GitHub Enterprise e as credenciais de conta de administrador reconhecidas por esse servidor e selecione Conectar.
A caixa de diálogo lista todos os repositórios para os quais você tem direitos de administração do GitHub. Você pode alternar entre Meu e Todos para determinar se outras pessoas aparecem e, em seguida, marcar as que deseja adicionar. Selecione Salvar ao terminar.
Dica
Você só pode fazer uma conexão com repositórios definidos em uma organização do GitHub. Para conectar um projeto a outros repositórios definidos em outra organização do GitHub, você deve adicionar outra conexão.
Se for a primeira vez que se conectar a uma conta ou organização do GitHub do Azure Boards, você também instalará o aplicativo Azure Boards para GitHub. Confirme a conexão anteriormente neste artigo.
A integração do Azure Boards com o GitHub usa vários protocolos de autenticação para manter a conexão. As alterações no escopo de permissão ou nas credenciais de autenticação de um usuário podem revogar os repositórios do GitHub conectados ao Azure Boards.
Para obter uma visão geral da integração suportada pelo aplicativo Azure Boards para GitHub, consulte Integração do Azure Boards com o GitHub.
As seguintes opções de autenticação suportadas dependem da plataforma GitHub à qual você está se conectando:
Plataforma
GitHub.com
GitHub Enterprise Server
Azure DevOps Services
- GitHub.com conta de usuário
- PAT (token de acesso pessoal)
- OAuth
- PAT
- Credenciais do GitHub
Azure DevOps Server 2020
Não aplicável
- PAT
- Credenciais do GitHub
Azure DevOps Server 2019
Não aplicável
- OAuth
- PAT
- Credenciais do GitHub
Observação
Com o aplicativo Azure Boards para GitHub, o Azure Boards e o Azure DevOps Services se integram aos repositórios do GitHub.com e do GitHub Enterprise Server. Azure DevOps Server 2019 e versões posteriores dão suporte à integração somente com repositórios GitHub Enterprise Server. Não há suporte para a integração com outros repositórios Git.
Se a integração entre o Azure Boards e o GitHub não estiver funcionando conforme o esperado, verifique se você concedeu acesso à organização.
No portal da Web do GitHub, abra Configurações no menu de perfil.
Selecione Aplicativos em Integrações>Aplicativos OAuth Autorizados>Azure Boards.
Em Acesso à organização, resolva possíveis problemas que possam aparecer. Selecione Conceder para conceder acesso a todas as organizações que aparecem com uma solicitação de Acesso pendente.
Quando a conexão do Azure Boards com o GitHub perde o acesso, um status de alerta com um X vermelho é exibido na interface do usuário. Passe o mouse sobre o alerta para ver que as credenciais não são mais válidas. Para corrigir o problema, remova a conexão e crie uma nova.
Para resolver esse problema, considere os itens a seguir:
Se a conexão estiver usando o OAuth:
O aplicativo Azure Boards teve seu acesso negado para um dos repositórios.
O GitHub pode estar indisponível/inacessível. Essa indisponibilidade pode ser devido a uma interrupção no serviço ou em um problema de infraestrutura/rede local. Você pode verificar o status do serviço nos seguintes links:
Exclua e recrie a conexão com o repositório GitHub. Essa conexão recriada faz com que o GitHub solicite a reautorização do Azure Boards.
Se a conexão estiver usando um PAT:
O PAT foi revogado ou os escopos de permissão necessários foram alterados e são insuficientes.
O usuário pode não ter permissões de administrador no repositório do GitHub.
Recrie o PAT e verifique se o escopo do token inclui as permissões necessárias:
repo, read:user, user:email, admin:repo_hook
. Para obter mais informações, consulte Práticas recomendadas para usar PATs.
Se você migrou do Azure DevOps Server para o Azure DevOps Services com uma conexão existente do GitHub Enterprise Server, sua conexão existente pode não funcionar como esperado. As menções de itens de trabalho no GitHub podem ser atrasadas ou nunca aparecer no Azure DevOps Services porque a URL de retorno de chamada associada ao GitHub não é mais válida. Considere as seguintes resoluções:
Remova e recrie a conexão: remova e recrie a conexão com o repositório do GitHub Enterprise Server. Siga a sequência de etapas fornecidas na documentação Conectar pelo Azure Boards.
Corrigir a URL do webhook: vá para a página de configurações do repositório do GitHub e edite a URL do webhook, apontando para a URL da organização de Azure DevOps migrada:
https://dev.azure.com/{OrganizationName}/_apis/work/events?api-version=5.2-preview
Conectar seu repositório GitHub a projetos em várias organizações do Azure DevOps, como dev.azure.com/Contoso e dev.azure.com/Fabrikam, pode causar resultados inesperados com menções AB#. Os IDs de itens de trabalho não são exclusivos nas organizações do Azure DevOps, portanto, AB#12 pode se referir a um item de trabalho na Contoso ou na Fabrikam. Quando um item de trabalho é mencionado em uma mensagem de confirmação ou solicitação de pull, ambas as organizações podem tentar vincular um item de trabalho com o ID correspondente, causando confusão.
Para evitar esse problema, conecte um único repositório GitHub a apenas uma organização do Azure DevOps.
Observação
Quando você se conecta usando o aplicativo Azure Boards para GitHub, o aplicativo impede conexões com várias organizações. Se um repositório do GitHub estiver conectado à organização errada do Azure DevOps, entre em contato com o proprietário dessa organização para remover a conexão antes de adicionar o repositório à organização correta do Azure DevOps.
Atualize as definições de XML para os tipos de itens de trabalho se a sua organização usar o modelo de processo XML hospedado ou XML local, para personalizar a experiência de rastreamento de trabalho, vincular e visualizar os tipos de links do GitHub na seção Desenvolvimento nos formulários de itens de trabalho.
Por exemplo, para vincular histórias de usuários e bugs a commits do GitHub e solicitações de pull da seção Desenvolvimento, será necessário atualizar as definições XML para histórias de usuário e bugs.
Siga a sequência de tarefas fornecidas em modelo de processo XML hospedado para atualizar as definições XML. Para cada tipo de item de trabalho, localize a seção Group Label="Development"
e adicione as duas linhas a seguir na seguinte sintaxe de código para dar suporte aos tipos de links externos: Commit do GitHub e Solicitação de pull do GitHub.
<ExternalLinkFilter Type="GitHub Pull Request" />
<ExternalLinkFilter Type="GitHub Commit" />
Após a atualização, a seção deve aparecer da forma a seguir.
<Group Label="Development">
<Control Type="LinksControl" Name="Development">
<LinksControlOptions ViewMode="Dynamic" ZeroDataExperience="Development" ShowCallToAction="true">
<ListViewOptions GroupLinks="false">
</ListViewOptions>
<LinkFilters>
<ExternalLinkFilter Type="Build" />
<ExternalLinkFilter Type="Integrated in build" />
<ExternalLinkFilter Type="Pull Request" />
<ExternalLinkFilter Type="Branch" />
<ExternalLinkFilter Type="Fixed in Commit" />
<ExternalLinkFilter Type="Fixed in Changeset" />
<ExternalLinkFilter Type="Source Code File" />
<ExternalLinkFilter Type="Found in build" />
<ExternalLinkFilter Type="GitHub Pull Request" />
<ExternalLinkFilter Type="GitHub Commit" />
</LinkFilters>
</LinksControlOptions>
</Control>
</Group>
P: Alguns dos meus usuários no Azure DevOps têm identidades do GitHub. Preciso adicioná-los como novos usuários do GitHub para a minha organização?
R: Não. Peça aos usuários que saiam e entrem novamente na organização com suas credenciais do GitHub em uma nova sessão do navegador. Essa ação estabelecerá suas identidades no GitHub.
P: sou administrador de uma organização e habilitei a política para convidar usuários do GitHub. Por que não posso convidar novos usuários do GitHub?
R: depois de alterar a configuração, saia do Azure DevOps e entre novamente na organização (dev.azure.com/{organizationName}
ou organizationName.visualstudio.com
) com suas credenciais do GitHub em uma nova sessão do navegador.
R: Somente administradores de organização ou projeto podem convidar novos usuários para ingressar na organização. Talvez você não tenha as permissões necessárias para adicionar novos usuários. Trabalhe com seu administrador para obter as permissões necessárias ou peça que ele adicione o usuário para você.