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.

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