Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 3 | set -xe |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 4 | |
Paul Sokolovsky | 896532e | 2023-05-12 23:22:49 +0300 | [diff] [blame] | 5 | USE_SQUAD=0 |
Paul Sokolovsky | 35c231a | 2023-05-12 22:53:23 +0300 | [diff] [blame] | 6 | |
Leonardo Sandoval | 5a33566 | 2021-03-26 19:57:40 -0600 | [diff] [blame] | 7 | # Wait for the LAVA job to finished |
| 8 | # By default, timeout at 5400 secs (1.5 hours) and monitor every 60 seconds |
| 9 | wait_lava_job() { |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 10 | set +x |
Leonardo Sandoval | 5a33566 | 2021-03-26 19:57:40 -0600 | [diff] [blame] | 11 | local id=$1 |
| 12 | local timeout="${2:-5400}" |
| 13 | local interval="${3:-60}" |
| 14 | |
| 15 | (( t = timeout )) |
| 16 | |
| 17 | while ((t > 0)); do |
| 18 | sleep $interval |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 19 | resilient_cmd lavacli jobs show $id | tee "${WORKSPACE}/lava-progress.show" | grep 'state *:' |
| 20 | set +x |
Leonardo Sandoval | 5a33566 | 2021-03-26 19:57:40 -0600 | [diff] [blame] | 21 | if grep 'state.*: Finished' "${WORKSPACE}/lava-progress.show"; then |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 22 | set -x |
| 23 | cat "${WORKSPACE}/lava-progress.show" |
Paul Sokolovsky | a153b60 | 2022-10-12 20:50:05 +0300 | [diff] [blame] | 24 | # finished |
| 25 | return 0 |
Leonardo Sandoval | 5a33566 | 2021-03-26 19:57:40 -0600 | [diff] [blame] | 26 | fi |
| 27 | ((t -= interval)) |
| 28 | done |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 29 | set -x |
| 30 | cat "${WORKSPACE}/lava-progress.show" |
| 31 | echo "Timeout waiting for job to finish" |
Paul Sokolovsky | a153b60 | 2022-10-12 20:50:05 +0300 | [diff] [blame] | 32 | # timeout |
| 33 | return 1 |
Leonardo Sandoval | 5a33566 | 2021-03-26 19:57:40 -0600 | [diff] [blame] | 34 | } |
| 35 | |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 36 | # Run the given command passed through parameters, if fails, try |
| 37 | # at most more N-times with a pause of M-seconds until success. |
| 38 | resilient_cmd() { |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 39 | set +x |
Paul Sokolovsky | 7fb59b5 | 2023-05-13 10:00:57 +0300 | [diff] [blame] | 40 | local max_retries=10 |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 41 | local sleep_body=2 |
| 42 | local iter=0 |
| 43 | |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 44 | while true; do |
Paul Sokolovsky | 04004c1 | 2023-02-24 18:27:40 +0700 | [diff] [blame] | 45 | if "$@"; then |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 46 | break |
| 47 | fi |
| 48 | |
| 49 | sleep ${sleep_body} |
Paul Sokolovsky | 719ac1d | 2023-05-13 10:03:37 +0300 | [diff] [blame] | 50 | # Exponential backoff |
| 51 | sleep_body=$(( sleep_body * 2 )) |
| 52 | if [ ${sleep_body} -ge 60 ]; then |
| 53 | sleep_body=60 |
| 54 | echo "WARNING: Command '$@' still not successful on retry #${iter}, exp backoff already limited" 1>&2 |
| 55 | fi |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 56 | |
| 57 | iter=$(( iter + 1 )) |
Paul Sokolovsky | 7fb59b5 | 2023-05-13 10:00:57 +0300 | [diff] [blame] | 58 | if [ ${iter} -ge ${max_retries} ]; then |
Paul Sokolovsky | 1f0b748 | 2023-05-09 22:47:49 +0300 | [diff] [blame] | 59 | echo "ERROR: Command '$@' failed ${iter} times in row" 1>&2 |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 60 | set -x |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 61 | return 1 |
| 62 | fi |
| 63 | done |
Paul Sokolovsky | 99eaff6 | 2023-01-25 19:41:23 +0700 | [diff] [blame] | 64 | set -x |
Leonardo Sandoval | eb94e91 | 2021-01-29 12:23:59 -0600 | [diff] [blame] | 65 | return 0 |
| 66 | } |
| 67 | |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 68 | ls -l ${WORKSPACE} |
| 69 | |
Paul Sokolovsky | eab838b | 2023-12-30 00:15:48 +0300 | [diff] [blame] | 70 | function submit_via_lava_or_squad() { |
| 71 | |
Paul Sokolovsky | 35c231a | 2023-05-12 22:53:23 +0300 | [diff] [blame] | 72 | lavacli identities add --username ${LAVA_USER} --token ${LAVA_TOKEN} --uri "https://${LAVA_SERVER}/RPC2" default |
| 73 | |
| 74 | if [ $USE_SQUAD -ne 0 -a -n "${QA_SERVER_VERSION}" ]; then |
| 75 | # Submit via SQUAD |
| 76 | |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 77 | if [ -n "${GERRIT_CHANGE_NUMBER}" ] && [ -n "${GERRIT_PATCHSET_NUMBER}" ]; then |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 78 | curl \ |
Paul Sokolovsky | a3ac126 | 2022-07-08 16:03:48 +0300 | [diff] [blame] | 79 | --fail \ |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 80 | --retry 4 \ |
| 81 | -X POST \ |
| 82 | --header "Auth-Token: ${QA_REPORTS_TOKEN}" \ |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 83 | ${QA_SERVER}/api/createbuild/${QA_SERVER_TEAM}/${QA_SERVER_PROJECT}/${QA_SERVER_VERSION} |
| 84 | fi |
| 85 | |
| 86 | TESTJOB_ID=$(curl \ |
Paul Sokolovsky | a3ac126 | 2022-07-08 16:03:48 +0300 | [diff] [blame] | 87 | --fail \ |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 88 | --retry 4 \ |
| 89 | -X POST \ |
| 90 | --header "Auth-Token: ${QA_REPORTS_TOKEN}" \ |
| 91 | --form backend=${LAVA_SERVER} \ |
Chris Kay | f6ff467 | 2022-11-03 13:09:44 +0000 | [diff] [blame] | 92 | --form definition=@artefacts-lava/job.yaml \ |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 93 | ${QA_SERVER}/api/submitjob/${QA_SERVER_TEAM}/${QA_SERVER_PROJECT}/${QA_SERVER_VERSION}/${DEVICE_TYPE}) |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 94 | |
Arthur She | 2770cee | 2022-09-14 15:12:18 -0700 | [diff] [blame] | 95 | # SQUAD will send 400, curl error code 22, on bad test definition |
| 96 | if [ "$?" = "22" ]; then |
| 97 | echo "Bad test definition!!" |
| 98 | exit 1 |
| 99 | fi |
| 100 | |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 101 | if [ -n "${TESTJOB_ID}" ]; then |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 102 | echo "TEST JOB URL: ${QA_SERVER}/testjob/${TESTJOB_ID} TEST JOB ID: ${TESTJOB_ID}" |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 103 | |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 104 | |
Leonardo Sandoval | 73d301a | 2021-02-12 13:42:55 -0600 | [diff] [blame] | 105 | # The below loop with a sleep is intentional: LAVA could be under heavy load so previous job creation can |
| 106 | # take 'some' time to get the right numeric LAVA JOB ID |
| 107 | renumber='^[0-9]+$' |
| 108 | LAVAJOB_ID="null" |
| 109 | iter=0 |
Chris Kay | f1b3da9 | 2022-09-08 13:15:16 +0100 | [diff] [blame] | 110 | max_tries=120 # run retries for an hour |
Leonardo Sandoval | 73d301a | 2021-02-12 13:42:55 -0600 | [diff] [blame] | 111 | while ! [[ $LAVAJOB_ID =~ $renumber ]]; do |
| 112 | if [ $iter -eq $max_tries ] ; then |
| 113 | LAVAJOB_ID='' |
| 114 | break |
| 115 | fi |
Leonardo Sandoval | 8267f43 | 2021-05-07 10:02:00 -0500 | [diff] [blame] | 116 | sleep 30 |
Paul Sokolovsky | a3ac126 | 2022-07-08 16:03:48 +0300 | [diff] [blame] | 117 | LAVAJOB_ID=$(curl --fail --retry 4 ${QA_SERVER}/api/testjobs/${TESTJOB_ID}/?fields=job_id) |
Leonardo Sandoval | 73d301a | 2021-02-12 13:42:55 -0600 | [diff] [blame] | 118 | |
| 119 | # Get the job_id value (whatever it is) |
| 120 | LAVAJOB_ID=$(echo ${LAVAJOB_ID} | jq '.job_id') |
| 121 | LAVAJOB_ID="${LAVAJOB_ID//\"/}" |
| 122 | |
| 123 | iter=$(( iter + 1 )) |
| 124 | done |
Paul Sokolovsky | 35c231a | 2023-05-12 22:53:23 +0300 | [diff] [blame] | 125 | fi |
| 126 | else |
| 127 | # Submit directly to LAVA |
| 128 | LAVAJOB_ID=$(resilient_cmd lavacli jobs submit artefacts-lava/job.yaml) |
| 129 | fi |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 130 | |
Paul Sokolovsky | 35c231a | 2023-05-12 22:53:23 +0300 | [diff] [blame] | 131 | |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 132 | # check that rest query at least get non-empty value |
| 133 | if [ -n "${LAVAJOB_ID}" ]; then |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 134 | |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 135 | echo "LAVA URL: https://${LAVA_SERVER}/scheduler/job/${LAVAJOB_ID} LAVA JOB ID: ${LAVAJOB_ID}" |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 136 | |
Leonardo Sandoval | a8078d6 | 2021-02-11 16:29:25 -0600 | [diff] [blame] | 137 | |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 138 | # if timeout on waiting for LAVA to complete, create an 'artificial' lava.log indicating |
| 139 | # job ID and timeout seconds |
| 140 | if ! wait_lava_job ${LAVAJOB_ID}; then |
| 141 | echo "Stopped monitoring LAVA JOB ${LAVAJOB_ID}, likely stuck or timeout too short?" | tee "${WORKSPACE}/lava.log" |
| 142 | exit 1 |
| 143 | else |
| 144 | # Retrieve the test job plain log which is a yaml format file from LAVA |
| 145 | resilient_cmd sh -c "lavacli jobs logs --raw ${LAVAJOB_ID} > ${WORKSPACE}/lava-raw.log" |
Arthur She | 5fc7427 | 2021-03-26 21:24:34 -0700 | [diff] [blame] | 146 | |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 147 | # Fetch and store LAVA job result (1 failure, 0 success) |
| 148 | resilient_cmd lavacli results ${LAVAJOB_ID} | tee "${WORKSPACE}/lava.results" |
| 149 | if grep -q '\[fail\]' "${WORKSPACE}/lava.results"; then |
Paul Sokolovsky | eab838b | 2023-12-30 00:15:48 +0300 | [diff] [blame] | 150 | return 1 |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 151 | else |
Paul Sokolovsky | eab838b | 2023-12-30 00:15:48 +0300 | [diff] [blame] | 152 | return 0 |
Leonardo Sandoval | 9f15980 | 2021-01-20 16:47:25 -0600 | [diff] [blame] | 153 | fi |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 154 | fi |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 155 | else |
| 156 | echo "LAVA Job ID could not be obtained" |
| 157 | exit 1 |
Milosz Wasilewski | 1043858 | 2020-12-03 11:36:21 +0000 | [diff] [blame] | 158 | fi |
Paul Sokolovsky | 74cd2e0 | 2023-05-12 23:40:55 +0300 | [diff] [blame] | 159 | |
Paul Sokolovsky | eab838b | 2023-12-30 00:15:48 +0300 | [diff] [blame] | 160 | } |
| 161 | |
| 162 | # FIXME: Juno and FVP jobs may fail due to non-related users changes, |
| 163 | # so CI needs to resubmit the job, at most three times: |
| 164 | # Juno jobs may fail due to LAVA lab infrastructure issues (see |
| 165 | # https://projects.linaro.org/browse/LSS-2128) |
| 166 | # FVP jobs may hang at some particular TFTF test (see |
| 167 | # https://linaro.atlassian.net/browse/TFC-176) |
| 168 | |
| 169 | # UPDATE: We want to keep retrying for LAVA for historical reasons, |
| 170 | # but we want to start from clean page with TuxSuite, so don't |
| 171 | # retry for it for now, and see how it goes. |
| 172 | |
| 173 | status=1 |
| 174 | for i in $(seq 1 ${LAVA_RETRIES:-3}); do |
| 175 | echo "# LAVA submission iteration #$i" |
| 176 | if submit_via_lava_or_squad; then |
| 177 | status=0 |
| 178 | break |
| 179 | fi |
| 180 | done |
| 181 | |
| 182 | exit ${status} |