You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

733 lines
21 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
  1. stages:
  2. - moderator
  3. - unit-tests
  4. - deploy-gce-part1
  5. - deploy-gce-part2
  6. - deploy-gce-special
  7. variables:
  8. FAILFASTCI_NAMESPACE: 'kargo-ci'
  9. # DOCKER_HOST: tcp://localhost:2375
  10. ANSIBLE_FORCE_COLOR: "true"
  11. # asia-east1-a
  12. # asia-northeast1-a
  13. # europe-west1-b
  14. # us-central1-a
  15. # us-east1-b
  16. # us-west1-a
  17. before_script:
  18. - pip install -r tests/requirements.txt
  19. - mkdir -p /.ssh
  20. - cp tests/ansible.cfg .
  21. .job: &job
  22. tags:
  23. - kubernetes
  24. - docker
  25. image: quay.io/ant31/kargo:master
  26. .docker_service: &docker_service
  27. services:
  28. - docker:dind
  29. .create_cluster: &create_cluster
  30. <<: *job
  31. <<: *docker_service
  32. .gce_variables: &gce_variables
  33. GCE_USER: travis
  34. SSH_USER: $GCE_USER
  35. TEST_ID: "$CI_PIPELINE_ID-$CI_BUILD_ID"
  36. CONTAINER_ENGINE: docker
  37. PRIVATE_KEY: $GCE_PRIVATE_KEY
  38. GS_ACCESS_KEY_ID: $GS_KEY
  39. GS_SECRET_ACCESS_KEY: $GS_SECRET
  40. CLOUD_MACHINE_TYPE: "g1-small"
  41. GCE_PREEMPTIBLE: "false"
  42. ANSIBLE_KEEP_REMOTE_FILES: "1"
  43. ANSIBLE_CONFIG: ./tests/ansible.cfg
  44. BOOTSTRAP_OS: none
  45. DOWNLOAD_LOCALHOST: "false"
  46. DOWNLOAD_RUN_ONCE: "false"
  47. IDEMPOT_CHECK: "false"
  48. RESET_CHECK: "false"
  49. UPGRADE_TEST: "false"
  50. KUBEADM_ENABLED: "false"
  51. RESOLVCONF_MODE: docker_dns
  52. LOG_LEVEL: "-vv"
  53. ETCD_DEPLOYMENT: "docker"
  54. KUBELET_DEPLOYMENT: "host"
  55. VAULT_DEPLOYMENT: "docker"
  56. WEAVE_CPU_LIMIT: "100m"
  57. MAGIC: "ci check this"
  58. .gce: &gce
  59. <<: *job
  60. <<: *docker_service
  61. cache:
  62. key: "$CI_BUILD_REF_NAME"
  63. paths:
  64. - downloads/
  65. - $HOME/.cache
  66. before_script:
  67. - docker info
  68. - pip install -r tests/requirements.txt
  69. - mkdir -p /.ssh
  70. - mkdir -p $HOME/.ssh
  71. - echo $PRIVATE_KEY | base64 -d > $HOME/.ssh/id_rsa
  72. - echo $GCE_PEM_FILE | base64 -d > $HOME/.ssh/gce
  73. - echo $GCE_CREDENTIALS > $HOME/.ssh/gce.json
  74. - chmod 400 $HOME/.ssh/id_rsa
  75. - ansible-playbook --version
  76. - export PYPATH=$([ "$BOOTSTRAP_OS" != "coreos" ] && echo /usr/bin/python || echo /opt/bin/python)
  77. script:
  78. - pwd
  79. - ls
  80. - echo ${PWD}
  81. - echo "${STARTUP_SCRIPT}"
  82. - >
  83. ansible-playbook tests/cloud_playbooks/create-gce.yml -i tests/local_inventory/hosts.cfg -c local
  84. ${LOG_LEVEL}
  85. -e cloud_image=${CLOUD_IMAGE}
  86. -e cloud_region=${CLOUD_REGION}
  87. -e gce_credentials_file=${HOME}/.ssh/gce.json
  88. -e gce_project_id=${GCE_PROJECT_ID}
  89. -e gce_service_account_email=${GCE_ACCOUNT}
  90. -e cloud_machine_type=${CLOUD_MACHINE_TYPE}
  91. -e inventory_path=${PWD}/inventory/inventory.ini
  92. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  93. -e mode=${CLUSTER_MODE}
  94. -e test_id=${TEST_ID}
  95. -e preemptible=$GCE_PREEMPTIBLE
  96. -e startup_script="'${STARTUP_SCRIPT}'"
  97. # Check out latest tag if testing upgrade
  98. # Uncomment when gitlab kargo repo has tags
  99. #- test "${UPGRADE_TEST}" != "false" && git fetch --all && git checkout $(git describe --tags $(git rev-list --tags --max-count=1))
  100. - test "${UPGRADE_TEST}" != "false" && git checkout 72ae7638bcc94c66afa8620dfa4ad9a9249327ea
  101. # Create cluster
  102. - >
  103. ansible-playbook -i inventory/inventory.ini -b --become-user=root --private-key=${HOME}/.ssh/id_rsa -u $SSH_USER
  104. ${SSH_ARGS}
  105. ${LOG_LEVEL}
  106. -e ansible_python_interpreter=${PYPATH}
  107. -e ansible_ssh_user=${SSH_USER}
  108. -e bootstrap_os=${BOOTSTRAP_OS}
  109. -e cloud_provider=gce
  110. -e cert_management=${CERT_MGMT:-script}
  111. -e "{deploy_netchecker: true}"
  112. -e "{download_localhost: ${DOWNLOAD_LOCALHOST}}"
  113. -e "{download_run_once: ${DOWNLOAD_RUN_ONCE}}"
  114. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  115. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  116. -e kubedns_min_replicas=1
  117. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  118. -e local_release_dir=${PWD}/downloads
  119. -e resolvconf_mode=${RESOLVCONF_MODE}
  120. -e vault_deployment_type=${VAULT_DEPLOYMENT}
  121. -e weave_cpu_requests=${WEAVE_CPU_LIMIT}
  122. -e weave_cpu_limit=${WEAVE_CPU_LIMIT}
  123. -e "{kubeadm_enabled: ${KUBEADM_ENABLED}}"
  124. --limit "all:!fake_hosts"
  125. cluster.yml
  126. # Repeat deployment if testing upgrade
  127. - >
  128. if [ "${UPGRADE_TEST}" != "false" ]; then
  129. test "${UPGRADE_TEST}" == "basic" && PLAYBOOK="cluster.yml";
  130. test "${UPGRADE_TEST}" == "graceful" && PLAYBOOK="upgrade-cluster.yml";
  131. git checkout "${CI_BUILD_REF}";
  132. ansible-playbook -i inventory/inventory.ini -b --become-user=root --private-key=${HOME}/.ssh/id_rsa -u $SSH_USER
  133. ${SSH_ARGS}
  134. ${LOG_LEVEL}
  135. -e ansible_python_interpreter=${PYPATH}
  136. -e ansible_ssh_user=${SSH_USER}
  137. -e bootstrap_os=${BOOTSTRAP_OS}
  138. -e cloud_provider=gce
  139. -e "{deploy_netchecker: true}"
  140. -e "{download_localhost: ${DOWNLOAD_LOCALHOST}}"
  141. -e "{download_run_once: ${DOWNLOAD_RUN_ONCE}}"
  142. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  143. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  144. -e kubedns_min_replicas=1
  145. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  146. -e local_release_dir=${PWD}/downloads
  147. -e resolvconf_mode=${RESOLVCONF_MODE}
  148. -e vault_deployment_type=${VAULT_DEPLOYMENT}
  149. -e weave_cpu_requests=${WEAVE_CPU_LIMIT}
  150. -e weave_cpu_limit=${WEAVE_CPU_LIMIT}
  151. -e "{kubeadm_enabled: ${KUBEADM_ENABLED}}"
  152. --limit "all:!fake_hosts"
  153. $PLAYBOOK;
  154. fi
  155. # Tests Cases
  156. ## Test Master API
  157. - >
  158. ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH} -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root --limit "all:!fake_hosts" tests/testcases/010_check-apiserver.yml $LOG_LEVEL
  159. -e "{kubeadm_enabled: ${KUBEADM_ENABLED}}"
  160. ## Ping the between 2 pod
  161. - ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH} -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root --limit "all:!fake_hosts" tests/testcases/030_check-network.yml $LOG_LEVEL
  162. ## Advanced DNS checks
  163. - ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH} -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root --limit "all:!fake_hosts" tests/testcases/040_check-network-adv.yml $LOG_LEVEL
  164. ## Idempotency checks 1/5 (repeat deployment)
  165. - >
  166. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  167. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  168. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  169. --private-key=${HOME}/.ssh/id_rsa
  170. -e bootstrap_os=${BOOTSTRAP_OS}
  171. -e cloud_provider=gce
  172. -e ansible_python_interpreter=${PYPATH}
  173. -e "{deploy_netchecker: true}"
  174. -e "{download_localhost: ${DOWNLOAD_LOCALHOST}}"
  175. -e "{download_run_once: ${DOWNLOAD_RUN_ONCE}}"
  176. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  177. -e kubedns_min_replicas=1
  178. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  179. -e local_release_dir=${PWD}/downloads
  180. -e resolvconf_mode=${RESOLVCONF_MODE}
  181. -e vault_deployment_type=${VAULT_DEPLOYMENT}
  182. -e "{kubeadm_enabled: ${KUBEADM_ENABLED}}"
  183. -e weave_cpu_requests=${WEAVE_CPU_LIMIT}
  184. -e weave_cpu_limit=${WEAVE_CPU_LIMIT}
  185. --limit "all:!fake_hosts"
  186. cluster.yml;
  187. fi
  188. ## Idempotency checks 2/5 (Advanced DNS checks)
  189. - >
  190. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  191. ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH}
  192. -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root
  193. --limit "all:!fake_hosts"
  194. tests/testcases/040_check-network-adv.yml $LOG_LEVEL;
  195. fi
  196. ## Idempotency checks 3/5 (reset deployment)
  197. - >
  198. if [ "${IDEMPOT_CHECK}" = "true" -a "${RESET_CHECK}" = "true" ]; then
  199. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  200. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  201. --private-key=${HOME}/.ssh/id_rsa
  202. -e bootstrap_os=${BOOTSTRAP_OS}
  203. -e cloud_provider=gce
  204. -e ansible_python_interpreter=${PYPATH}
  205. -e reset_confirmation=yes
  206. --limit "all:!fake_hosts"
  207. reset.yml;
  208. fi
  209. ## Idempotency checks 4/5 (redeploy after reset)
  210. - >
  211. if [ "${IDEMPOT_CHECK}" = "true" -a "${RESET_CHECK}" = "true" ]; then
  212. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  213. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  214. --private-key=${HOME}/.ssh/id_rsa
  215. -e bootstrap_os=${BOOTSTRAP_OS}
  216. -e cloud_provider=gce
  217. -e ansible_python_interpreter=${PYPATH}
  218. -e "{deploy_netchecker: true}"
  219. -e "{download_localhost: ${DOWNLOAD_LOCALHOST}}"
  220. -e "{download_run_once: ${DOWNLOAD_RUN_ONCE}}"
  221. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  222. -e kubedns_min_replicas=1
  223. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  224. -e local_release_dir=${PWD}/downloads
  225. -e resolvconf_mode=${RESOLVCONF_MODE}
  226. -e vault_deployment_type=${VAULT_DEPLOYMENT}
  227. -e "{kubeadm_enabled: ${KUBEADM_ENABLED}}"
  228. -e weave_cpu_requests=${WEAVE_CPU_LIMIT}
  229. -e weave_cpu_limit=${WEAVE_CPU_LIMIT}
  230. --limit "all:!fake_hosts"
  231. cluster.yml;
  232. fi
  233. ## Idempotency checks 5/5 (Advanced DNS checks)
  234. - >
  235. if [ "${IDEMPOT_CHECK}" = "true" -a "${RESET_CHECK}" = "true" ]; then
  236. ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH}
  237. -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root
  238. --limit "all:!fake_hosts"
  239. tests/testcases/040_check-network-adv.yml $LOG_LEVEL;
  240. fi
  241. after_script:
  242. - >
  243. ansible-playbook -i inventory/inventory.ini tests/cloud_playbooks/delete-gce.yml -c local $LOG_LEVEL
  244. -e mode=${CLUSTER_MODE}
  245. -e test_id=${TEST_ID}
  246. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  247. -e gce_project_id=${GCE_PROJECT_ID}
  248. -e gce_service_account_email=${GCE_ACCOUNT}
  249. -e gce_credentials_file=${HOME}/.ssh/gce.json
  250. -e cloud_image=${CLOUD_IMAGE}
  251. -e inventory_path=${PWD}/inventory/inventory.ini
  252. -e cloud_region=${CLOUD_REGION}
  253. # Test matrix. Leave the comments for markup scripts.
  254. .coreos_calico_aio_variables: &coreos_calico_aio_variables
  255. # stage: deploy-gce-part1
  256. KUBE_NETWORK_PLUGIN: calico
  257. CLOUD_IMAGE: coreos-stable
  258. CLOUD_REGION: us-west1-b
  259. CLOUD_MACHINE_TYPE: "n1-standard-2"
  260. CLUSTER_MODE: aio
  261. BOOTSTRAP_OS: coreos
  262. RESOLVCONF_MODE: host_resolvconf # This is required as long as the CoreOS stable channel uses docker < 1.12
  263. ##User-data to simply turn off coreos upgrades
  264. STARTUP_SCRIPT: 'systemctl disable locksmithd && systemctl stop locksmithd'
  265. .ubuntu_canal_ha_variables: &ubuntu_canal_ha_variables
  266. # stage: deploy-gce-part1
  267. KUBE_NETWORK_PLUGIN: canal
  268. CLOUD_IMAGE: ubuntu-1604-lts
  269. CLOUD_REGION: europe-west1-b
  270. CLUSTER_MODE: ha
  271. UPGRADE_TEST: "graceful"
  272. STARTUP_SCRIPT: ""
  273. .centos_weave_kubeadm_variables: &centos_weave_kubeadm_variables
  274. # stage: deploy-gce-part1
  275. KUBE_NETWORK_PLUGIN: weave
  276. CLOUD_IMAGE: centos-7
  277. CLOUD_MACHINE_TYPE: "n1-standard-1"
  278. CLOUD_REGION: us-central1-b
  279. CLUSTER_MODE: ha
  280. KUBEADM_ENABLED: "true"
  281. UPGRADE_TEST: "graceful"
  282. STARTUP_SCRIPT: ""
  283. .ubuntu_canal_kubeadm_variables: &ubuntu_canal_kubeadm_variables
  284. # stage: deploy-gce-part1
  285. KUBE_NETWORK_PLUGIN: canal
  286. CLOUD_IMAGE: ubuntu-1604-lts
  287. CLOUD_MACHINE_TYPE: "n1-standard-1"
  288. CLOUD_REGION: europe-west1-b
  289. CLUSTER_MODE: ha
  290. KUBEADM_ENABLED: "true"
  291. STARTUP_SCRIPT: ""
  292. .rhel7_weave_variables: &rhel7_weave_variables
  293. # stage: deploy-gce-part1
  294. KUBE_NETWORK_PLUGIN: weave
  295. CLOUD_IMAGE: rhel-7
  296. CLOUD_REGION: europe-west1-b
  297. CLUSTER_MODE: default
  298. STARTUP_SCRIPT: ""
  299. .centos7_flannel_variables: &centos7_flannel_variables
  300. # stage: deploy-gce-part2
  301. KUBE_NETWORK_PLUGIN: flannel
  302. CLOUD_IMAGE: centos-7
  303. CLOUD_REGION: us-west1-a
  304. CLOUD_MACHINE_TYPE: "n1-standard-1"
  305. CLUSTER_MODE: default
  306. STARTUP_SCRIPT: ""
  307. .debian8_calico_variables: &debian8_calico_variables
  308. # stage: deploy-gce-part2
  309. KUBE_NETWORK_PLUGIN: calico
  310. CLOUD_IMAGE: debian-8-kubespray
  311. CLOUD_REGION: us-central1-b
  312. CLUSTER_MODE: default
  313. BOOTSTRAP_OS: debian
  314. STARTUP_SCRIPT: ""
  315. .coreos_canal_variables: &coreos_canal_variables
  316. # stage: deploy-gce-part2
  317. KUBE_NETWORK_PLUGIN: canal
  318. CLOUD_IMAGE: coreos-stable
  319. CLOUD_REGION: us-east1-b
  320. CLUSTER_MODE: default
  321. BOOTSTRAP_OS: coreos
  322. IDEMPOT_CHECK: "true"
  323. RESOLVCONF_MODE: host_resolvconf # This is required as long as the CoreOS stable channel uses docker < 1.12
  324. STARTUP_SCRIPT: 'systemctl disable locksmithd && systemctl stop locksmithd'
  325. .rhel7_canal_sep_variables: &rhel7_canal_sep_variables
  326. # stage: deploy-gce-special
  327. KUBE_NETWORK_PLUGIN: canal
  328. CLOUD_IMAGE: rhel-7
  329. CLOUD_REGION: us-east1-b
  330. CLUSTER_MODE: separate
  331. STARTUP_SCRIPT: ""
  332. .ubuntu_weave_sep_variables: &ubuntu_weave_sep_variables
  333. # stage: deploy-gce-special
  334. KUBE_NETWORK_PLUGIN: weave
  335. CLOUD_IMAGE: ubuntu-1604-lts
  336. CLOUD_REGION: us-central1-b
  337. CLUSTER_MODE: separate
  338. IDEMPOT_CHECK: "false"
  339. STARTUP_SCRIPT: ""
  340. .centos7_calico_ha_variables: &centos7_calico_ha_variables
  341. # stage: deploy-gce-special
  342. KUBE_NETWORK_PLUGIN: calico
  343. DOWNLOAD_LOCALHOST: "true"
  344. DOWNLOAD_RUN_ONCE: "true"
  345. CLOUD_IMAGE: centos-7
  346. CLOUD_REGION: europe-west1-b
  347. CLUSTER_MODE: ha-scale
  348. IDEMPOT_CHECK: "true"
  349. STARTUP_SCRIPT: ""
  350. .coreos_alpha_weave_ha_variables: &coreos_alpha_weave_ha_variables
  351. # stage: deploy-gce-special
  352. KUBE_NETWORK_PLUGIN: weave
  353. CLOUD_IMAGE: coreos-alpha
  354. CLOUD_REGION: us-west1-a
  355. CLUSTER_MODE: ha-scale
  356. BOOTSTRAP_OS: coreos
  357. RESOLVCONF_MODE: host_resolvconf # This is required as long as the CoreOS stable channel uses docker < 1.12
  358. STARTUP_SCRIPT: 'systemctl disable locksmithd && systemctl stop locksmithd'
  359. .ubuntu_rkt_sep_variables: &ubuntu_rkt_sep_variables
  360. # stage: deploy-gce-part1
  361. KUBE_NETWORK_PLUGIN: flannel
  362. CLOUD_IMAGE: ubuntu-1604-lts
  363. CLOUD_REGION: us-central1-b
  364. CLUSTER_MODE: separate
  365. ETCD_DEPLOYMENT: rkt
  366. KUBELET_DEPLOYMENT: rkt
  367. STARTUP_SCRIPT: ""
  368. .ubuntu_vault_sep_variables: &ubuntu_vault_sep_variables
  369. # stage: deploy-gce-part1
  370. CLOUD_MACHINE_TYPE: "n1-standard-1"
  371. KUBE_NETWORK_PLUGIN: canal
  372. CERT_MGMT: vault
  373. CLOUD_IMAGE: ubuntu-1604-lts
  374. CLOUD_REGION: us-central1-b
  375. CLUSTER_MODE: separate
  376. STARTUP_SCRIPT: ""
  377. .ubuntu_flannel_variables: &ubuntu_flannel_variables
  378. # stage: deploy-gce-special
  379. KUBE_NETWORK_PLUGIN: flannel
  380. CLOUD_IMAGE: ubuntu-1604-lts
  381. CLOUD_REGION: europe-west1-b
  382. CLUSTER_MODE: separate
  383. STARTUP_SCRIPT: ""
  384. # Builds for PRs only (premoderated by unit-tests step) and triggers (auto)
  385. coreos-calico-aio:
  386. stage: deploy-gce-part1
  387. <<: *job
  388. <<: *gce
  389. variables:
  390. <<: *gce_variables
  391. <<: *coreos_calico_aio_variables
  392. when: on_success
  393. except: ['triggers']
  394. only: [/^pr-.*$/]
  395. coreos-calico-sep-triggers:
  396. stage: deploy-gce-part1
  397. <<: *job
  398. <<: *gce
  399. variables:
  400. <<: *gce_variables
  401. <<: *coreos_calico_aio_variables
  402. when: on_success
  403. only: ['triggers']
  404. centos7-flannel:
  405. stage: deploy-gce-part2
  406. <<: *job
  407. <<: *gce
  408. variables:
  409. <<: *gce_variables
  410. <<: *centos7_flannel_variables
  411. when: on_success
  412. except: ['triggers']
  413. only: [/^pr-.*$/]
  414. centos7-flannel-triggers:
  415. stage: deploy-gce-part1
  416. <<: *job
  417. <<: *gce
  418. variables:
  419. <<: *gce_variables
  420. <<: *centos7_flannel_variables
  421. when: on_success
  422. only: ['triggers']
  423. ubuntu-weave-sep:
  424. stage: deploy-gce-special
  425. <<: *job
  426. <<: *gce
  427. variables:
  428. <<: *gce_variables
  429. <<: *ubuntu_weave_sep_variables
  430. when: on_success
  431. except: ['triggers']
  432. only: [/^pr-.*$/]
  433. ubuntu-weave-sep-triggers:
  434. stage: deploy-gce-part1
  435. <<: *job
  436. <<: *gce
  437. variables:
  438. <<: *gce_variables
  439. <<: *ubuntu_weave_sep_variables
  440. when: on_success
  441. only: ['triggers']
  442. # More builds for PRs/merges (manual) and triggers (auto)
  443. ubuntu-canal-ha:
  444. stage: deploy-gce-part1
  445. <<: *job
  446. <<: *gce
  447. variables:
  448. <<: *gce_variables
  449. <<: *ubuntu_canal_ha_variables
  450. when: manual
  451. except: ['triggers']
  452. only: ['master', /^pr-.*$/]
  453. ubuntu-canal-ha-triggers:
  454. stage: deploy-gce-part1
  455. <<: *job
  456. <<: *gce
  457. variables:
  458. <<: *gce_variables
  459. <<: *ubuntu_canal_ha_variables
  460. when: on_success
  461. only: ['triggers']
  462. ubuntu-canal-kubeadm:
  463. stage: deploy-gce-part1
  464. <<: *job
  465. <<: *gce
  466. variables:
  467. <<: *gce_variables
  468. <<: *ubuntu_canal_kubeadm_variables
  469. when: manual
  470. except: ['triggers']
  471. only: ['master', /^pr-.*$/]
  472. ubuntu-canal-kubeadm-triggers:
  473. stage: deploy-gce-part1
  474. <<: *job
  475. <<: *gce
  476. variables:
  477. <<: *gce_variables
  478. <<: *ubuntu_canal_kubeadm_variables
  479. when: on_success
  480. only: ['triggers']
  481. centos-weave-kubeadm:
  482. stage: deploy-gce-part1
  483. <<: *job
  484. <<: *gce
  485. variables:
  486. <<: *gce_variables
  487. <<: *centos_weave_kubeadm_variables
  488. when: manual
  489. except: ['triggers']
  490. only: ['master', /^pr-.*$/]
  491. centos-weave-kubeadm-triggers:
  492. stage: deploy-gce-part1
  493. <<: *job
  494. <<: *gce
  495. variables:
  496. <<: *gce_variables
  497. <<: *centos_weave_kubeadm_variables
  498. when: on_success
  499. only: ['triggers']
  500. rhel7-weave:
  501. stage: deploy-gce-part1
  502. <<: *job
  503. <<: *gce
  504. variables:
  505. <<: *gce_variables
  506. <<: *rhel7_weave_variables
  507. when: manual
  508. except: ['triggers']
  509. only: ['master', /^pr-.*$/]
  510. rhel7-weave-triggers:
  511. stage: deploy-gce-part1
  512. <<: *job
  513. <<: *gce
  514. variables:
  515. <<: *gce_variables
  516. <<: *rhel7_weave_variables
  517. when: on_success
  518. only: ['triggers']
  519. debian8-calico-upgrade:
  520. stage: deploy-gce-part2
  521. <<: *job
  522. <<: *gce
  523. variables:
  524. <<: *gce_variables
  525. <<: *debian8_calico_variables
  526. when: manual
  527. except: ['triggers']
  528. only: ['master', /^pr-.*$/]
  529. debian8-calico-triggers:
  530. stage: deploy-gce-part1
  531. <<: *job
  532. <<: *gce
  533. variables:
  534. <<: *gce_variables
  535. <<: *debian8_calico_variables
  536. when: on_success
  537. only: ['triggers']
  538. coreos-canal:
  539. stage: deploy-gce-part2
  540. <<: *job
  541. <<: *gce
  542. variables:
  543. <<: *gce_variables
  544. <<: *coreos_canal_variables
  545. when: manual
  546. except: ['triggers']
  547. only: ['master', /^pr-.*$/]
  548. coreos-canal-triggers:
  549. stage: deploy-gce-part1
  550. <<: *job
  551. <<: *gce
  552. variables:
  553. <<: *gce_variables
  554. <<: *coreos_canal_variables
  555. when: on_success
  556. only: ['triggers']
  557. rhel7-canal-sep:
  558. stage: deploy-gce-special
  559. <<: *job
  560. <<: *gce
  561. variables:
  562. <<: *gce_variables
  563. <<: *rhel7_canal_sep_variables
  564. when: manual
  565. except: ['triggers']
  566. only: ['master', /^pr-.*$/,]
  567. rhel7-canal-sep-triggers:
  568. stage: deploy-gce-part1
  569. <<: *job
  570. <<: *gce
  571. variables:
  572. <<: *gce_variables
  573. <<: *rhel7_canal_sep_variables
  574. when: on_success
  575. only: ['triggers']
  576. centos7-calico-ha:
  577. stage: deploy-gce-special
  578. <<: *job
  579. <<: *gce
  580. variables:
  581. <<: *gce_variables
  582. <<: *centos7_calico_ha_variables
  583. when: manual
  584. except: ['triggers']
  585. only: ['master', /^pr-.*$/]
  586. centos7-calico-ha-triggers:
  587. stage: deploy-gce-part1
  588. <<: *job
  589. <<: *gce
  590. variables:
  591. <<: *gce_variables
  592. <<: *centos7_calico_ha_variables
  593. when: on_success
  594. only: ['triggers']
  595. # no triggers yet https://github.com/kubernetes-incubator/kargo/issues/613
  596. coreos-alpha-weave-ha:
  597. stage: deploy-gce-special
  598. <<: *job
  599. <<: *gce
  600. variables:
  601. <<: *gce_variables
  602. <<: *coreos_alpha_weave_ha_variables
  603. when: manual
  604. except: ['triggers']
  605. only: ['master', /^pr-.*$/]
  606. ubuntu-rkt-sep:
  607. stage: deploy-gce-part1
  608. <<: *job
  609. <<: *gce
  610. variables:
  611. <<: *gce_variables
  612. <<: *ubuntu_rkt_sep_variables
  613. when: manual
  614. except: ['triggers']
  615. only: ['master', /^pr-.*$/]
  616. ubuntu-vault-sep:
  617. stage: deploy-gce-part1
  618. <<: *job
  619. <<: *gce
  620. variables:
  621. <<: *gce_variables
  622. <<: *ubuntu_vault_sep_variables
  623. when: manual
  624. except: ['triggers']
  625. only: ['master', /^pr-.*$/]
  626. ubuntu-flannel-sep:
  627. stage: deploy-gce-special
  628. <<: *job
  629. <<: *gce
  630. variables:
  631. <<: *gce_variables
  632. <<: *ubuntu_flannel_variables
  633. when: manual
  634. except: ['triggers']
  635. only: ['master', /^pr-.*$/]
  636. # Premoderated with manual actions
  637. ci-authorized:
  638. <<: *job
  639. stage: moderator
  640. before_script:
  641. - apt-get -y install jq
  642. script:
  643. - /bin/sh scripts/premoderator.sh
  644. except: ['triggers', 'master']
  645. syntax-check:
  646. <<: *job
  647. stage: unit-tests
  648. script:
  649. - ansible-playbook -i inventory/local-tests.cfg -u root -e ansible_ssh_user=root -b --become-user=root cluster.yml -vvv --syntax-check
  650. - ansible-playbook -i inventory/local-tests.cfg -u root -e ansible_ssh_user=root -b --become-user=root upgrade-cluster.yml -vvv --syntax-check
  651. - ansible-playbook -i inventory/local-tests.cfg -u root -e ansible_ssh_user=root -b --become-user=root reset.yml -vvv --syntax-check
  652. - ansible-playbook -i inventory/local-tests.cfg -u root -e ansible_ssh_user=root -b --become-user=root extra_playbooks/upgrade-only-k8s.yml -vvv --syntax-check
  653. except: ['triggers', 'master']
  654. yamllint:
  655. <<: *job
  656. stage: unit-tests
  657. script:
  658. - yamllint roles
  659. except: ['triggers', 'master']
  660. tox-inventory-builder:
  661. stage: unit-tests
  662. <<: *job
  663. script:
  664. - pip install tox
  665. - cd contrib/inventory_builder && tox
  666. when: manual
  667. except: ['triggers', 'master']