SonarQube: получение хэшей коммитов git через веб-API

Если я правильно понял, согласно документации веб-API SonarQube должна быть возможность получить хэш коммита через api/issues/search, однако, когда я это делаю и сравниваю этот хэш с :

git log --all | grep "<hash>"

Я ничего не получаю в ответ, что приводит меня к двум вопросам:

  1. Я неправильно понял (иногда довольно загадочную) документацию по веб-API, и это хэш для чего-то другого, или я мог что-то неправильно настроить, и поэтому я получаю случайные значения?

  2. Есть ли способ получить корреляцию проблем/мер из проекта и соответствующих хэшей коммитов? В этом случае можно использовать SQL-запрос к PostgreSQL? Если да, то есть идеи о том, где будет храниться эта информация?


person GoDieNow    schedule 18.02.2019    source источник


Ответы (1)


Итак, подождав некоторое время, похоже, что ответа нет, поскольку вы уже здесь... Давайте избегать это

Итак, у вас есть кусок кода bash для создания таблицы с корреляцией между датами из файла с вашими извлеченными данными и коммитами проекта.

Вероятно, не лучший подход и не самый быстрый, но он даст вам то, что вам нужно :)

Сохраните в файле.sh и используйте как: ./file.sh GithubUser/ProjectName YourFileWithTheExtractedData.csv

#!/bin/bash

gitproject="[email protected]:${1}.git"
gitfolder=$(echo $gitproject | sed -E 's/(.+)\/(.+\.git$)/\2/g')
workdir="$(pwd)"
measuresFile=$2

if [ ! -d "$workdir/$gitfolder" ];
then
        $(git -C $workdir clone -q --bare $gitproject)
fi

echo '"sonar-timestamp","git-timestamp","commit-hash"' >> $workdir/Hashes_$2
cat $workdir/$measuresFile | grep -Eo '"[[:digit:]]{4}-[[:digit:]]{2}-[[:digit:]]{2}T[[:digit:]]{2}:[[:digit:]]{2}:[[:digit:]]{2}\+[[:digit:]]{4}",' | sed -E 's/"|",//g' | sort -u >> $workdir/TMP_Hashes_$2
for i in $( cat $workdir/TMP_Hashes_$2 | sort -u ); do echo $(echo $i | date '+%s' -f - ),"$i" >> $workdir/Hashes_$2 ; done
rm -rf $workdir/TMP_Hashes_$2

gHashes=( $(TZ=Europe/London git -C $workdir/$gitfolder log --all --date=format-local:%Y-%m-%dT%H:%M:%S%z --format=%ad\ %H | sort | tr '\n' ' ') )

COUNTER=0
while (("$COUNTER" < "${#gHashes[@]}"))
do
        sust=$(date -d "${gHashes[$COUNTER]}" '+%s')
        notInc=$(cat $workdir/Hashes_$2 | grep -o "^${sust}" | wc -l )
        $(sed -i -E "s/(^${sust}),(.+)/\"\2\",\"${gHashes[($COUNTER)]}\",\"${gHashes[($COUNTER + 1)]}\"/g" $workdir/Hashes_$2)

        if (( "$notInc" == "0" ));
        then
                rHashes+=( "${gHashes[($COUNTER)]}" "${gHashes[($COUNTER + 1)]}" )
        fi

        let COUNTER=COUNTER+2
done

$(sed -i -E "s/(^[0-9]+),(.+)/\"\2\",\"\",\"\"/g" $workdir/Hashes_$2)

COUNTER=0
while (("$COUNTER" < "${#rHashes[@]}"))
do
        echo "\"\",\"${rHashes[($COUNTER)]}\",\"${rHashes[($COUNTER + 1)]}\"" >> $workdir/Hashes_$2
        let COUNTER=COUNTER+2
done
person GoDieNow    schedule 17.04.2019