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.

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