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.

522 lines
14 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
  1. stages:
  2. - unit-tests
  3. - deploy-gce-part1
  4. - deploy-gce-part2
  5. - deploy-gce-special
  6. variables:
  7. FAILFASTCI_NAMESPACE: 'kargo-ci'
  8. # DOCKER_HOST: tcp://localhost:2375
  9. ANSIBLE_FORCE_COLOR: "true"
  10. # asia-east1-a
  11. # asia-northeast1-a
  12. # europe-west1-b
  13. # us-central1-a
  14. # us-east1-b
  15. # us-west1-a
  16. before_script:
  17. - pip install ansible
  18. - pip install netaddr
  19. - pip install apache-libcloud==0.20.1
  20. - pip install boto==2.9.0
  21. - mkdir -p /.ssh
  22. - cp tests/ansible.cfg .
  23. .job: &job
  24. tags:
  25. - kubernetes
  26. - docker
  27. image: quay.io/ant31/kargo:master
  28. .docker_service: &docker_service
  29. services:
  30. - docker:dind
  31. .create_cluster: &create_cluster
  32. <<: *job
  33. <<: *docker_service
  34. .gce_variables: &gce_variables
  35. GCE_USER: travis
  36. SSH_USER: $GCE_USER
  37. TEST_ID: "$CI_PIPELINE_ID-$CI_BUILD_ID"
  38. CONTAINER_ENGINE: docker
  39. PRIVATE_KEY: $GCE_PRIVATE_KEY
  40. GS_ACCESS_KEY_ID: $GS_KEY
  41. GS_SECRET_ACCESS_KEY: $GS_SECRET
  42. ANSIBLE_KEEP_REMOTE_FILES: "1"
  43. BOOTSTRAP_OS: none
  44. IDEMPOT_CHECK: "false"
  45. RESOLVCONF_MODE: docker_dns
  46. LOG_LEVEL: "-vv"
  47. ETCD_DEPLOYMENT: "docker"
  48. KUBELET_DEPLOYMENT: "docker"
  49. MAGIC: "ci check this"
  50. .gce: &gce
  51. <<: *job
  52. <<: *docker_service
  53. cache:
  54. key: "$CI_BUILD_REF_NAME"
  55. paths:
  56. - downloads/
  57. - $HOME/.cache
  58. stage: deploy-gce
  59. before_script:
  60. - docker info
  61. - pip install ansible==2.1.3.0
  62. - pip install netaddr
  63. - pip install apache-libcloud==0.20.1
  64. - pip install boto==2.9.0
  65. - mkdir -p /.ssh
  66. - cp tests/ansible.cfg .
  67. - mkdir -p $HOME/.ssh
  68. - echo $PRIVATE_KEY | base64 -d > $HOME/.ssh/id_rsa
  69. - echo $GCE_PEM_FILE | base64 -d > $HOME/.ssh/gce
  70. - echo $GCE_CREDENTIALS > $HOME/.ssh/gce.json
  71. - chmod 400 $HOME/.ssh/id_rsa
  72. - ansible-playbook --version
  73. - cp tests/ansible.cfg .
  74. - export PYPATH=$([ $BOOTSTRAP_OS = none ] && echo /usr/bin/python || echo /opt/bin/python)
  75. script:
  76. - pwd
  77. - ls
  78. - echo ${PWD}
  79. - >
  80. ansible-playbook tests/cloud_playbooks/create-gce.yml -i tests/local_inventory/hosts.cfg -c local $LOG_LEVEL
  81. -e mode=${CLUSTER_MODE}
  82. -e test_id=${TEST_ID}
  83. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  84. -e gce_project_id=${GCE_PROJECT_ID}
  85. -e gce_service_account_email=${GCE_ACCOUNT}
  86. -e gce_credentials_file=${HOME}/.ssh/gce.json
  87. -e cloud_image=${CLOUD_IMAGE}
  88. -e inventory_path=${PWD}/inventory/inventory.ini
  89. -e cloud_region=${CLOUD_REGION}
  90. # Create cluster
  91. - >
  92. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  93. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  94. --private-key=${HOME}/.ssh/id_rsa
  95. -e bootstrap_os=${BOOTSTRAP_OS}
  96. -e ansible_python_interpreter=${PYPATH}
  97. -e download_run_once=true
  98. -e download_localhost=true
  99. -e deploy_netchecker=true
  100. -e resolvconf_mode=${RESOLVCONF_MODE}
  101. -e local_release_dir=${PWD}/downloads
  102. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  103. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  104. cluster.yml
  105. # Tests Cases
  106. ## Test Master API
  107. - 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 tests/testcases/010_check-apiserver.yml $LOG_LEVEL
  108. ## Ping the between 2 pod
  109. - 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 tests/testcases/030_check-network.yml $LOG_LEVEL
  110. ## Advanced DNS checks
  111. - 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 tests/testcases/040_check-network-adv.yml $LOG_LEVEL
  112. ## Idempotency checks 1/5 (repeat deployment)
  113. - >
  114. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  115. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  116. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  117. --private-key=${HOME}/.ssh/id_rsa
  118. -e bootstrap_os=${BOOTSTRAP_OS}
  119. -e ansible_python_interpreter=${PYPATH}
  120. -e download_run_once=true
  121. -e download_localhost=true
  122. -e deploy_netchecker=true
  123. -e resolvconf_mode=${RESOLVCONF_MODE}
  124. -e local_release_dir=${PWD}/downloads
  125. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  126. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  127. cluster.yml;
  128. fi
  129. ## Idempotency checks 2/5 (Advanced DNS checks)
  130. - >
  131. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  132. ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH}
  133. -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root
  134. tests/testcases/040_check-network-adv.yml $LOG_LEVEL;
  135. fi
  136. ## Idempotency checks 3/5 (reset deployment)
  137. - >
  138. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  139. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  140. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  141. --private-key=${HOME}/.ssh/id_rsa
  142. -e bootstrap_os=${BOOTSTRAP_OS}
  143. -e ansible_python_interpreter=${PYPATH}
  144. reset.yml;
  145. fi
  146. ## Idempotency checks 4/5 (redeploy after reset)
  147. - >
  148. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  149. ansible-playbook -i inventory/inventory.ini -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS
  150. -b --become-user=root -e cloud_provider=gce $LOG_LEVEL -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  151. --private-key=${HOME}/.ssh/id_rsa
  152. -e bootstrap_os=${BOOTSTRAP_OS}
  153. -e ansible_python_interpreter=${PYPATH}
  154. -e download_run_once=true
  155. -e download_localhost=true
  156. -e deploy_netchecker=true
  157. -e resolvconf_mode=${RESOLVCONF_MODE}
  158. -e local_release_dir=${PWD}/downloads
  159. -e etcd_deployment_type=${ETCD_DEPLOYMENT}
  160. -e kubelet_deployment_type=${KUBELET_DEPLOYMENT}
  161. cluster.yml;
  162. fi
  163. ## Idempotency checks 5/5 (Advanced DNS checks)
  164. - >
  165. if [ "${IDEMPOT_CHECK}" = "true" ]; then
  166. ansible-playbook -i inventory/inventory.ini -e ansible_python_interpreter=${PYPATH}
  167. -u $SSH_USER -e ansible_ssh_user=$SSH_USER $SSH_ARGS -b --become-user=root
  168. tests/testcases/040_check-network-adv.yml $LOG_LEVEL;
  169. fi
  170. after_script:
  171. - >
  172. ansible-playbook -i inventory/inventory.ini tests/cloud_playbooks/delete-gce.yml -c local $LOG_LEVEL
  173. -e mode=${CLUSTER_MODE}
  174. -e test_id=${TEST_ID}
  175. -e kube_network_plugin=${KUBE_NETWORK_PLUGIN}
  176. -e gce_project_id=${GCE_PROJECT_ID}
  177. -e gce_service_account_email=${GCE_ACCOUNT}
  178. -e gce_credentials_file=${HOME}/.ssh/gce.json
  179. -e cloud_image=${CLOUD_IMAGE}
  180. -e inventory_path=${PWD}/inventory/inventory.ini
  181. -e cloud_region=${CLOUD_REGION}
  182. # Test matrix. Leave the comments for markup scripts.
  183. .coreos_calico_sep_variables: &coreos_calico_sep_variables
  184. # stage: deploy-gce-part1
  185. KUBE_NETWORK_PLUGIN: calico
  186. CLOUD_IMAGE: coreos-stable
  187. CLOUD_REGION: us-west1-b
  188. CLUSTER_MODE: separated
  189. BOOTSTRAP_OS: coreos
  190. RESOLVCONF_MODE: host_resolvconf # This is required as long as the CoreOS stable channel uses docker < 1.12
  191. .debian8_canal_ha_variables: &debian8_canal_ha_variables
  192. # stage: deploy-gce-part1
  193. KUBE_NETWORK_PLUGIN: canal
  194. CLOUD_IMAGE: debian-8-kubespray
  195. CLOUD_REGION: us-east1-b
  196. CLUSTER_MODE: ha
  197. .rhel7_weave_variables: &rhel7_weave_variables
  198. # stage: deploy-gce-part1
  199. KUBE_NETWORK_PLUGIN: weave
  200. CLOUD_IMAGE: rhel-7
  201. CLOUD_REGION: europe-west1-b
  202. CLUSTER_MODE: default
  203. .centos7_flannel_variables: &centos7_flannel_variables
  204. # stage: deploy-gce-part2
  205. KUBE_NETWORK_PLUGIN: flannel
  206. CLOUD_IMAGE: centos-7
  207. CLOUD_REGION: us-west1-a
  208. CLUSTER_MODE: default
  209. .debian8_calico_variables: &debian8_calico_variables
  210. # stage: deploy-gce-part2
  211. KUBE_NETWORK_PLUGIN: calico
  212. CLOUD_IMAGE: debian-8-kubespray
  213. CLOUD_REGION: us-central1-b
  214. CLUSTER_MODE: default
  215. .coreos_canal_variables: &coreos_canal_variables
  216. # stage: deploy-gce-part2
  217. KUBE_NETWORK_PLUGIN: canal
  218. CLOUD_IMAGE: coreos-stable
  219. CLOUD_REGION: us-east1-b
  220. CLUSTER_MODE: default
  221. BOOTSTRAP_OS: coreos
  222. RESOLVCONF_MODE: host_resolvconf # This is required as long as the CoreOS stable channel uses docker < 1.12
  223. IDEMPOT_CHECK: "true"
  224. .rhel7_canal_sep_variables: &rhel7_canal_sep_variables
  225. # stage: deploy-gce-special
  226. KUBE_NETWORK_PLUGIN: canal
  227. CLOUD_IMAGE: rhel-7
  228. CLOUD_REGION: us-east1-b
  229. CLUSTER_MODE: separated
  230. .ubuntu_weave_sep_variables: &ubuntu_weave_sep_variables
  231. # stage: deploy-gce-special
  232. KUBE_NETWORK_PLUGIN: weave
  233. CLOUD_IMAGE: ubuntu-1604-xenial
  234. CLOUD_REGION: us-central1-b
  235. CLUSTER_MODE: separated
  236. IDEMPOT_CHECK: "true"
  237. .centos7_calico_ha_variables: &centos7_calico_ha_variables
  238. # stage: deploy-gce-special
  239. KUBE_NETWORK_PLUGIN: calico
  240. CLOUD_IMAGE: centos-7
  241. CLOUD_REGION: europe-west1-b
  242. CLUSTER_MODE: ha
  243. IDEMPOT_CHECK: "true"
  244. .coreos_alpha_weave_ha_variables: &coreos_alpha_weave_ha_variables
  245. # stage: deploy-gce-special
  246. KUBE_NETWORK_PLUGIN: weave
  247. CLOUD_IMAGE: coreos-alpha
  248. CLOUD_REGION: us-west1-a
  249. CLUSTER_MODE: ha
  250. BOOTSTRAP_OS: coreos
  251. .ubuntu_rkt_sep_variables: &ubuntu_rkt_sep_variables
  252. # stage: deploy-gce-part1
  253. KUBE_NETWORK_PLUGIN: flannel
  254. CLOUD_IMAGE: ubuntu-1604-xenial
  255. CLOUD_REGION: us-central1-b
  256. CLUSTER_MODE: separated
  257. ETCD_DEPLOYMENT: rkt
  258. KUBELET_DEPLOYMENT: rkt
  259. # Builds for PRs only (premoderated by unit-tests step) and triggers (auto)
  260. coreos-calico-sep:
  261. stage: deploy-gce-part1
  262. <<: *job
  263. <<: *gce
  264. variables:
  265. <<: *gce_variables
  266. <<: *coreos_calico_sep_variables
  267. when: on_success
  268. except: ['triggers']
  269. only: [/^pr-.*$/]
  270. coreos-calico-sep-triggers:
  271. stage: deploy-gce-part1
  272. <<: *job
  273. <<: *gce
  274. variables:
  275. <<: *gce_variables
  276. <<: *coreos_calico_sep_variables
  277. when: on_success
  278. only: ['triggers']
  279. centos7-flannel:
  280. stage: deploy-gce-part2
  281. <<: *job
  282. <<: *gce
  283. variables:
  284. <<: *gce_variables
  285. <<: *centos7_flannel_variables
  286. when: on_success
  287. except: ['triggers']
  288. only: [/^pr-.*$/]
  289. centos7-flannel-triggers:
  290. stage: deploy-gce-part1
  291. <<: *job
  292. <<: *gce
  293. variables:
  294. <<: *gce_variables
  295. <<: *centos7_flannel_variables
  296. when: on_success
  297. only: ['triggers']
  298. ubuntu-weave-sep:
  299. stage: deploy-gce-special
  300. <<: *job
  301. <<: *gce
  302. variables:
  303. <<: *gce_variables
  304. <<: *ubuntu_weave_sep_variables
  305. when: on_success
  306. except: ['triggers']
  307. only: [/^pr-.*$/]
  308. ubuntu-weave-sep-triggers:
  309. stage: deploy-gce-part1
  310. <<: *job
  311. <<: *gce
  312. variables:
  313. <<: *gce_variables
  314. <<: *ubuntu_weave_sep_variables
  315. when: on_success
  316. only: ['triggers']
  317. # More builds for PRs/merges (manual) and triggers (auto)
  318. debian8-canal-ha:
  319. stage: deploy-gce-part1
  320. <<: *job
  321. <<: *gce
  322. variables:
  323. <<: *gce_variables
  324. <<: *debian8_canal_ha_variables
  325. when: manual
  326. except: ['triggers']
  327. only: ['master', /^pr-.*$/]
  328. debian8-canal-ha-triggers:
  329. stage: deploy-gce-part1
  330. <<: *job
  331. <<: *gce
  332. variables:
  333. <<: *gce_variables
  334. <<: *debian8_canal_ha_variables
  335. when: on_success
  336. only: ['triggers']
  337. rhel7-weave:
  338. stage: deploy-gce-part1
  339. <<: *job
  340. <<: *gce
  341. variables:
  342. <<: *gce_variables
  343. <<: *rhel7_weave_variables
  344. when: manual
  345. except: ['triggers']
  346. only: ['master', /^pr-.*$/]
  347. rhel7-weave-triggers:
  348. stage: deploy-gce-part1
  349. <<: *job
  350. <<: *gce
  351. variables:
  352. <<: *gce_variables
  353. <<: *rhel7_weave_variables
  354. when: on_success
  355. only: ['triggers']
  356. debian8-calico:
  357. stage: deploy-gce-part2
  358. <<: *job
  359. <<: *gce
  360. variables:
  361. <<: *gce_variables
  362. <<: *debian8_calico_variables
  363. when: manual
  364. except: ['triggers']
  365. only: ['master', /^pr-.*$/]
  366. debian8-calico-triggers:
  367. stage: deploy-gce-part1
  368. <<: *job
  369. <<: *gce
  370. variables:
  371. <<: *gce_variables
  372. <<: *debian8_calico_variables
  373. when: on_success
  374. only: ['triggers']
  375. coreos-canal:
  376. stage: deploy-gce-part2
  377. <<: *job
  378. <<: *gce
  379. variables:
  380. <<: *gce_variables
  381. <<: *coreos_canal_variables
  382. when: manual
  383. except: ['triggers']
  384. only: ['master', /^pr-.*$/]
  385. coreos-canal-triggers:
  386. stage: deploy-gce-part1
  387. <<: *job
  388. <<: *gce
  389. variables:
  390. <<: *gce_variables
  391. <<: *coreos_canal_variables
  392. when: on_success
  393. only: ['triggers']
  394. rhel7-canal-sep:
  395. stage: deploy-gce-special
  396. <<: *job
  397. <<: *gce
  398. variables:
  399. <<: *gce_variables
  400. <<: *rhel7_canal_sep_variables
  401. when: manual
  402. except: ['triggers']
  403. only: ['master', /^pr-.*$/,]
  404. rhel7-canal-sep-triggers:
  405. stage: deploy-gce-part1
  406. <<: *job
  407. <<: *gce
  408. variables:
  409. <<: *gce_variables
  410. <<: *rhel7_canal_sep_variables
  411. when: on_success
  412. only: ['triggers']
  413. centos7-calico-ha:
  414. stage: deploy-gce-special
  415. <<: *job
  416. <<: *gce
  417. variables:
  418. <<: *gce_variables
  419. <<: *centos7_calico_ha_variables
  420. when: manual
  421. except: ['triggers']
  422. only: ['master', /^pr-.*$/]
  423. centos7-calico-ha-triggers:
  424. stage: deploy-gce-part1
  425. <<: *job
  426. <<: *gce
  427. variables:
  428. <<: *gce_variables
  429. <<: *centos7_calico_ha_variables
  430. when: on_success
  431. only: ['triggers']
  432. # no triggers yet https://github.com/kubernetes-incubator/kargo/issues/613
  433. coreos-alpha-weave-ha:
  434. stage: deploy-gce-special
  435. <<: *job
  436. <<: *gce
  437. variables:
  438. <<: *gce_variables
  439. <<: *coreos_alpha_weave_ha_variables
  440. when: manual
  441. except: ['triggers']
  442. only: ['master', /^pr-.*$/]
  443. ubuntu-rkt-sep:
  444. stage: deploy-gce-part1
  445. <<: *job
  446. <<: *gce
  447. variables:
  448. <<: *gce_variables
  449. <<: *ubuntu_rkt_sep_variables
  450. when: manual
  451. except: ['triggers']
  452. only: ['master', /^pr-.*$/]
  453. # Premoderated with manual actions
  454. syntax-check:
  455. <<: *job
  456. stage: unit-tests
  457. before_script:
  458. - apt-get -y install jq
  459. script:
  460. - ansible-playbook -i inventory/local-tests.cfg -u root -e ansible_ssh_user=root -b --become-user=root cluster.yml -vvv --syntax-check
  461. - /bin/sh scripts/premoderator.sh
  462. except: ['triggers', 'master']
  463. tox-inventory-builder:
  464. stage: unit-tests
  465. <<: *job
  466. script:
  467. - pip install tox
  468. - cd contrib/inventory_builder && tox
  469. when: manual
  470. except: ['triggers', 'master']