summaryrefslogtreecommitdiffstats
path: root/cns-libs/templates/jenkins/files/start-load-on-jenkins.j2
blob: 7c85e8bd6dcf18cf642fa88a7669c3fa8cea5efb (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
#!/bin/bash

readonly TOTAL_BUILD_NUMBER=29
readonly JENKINS_URL=$(awk '/^url/{split ($1, a, "="); print a[2]}' /etc/jenkins_jobs/jenkins_jobs.ini)

echo "JENKINS_URL: $JENKINS_URL"

function trigger() {
    local url
    local job_name

    url=$1
    job_name=$2

    echo "Start job: $job_name"
    curl -s -k --user admin:password -X POST "${url}/job/${job_name}/build/api/json" --data-urlencode json='{"parameter": []}'
}


function check_build() {
    local result
    local job_name
    local url

    url=$1
    job_name=$2

    echo "Executing validation for job: ${job_name}"
    result=$(curl -s -k --user admin:password ${url}/job/${job_name}/lastBuild/api/json | python -c "import json,sys; obj=json.load(sys.stdin); print obj['result'] if 'result' in obj else False")

    echo "Status: ${result}"
    if [[ "${result}" = "SUCCESS" ]] || [[ "${result}" = "FAILURE" ]] || [[ "${result}" = "UNSTABLE" ]] || [[ "${result}" = "ABORTED" ]]
    then
        echo "Build completed, re-starting build"
        trigger "${JENKINS_URL}" "${job_name}"
    else
        echo "Build in progress, waiting for completion"
    fi
}


### delete jobs
echo "Delete existing jobs"
for j in $(seq 0 ${TOTAL_BUILD_NUMBER})
do
    jenkins-jobs delete test-${j}_job
done

echo "Wait for 30 sec until all jobs get created"
sleep 30

### create jobs
echo "Create new jobs"
jenkins-jobs --flush-cache update --delete-old /data

echo "Wait for 30 sec until all jobs get created"
sleep 30

### trigger jobs
echo "Start building new job"
for j in $(seq 0 ${TOTAL_BUILD_NUMBER})
do
    trigger "${JENKINS_URL}" "test-${j}_job"
done

echo "Wait for 2 mins to jenkin schedule and start the jobs"
sleep 120

### check jobs
echo "Start polling status for started jobs"

while true
do
    for i in $(seq 0 ${TOTAL_BUILD_NUMBER})
    do
        check_build "${JENKINS_URL}" "test-${i}_job/job/ttt"
    done

    echo "Validated all jobs geting some rest"
    sleep 30
done