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.

742 lines
21 KiB

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