blob: 52dd7f186dfb294cf5950e54b2cee3841355d0c2 [file] [log] [blame]
Fatih Degirmenciccc68892019-02-27 09:16:45 +00001---
2# ============LICENSE_START=======================================================
3# Copyright (C) 2019 The Nordix Foundation. All rights reserved.
4# ================================================================================
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16#
17# SPDX-License-Identifier: Apache-2.0
18# ============LICENSE_END=========================================================
19
20- name: Remove existing files and directories
21 file:
22 path: "{{ engine_cache }}/repos/kubespray"
23 state: absent
24
25- name: Clone kubespray repository and checkout '{{ kubespray_version }}'
26 git:
27 repo: "{{ kubespray_git_url }}"
28 dest: "{{ engine_cache }}/repos/kubespray"
29 version: "{{ kubespray_version }}"
30 force: yes
31 environment:
32 http_proxy: "{{ lookup('env','http_proxy') }}"
33 https_proxy: "{{ lookup('env','https_proxy') }}"
34 no_proxy: "{{ lookup('env','no_proxy') }}"
35
36# TODO: some stuff below could and perhaps should be pushed into the scenario
37# it is put here to make basic installation work without complexities
38- name: Put initial structure in place
39 synchronize:
40 src: "{{ engine_cache }}/repos/kubespray/inventory/sample/"
41 dest: "{{ engine_cache }}/repos/kubespray/inventory/engine"
42 recursive: yes
43 delete: yes
44
Wenqing Gu3d802212019-04-18 08:28:24 +020045# update ControlPersist to 60m to inline with max time
46- name: Update ControlPersist in ansible config
47 lineinfile:
48 path: "{{ engine_cache }}/repos/kubespray/ansible.cfg"
49 regexp: "^ssh_args.*"
50 line: "ssh_args = -o ControlMaster=auto -o ControlPersist=60m -o ConnectionAttempts=100 -o UserKnownHostsFile=/dev/null"
51
Fatih Degirmenci51a4f882019-03-19 17:35:15 +000052# enable helm for all the scenarios using kubespray
53- name: Enable helm
54 lineinfile:
55 path: "{{ engine_cache }}/repos/kubespray/inventory/engine/group_vars/k8s-cluster/addons.yml"
56 regexp: "^helm_enabled:.*"
57 line: "helm_enabled: true"
58
Fatih Degirmenci41873702019-04-08 22:24:18 +000059# enable creation of kubeconfig on localhost for all the scenarios using kubespray
60- name: Enable creation of kubeconfig on localhost
61 lineinfile:
62 path: "{{ engine_cache }}/repos/kubespray/inventory/engine/group_vars/k8s-cluster/k8s-cluster.yml"
63 regexp: "^# kubeconfig_localhost:.*"
64 line: "kubeconfig_localhost: true"
65
Fatih Degirmenciccc68892019-02-27 09:16:45 +000066# TODO: reuse of bifrost dynamic inventory is only valid for the cases that use
67# bifrost for provisioning so this needs fixing and we could perhaps switch to
68# our own inventory, dynamic or static.
69- name: Place bifrost_inventory.py in Kubespray inventory
70 file:
71 src: "{{ engine_cache }}/repos/bifrost/playbooks/inventory/bifrost_inventory.py"
72 dest: "{{ engine_cache }}/repos/kubespray/inventory/engine/bifrost_inventory.py"
73 state: link
74
Fatih Degirmencif2b36ac2019-04-01 23:28:50 +000075# configure docker with iptables
76- name: Ensure docker daemon iptables option is set to true
77 lineinfile:
78 path: "{{ engine_cache }}/repos/kubespray/inventory/engine/group_vars/all/docker.yml"
79 regexp: "^docker_iptables_enabled:.*"
80 line: "docker_iptables_enabled: true"
81
Fatih Degirmenciccc68892019-02-27 09:16:45 +000082# vim: set ts=2 sw=2 expandtab: