У меня есть webhook, который прослушивает все обзоры кода, затем я выбираю комментарии этого PR-обзора, чтобы получить позицию комментария в diff.Я использую GitHub REST API, но у меня такая же проблема с GraphQL API.
Итак, рабочий процесс:
- Получить идентификатор отзыва из webhook
- Извлечение списка комментариев этого обзора
- Для каждого комментария, получите блок diff и позицию, чтобы найти отредактированную строку
Все это прекрасно работает 99%времени.Иногда я получаю null
в позиции, я игнорирую эти комментарии.
Но на этот раз у меня возникает еще одна странная проблема.Обычно позиция относится к индексу строки в diff.
Например, в:
@@ -1 +1,3 @@
-# sedy-test
\\ No newline at end of file
+# sedy-test
+
+This repository is used to test [sedy](https://github.com/marmelab/sedy).
Если позиция равна 3, редактируемая строка равна +# sedy-test
.
Проблема в том, что для некоторых комментариев я получаю позицию, которая не может быть внутри различий.В качестве примера см. этот PR .
Когда я пытаюсь получить позицию комментария обзора со следующим запросом:
{
repository(owner: "Kmaschta", name: "comfygure") {
pullRequest(number: 1) {
reviews(last: 1) {
edges {
node {
state
comments(first: 1) {
edges {
node {
bodyText
authorAssociation
position
originalPosition
diffHunk
}
}
}
}
}
}
}
}
}
Ответ следующий:
{
"data": {
"repository": {
"pullRequest": {
"reviews": {
"edges": [
{
"node": {
"state": "COMMENTED",
"comments": {
"edges": [
{
"node": {
"bodyText": "s/fot/for/",
"authorAssociation": "OWNER",
"position": 71,
"originalPosition": 71,
"diffHunk": "@@ -24,31 +34,39 @@ const ls = (ui, modules) => function* () {\n };\n \n const add = (ui, modules, options) => function* () {\n- const { red, bold } = ui.colors;\n+ const { red, bold, green } = ui.colors;\n \n if (!options.length) {\n ui.error(`${red('No environment specified.')}`);\n- help(ui, 1);\n }\n \n if (options.length > 1) {\n ui.error(`${red('Invalid environment format. The environment name should be one word.')}`);\n- help(ui, 1);\n+ }\n+\n+ if (options.length !== 1) {\n+ ui.print(`${bold('SYNOPSIS')}\n+ ${bold('comfy')} env add <environment>\n+\n+Type ${green('comfy env --help')} for details`);\n+\n+ return ui.exit(0);\n }\n \n const project = yield modules.project.retrieveFromConfig();\n const environment = yield modules.environment.add(project, options[0]);\n- const addCommand = `comfy add ${environment.name}`;\n+ const addCommand = `comfy setall ${environment.name}`;\n \n- ui.print(`${bold('Cool!')} Your new environment \"${bold(environment.name)}\" was successfully saved.`);\n- ui.print(`You can now add a configuration, try ${bold(addCommand)}`);\n+ ui.print(`${bold(green('Environment successfully created'))}`);\n+ ui.print(`You can now set a configuration fot this environment using ${bold(addCommand)}`);"
}
}
]
}
}
}
]
}
}
}
}
}
Позиция составляет 71, но разница не содержит более 40 строк.
Так что это ошибка, если GitHub API, или я не понялточка поля позиции?
Примечание: я выложил такой же вопрос на форуме GitHub , почему пока нет ответа.