]> git.immae.eu Git - github/fretlink/ansible-clever.git/blobdiff - tasks/deploy.yml
Merge pull request #37 from gaetanfl/fix_path
[github/fretlink/ansible-clever.git] / tasks / deploy.yml
index 09cf10ea8dbb6098ef1b9df2b4886832f363c4f9..81e2bb7eafc9db95efd510b5504ece6a9fdb21bd 100644 (file)
@@ -1,6 +1,6 @@
 - name: Configure Drain
   when: syslog_server is defined or clever_syslog_server is defined
-  command: clever-set-drain.sh
+  command: "{{ ansible_env.HOME }}/{{ clever_user_path }}/clever-set-drain.sh"
   args:
     chdir: "{{ clever_app_root }}"
   environment:
@@ -9,7 +9,7 @@
 
 - name: Configure Domain
   when: domain is defined or clever_domain is defined
-  command: clever-set-domain.sh
+  command: "{{ ansible_env.HOME }}/{{ clever_user_path }}/clever-set-domain.sh"
   args:
     chdir: "{{ clever_app_root }}"
   environment:
     - clever_deploy is failed
     - clever_deploy.stderr is defined
 
+- name: Retrieve clever activity
+  command: clever activity
+  args:
+    chdir: "{{ clever_app_root }}"
+  environment:
+    CONFIGURATION_FILE: "{{ clever_login_file }}"
+  changed_when: false
+  register: clever_activity_result
+
+- name: Display clever activity
+  debug:
+    var: clever_activity_result.stdout_lines
+
+- name: Get current commit sha
+  command: git show -q --format=format:%H HEAD
+  args:
+    chdir: "{{ clever_app_root }}"
+    warn: False
+  changed_when: false
+  register: current_commit_sha
+
+# ####
+# Expects all configuration to be located in the project's repository.
+# Making a git commit bound to the same *configuration* and *executable* version.
+# ##
+- name: Fail if current commit is not the last deployed one
+  fail:
+    msg: "The clever deployment failed! Please check latest deploy activity logs above."
+  when:
+    - clever_deploy is failed
+    - clever_deploy.stderr is defined
+    - clever_deploy.stderr is search("application is up-to-date")
+    - clever_activity_valid_deploy_keyword in clever_activity_result.stdout_lines[-1]
+    - current_commit_sha.stdout_lines[-1] in clever_activity_result.stdout_lines[-1]
+
 - name: Fail on deployment errors
-  fail: "The clever deployment failed! Please check logs above."
-  when: clever_deploy is failed
+  fail:
+    msg: "The clever deployment failed! Please check logs above."
+  when:
+    - clever_deploy is failed
+    - clever_deploy.stderr is defined
+    - clever_deploy.stderr is not search("application is up-to-date")