1 - name: Configure Drain
2 when: syslog_server is defined or clever_syslog_server is defined
3 command: "{{ ansible_env.HOME }}/{{ clever_user_path }}/clever-set-drain.sh"
5 chdir: "{{ clever_app_root }}"
7 SYSLOG_UDP_SERVER: "{{ clever_syslog_server | default(syslog_server) }}"
8 CONFIGURATION_FILE: "{{ clever_login_file }}"
10 - name: Configure Domain
11 when: domain is defined or clever_domain is defined
12 command: "{{ ansible_env.HOME }}/{{ clever_user_path }}/clever-set-domain.sh"
14 chdir: "{{ clever_app_root }}"
16 DOMAIN: "{{ clever_domain | default(domain) }}"
17 CONFIGURATION_FILE: "{{ clever_login_file }}"
19 - name: Push Environment
20 shell: "clever env import < {{ clever_app_confdir }}/env"
22 chdir: "{{ clever_app_root }}"
24 CONFIGURATION_FILE: "{{ clever_login_file }}"
27 #TODO: Improve ssh-key validation
28 - name: Accept Clever-Cloud servers
29 shell: "ssh-keyscan -H push-par-clevercloud-customers.services.clever-cloud.com >> ~/.ssh/known_hosts"
33 - name: Deploy to Clever-Cloud
34 command: "git push --force git+ssh://git@push-par-clevercloud-customers.services.clever-cloud.com/{{ clever_app }}.git HEAD:refs/heads/master"
36 chdir: "{{ clever_app_root }}"
37 register: clever_deploy
42 ##################################################################
43 # Re-deploy only if its the first clever deploy for that project #
44 ##################################################################
46 - name: First time push to Clever-Cloud needs a full git clone
47 command: "git fetch --unshallow"
49 chdir: "{{ clever_app_root }}"
51 - clever_deploy is failed
52 - clever_deploy.stderr is defined
53 - clever_deploy.stderr is search("Failed to read git object")
57 - name: Deploy to Clever-Cloud
58 command: "git push --force git+ssh://git@push-par-clevercloud-customers.services.clever-cloud.com/{{ clever_app }}.git HEAD:refs/heads/master"
60 chdir: "{{ clever_app_root }}"
62 - clever_deploy is failed
63 - clever_deploy.stderr is defined
64 - clever_deploy.stderr is search("Failed to read git object")
65 register: clever_deploy
69 ##############################################################################
70 # Poll deployment status from 'clever activity' command. #
71 # 'clever deploy' command is not yet 100% reliable to get a blocking command #
72 # until the deployment is over. Hence the need for a custom waiting script. #
73 ##############################################################################
75 - name: Watch deployment status
76 command: "{{ ansible_env.HOME }}/{{ clever_user_path }}/clever-wait-deploy.sh"
78 chdir: "{{ clever_app_root }}"
80 CONFIGURATION_FILE: "{{ clever_login_file }}"
81 async: 2400 # 40 minutes
83 register: long_command
86 - name: Wait 40 minutes for deployment completion
88 jid: "{{ long_command.ansible_job_id }}"
90 until: job_result.finished
93 retries: 80 # 40 minutes (80 * 30 secs delay)
95 - name: Waiting script logs (stdout)
97 var: job_result.stdout_lines
98 when: job_result.stdout_lines is defined
100 - name: Waiting script logs (stderr)
102 var: job_result.stderr_lines
103 when: job_result.stderr_lines is defined
105 - name: Fail in case of timeout or failure
107 msg: "Deployment failed. Please check logs above."
108 when: not job_result.finished or not job_result.rc == 0