Вы не упоминаете язык сценариев, который хотите использовать, поэтому я буду говорить конкретно о HTTP-запросах к API BitBucket:
Предположения
Если у вас есть репозиторий BitBucket, в котором есть три коммита, первый и последний потерпели неудачу при сборке, середина проходит:
- 4768815 ❌
- 49d7110 ✅
- 42d357f ❌
Получить список коммитов
Вы можете получить список коммитов, вызвав следующий метод API:
https://api.bitbucket.org/2.0/repositories/{{owner}}/{{repo_slug}}/commits
owner
: RichardSlater
repo_slug
: greencommitproofofconcept
Ответ выглядит так:
{
"pagelen": 30,
"values": [
{
"hash": "4768815fdc27abf4be17096e7c460f7f68f5d39b",
"repository": { ... },
"links": {
...
"statuses": {
"href": "https://api.bitbucket.org/2.0/repositories/RichardSlater/greencommitproofofconcept/commit/4768815fdc27abf4be17096e7c460f7f68f5d39b/statuses"
}
},
"author": { ... },
"parents": [ ... ],
"date": "2017-04-10T11:38:18+00:00",
"message": "README.md edited online with Bitbucket",
"type": "commit"
},
{
"hash": "49d7110b98616358d16055960a4abdf2926b890d",
...
},
{
"hash": "42d357f1df7a7d7bcf1f10a9f3a5a40d85d5b11c",
...
}
]
}
Если вы анализируете JSON и перебираете ответы, вы можете извлечь статусы из:
values[n].links.statuses.href
Где n
это индекс, то есть 0
, 1
или 2
в приведенном выше примере. Если бы вы построили это с нуля, это было бы в следующем формате.
Получить список статусов от коммита
https://api.bitbucket.org/2.0/repositories/{{owner}}/{{repo_slug}}/commit/{{sha}}/statuses"
owner
: RichardSlater
repo_slug
: greencommitproofofconcept
sha
: 4768815fdc27abf4be17096e7c460f7f68f5d39b
Примечание: это Hypermedia API, который означает, что URL-адреса могут измениться, поэтому я бы рекомендовал использовать ссылки из предыдущего ответа, а не пытаться сгенерировать их с нуля.
Ответ от вышеуказанного HTTP-запроса будет примерно таким:
{
"pagelen": 10,
"values": [
{
"key": "POC-01",
"name": "Build #1",
"repository": { ... },
"url": "http://devops.stackexchange.com/q/809/397",
"links": { ... },
"refname": null,
"state": "FAILED",
"created_on": "2017-04-10T13:04:28.261734+00:00",
"updated_on": "2017-04-10T13:04:28.261759+00:00",
"type": "build",
"description": "Changes by Richard Slater"
}
],
"page": 1,
"size": 1
}
Из этого ответа вы можете извлечь state
используя:
values[n].state
Опять же, где n
это status
- там может быть много , если один коммит привел многие сборки.
Если состояние для сборки, о которой вы заботитесь, SUCCESSFUL
значит, у вас есть ответ, и вы можете немедленно вернуть sha
коммит.
Зацикливайтесь на всех коммитах с первой фазы, если у вас кончились коммиты, перейдите на next
страницу, link
которая включена в вызов /commits
.
Полная блок-схема
На высоком уровне поток будет выглядеть так:
Не забывайте, что это API-интерфейс Hypermedia, поэтому, по возможности, ваш код должен следовать ссылкам в API, а не пытаться их «угадать».