summaryrefslogtreecommitdiff
path: root/.gitlab-ci/check-commit-log.sh
blob: c309ff2254e06e04d24188f5c7506803dcb7c3b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env bash

if [ -z "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME" ]; then
  echo Cannot review non-merge request
  exit 1
fi

git fetch $CI_MERGE_REQUEST_PROJECT_URL.git $CI_MERGE_REQUEST_TARGET_BRANCH_NAME

branch_point=$(git merge-base HEAD FETCH_HEAD)

commits=$(git log --format='format:%H' $branch_point..$CI_COMMIT_SHA)

if [ -z "$commits" ]; then
  echo Commit range empty
  exit 1
fi

function commit_message_has_mr_url() {
  commit=$1
  commit_message=$(git show -s --format='format:%b' $commit)
  echo "$commit_message" | grep -qe "^$CI_MERGE_REQUEST_PROJECT_URL\/\(-\/\)\?merge_requests\/$CI_MERGE_REQUEST_IID$"
  return $?
}

JUNIT_REPORT_TESTS_FILE=$(mktemp)

function append_failed_test_case() {
  test_name="$1"
  commit="$2"
  test_message="$3"
  commit_short=${commit:0:8}

  echo "<testcase name=\"$test_name: $commit_short\"><failure message=\"$commit_short: $test_message\"/></testcase>" >> $JUNIT_REPORT_TESTS_FILE
  echo &>2 "Commit check failed: $commit_short: $test_message"
}

function append_passed_test_case() {
  test_name="$1"
  commit="$2"
  commit_short=${commit:0:8}

  echo "<testcase name=\"$test_name: $commit_short\"></testcase>" >> $JUNIT_REPORT_TESTS_FILE
}

function generate_junit_report() {
  junit_report_file="$1"
  num_tests=$(cat "$JUNIT_REPORT_TESTS_FILE" | wc -l)
  num_failures=$(grep '<failure />' "$JUNIT_REPORT_TESTS_FILE" | wc -l )

  echo Generating JUnit report \"$(pwd)/$junit_report_file\" with $num_tests tests and $num_failures failures.

  cat > $junit_report_file << __EOF__
<?xml version="1.0" encoding="utf-8"?>
<testsuites tests="$num_tests" errors="0" failures="$num_failures">
<testsuite name="commit-review" tests="$num_tests" errors="0" failures="$num_failures" skipped="0">
$(< $JUNIT_REPORT_TESTS_FILE)
</testsuite>
</testsuites>
__EOF__
}

function check_commit_message_subject() {
  commit=$1
  commit_message_subject=$(git show -s --format='format:%s' $commit)

  if echo "$commit_message_subject" | grep -qe "\(^meta-\|^Meta\)"; then
    append_failed_test_case meta-prefix $commit \
      "Commit message subject should not be prefixed with 'meta-' or 'Meta'"
  else
    append_passed_test_case meta-prefix $commit
  fi

  if echo "$commit_message_subject" | grep -qe "\(^clutter-\|^Clutter\)"; then
    append_failed_test_case clutter-prefix $commit \
      "Commit message subject should not be prefixed with 'clutter-' or 'Clutter', use 'clutter/' instead"
  else
    append_passed_test_case clutter-prefix $commit
  fi

  if echo "$commit_message_subject" | grep -qe "\(^cogl-\|^Cogl\)"; then
    append_failed_test_case cogl-prefix $commit \
      "Commit message subject should not be prefixed with 'cogl-' or 'Cogl', use 'cogl/' instead"
  else
    append_passed_test_case cogl-prefix $commit
  fi

  if echo "$commit_message_subject" | sed -e 's/^[^:]\+: //' | grep -qe '^[[:lower:]]'; then
    append_failed_test_case capitalization $commit \
      "Commit message subject should be properly Capitalized. E.g. 'window: Marginalize extradicity'"
  else
    append_passed_test_case capitalization $commit
  fi

  if echo "$commit_message_subject" | grep -qe "\.[ch]:"; then
    append_failed_test_case not-file-suffix $commit \
      "Commit message subject prefix should not include .c, .h, etc."
  else
    append_passed_test_case not-file-suffix $commit
  fi

  return 0
}

RET=0
for commit in $commits; do

  if commit_message_has_mr_url $commit; then
    append_failed_test_case superfluous_url $commit \
      "Commit message must not contain a link to its own merge request"
  else
    append_passed_test_case superfluous_url $commit
  fi

  check_commit_message_subject $commit
done

generate_junit_report commit-message-junit-report.xml

! grep -q '<failure' commit-message-junit-report.xml
exit $?