Merge "Rectify inter-job blocking strategy"
[releng.git] / jjb / bottlenecks / bottlenecks-ci-jobs.yml
1 ####################################
2 # job configuration for bottlenecks
3 ####################################
4 - project:
5     name: bottlenecks-ci-jobs
6
7     project: 'bottlenecks'
8
9 #--------------------------------
10 # BRANCH ANCHORS
11 #--------------------------------
12     master: &master
13         stream: master
14         branch: '{stream}'
15         #This is used for common project file storage
16         gs-pathname: ''
17         #This is used for different test suite dependent packages storage
18         gs-packagepath: '/{suite}'
19         #docker tag used for version control
20         docker-tag: 'latest'
21     danube: &danube
22         stream: danube
23         branch: 'stable/{stream}'
24         gs-pathname: '/{stream}'
25         gs-packagepath: '/{stream}/{suite}'
26         docker-tag: 'stable'
27 #--------------------------------
28 # POD, INSTALLER, AND BRANCH MAPPING
29 #--------------------------------
30 #    Installers using labels
31 #            CI PODs
32 # This section should only contain the installers
33 # that have been switched using labels for slaves
34 #--------------------------------
35     pod:
36 #compass CI PODs
37         - baremetal:
38             slave-label: compass-baremetal-master
39             installer: compass
40             auto-trigger-name: 'daily-trigger-disabled'
41             <<: *master
42         - virtual:
43             slave-label: compass-virtual-master
44             installer: compass
45             auto-trigger-name: 'daily-trigger-disabled'
46             <<: *master
47         - baremetal:
48             slave-label: compass-baremetal-branch
49             installer: compass
50             auto-trigger-name: 'daily-trigger-disabled'
51             <<: *danube
52         - virtual:
53             slave-label: compass-virtual-branch
54             installer: compass
55             auto-trigger-name: 'daily-trigger-disabled'
56             <<: *danube
57
58 #--------------------------------
59 #        None-CI PODs
60 #--------------------------------
61        # - orange-pod2:
62        #     slave-label: '{pod}'
63        #     installer: joid
64        #     auto-trigger-name: 'daily-trigger-disabled'
65        #     <<: *danube
66        # - orange-pod2:
67        #     slave-label: '{pod}'
68        #     installer: joid
69        #     auto-trigger-name: 'daily-trigger-disabled'
70        #     <<: *master
71 #--------------------------------------------
72     suite:
73         - 'posca_stress_traffic'
74         - 'posca_stress_ping'
75
76     jobs:
77         - 'bottlenecks-{installer}-{suite}-{pod}-daily-{stream}'
78
79 ################################
80 # job templates
81 ################################
82 - job-template:
83     name: 'bottlenecks-{installer}-{suite}-{pod}-daily-{stream}'
84
85     wrappers:
86         - build-name:
87             name: '$BUILD_NUMBER - Scenario: $DEPLOY_SCENARIO'
88         - timeout:
89             timeout: 180
90             abort: true
91
92     triggers:
93         - '{auto-trigger-name}'
94
95     parameters:
96         - project-parameter:
97             project: '{project}'
98             branch: '{branch}'
99         - '{slave-label}-defaults'
100         - '{installer}-defaults'
101         - 'bottlenecks-params-{slave-label}'
102         - string:
103             name: REPO_DIR
104             default: "/home/opnfv/bottlenecks"
105             description: "Directory where the repository is cloned"
106         - string:
107             name: DEPLOY_SCENARIO
108             default: 'os-odl_l2-nofeature-ha'
109         - string:
110             name: GERRIT_REFSPEC_DEBUG
111             default: 'true'
112             description: "Gerrit refspec for debug."
113         - string:
114             name: SUITE_NAME
115             default: '{suite}'
116             description: "test suite name."
117         - string:
118             name: DOCKER_TAG
119             default: '{docker-tag}'
120             description: "docker image tag used for version control"
121
122     scm:
123         - git-scm
124
125     builders:
126         - 'bottlenecks-env-cleanup'
127         - 'bottlenecks-run-suite'
128
129     publishers:
130         - email:
131             recipients: gabriel.yuyang@huawei.com, liyin11@huawei.com
132         - email-jenkins-admins-on-failure
133
134 ########################
135 # builder macros
136 ########################
137 - builder:
138     name: bottlenecks-env-cleanup
139     builders:
140         - shell:
141             !include-raw: ./bottlenecks-cleanup.sh
142
143 - builder:
144     name: bottlenecks-run-suite
145     builders:
146         - shell:
147             !include-raw: ./bottlenecks-run-suite.sh
148
149 ####################
150 # parameter macros
151 ####################
152
153 - parameter:
154     name: 'bottlenecks-params-compass-baremetal-master'
155     parameters:
156         - string:
157             name: BOTTLENECKS_DB_TARGET
158             default: 'http://testresults.opnfv.org/test/api/v1/results'
159             description: 'Arguments to use in order to choose the backend DB'
160
161 - parameter:
162     name: 'bottlenecks-params-compass-virtual-master'
163     parameters:
164         - string:
165             name: BOTTLENECKS_DB_TARGET
166             default: 'http://testresults.opnfv.org/test/api/v1/results'
167             description: 'Arguments to use in order to choose the backend DB'
168
169 - parameter:
170     name: 'bottlenecks-params-compass-baremetal-branch'
171     parameters:
172         - string:
173             name: BOTTLENECKS_DB_TARGET
174             default: 'http://testresults.opnfv.org/test/api/v1/results'
175             description: 'Arguments to use in order to choose the backend DB'
176
177 - parameter:
178     name: 'bottlenecks-params-compass-virtual-branch'
179     parameters:
180         - string:
181             name: BOTTLENECKS_DB_TARGET
182             default: 'http://testresults.opnfv.org/test/api/v1/results'
183             description: 'Arguments to use in order to choose the backend DB'