File: zuul_post_with_postgresql.yaml

package info (click to toggle)
python-ara 1.5.8-1.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 10,460 kB
  • sloc: python: 6,493; sh: 215; makefile: 15; javascript: 2
file content (54 lines) | stat: -rw-r--r-- 1,996 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
---
#  Copyright (c) 2020 Red Hat, Inc.
#
#  This file is part of ARA Records Ansible.
#
#  ARA Records Ansible is free software: you can redistribute it and/or modify
#  it under the terms of the GNU General Public License as published by
#  the Free Software Foundation, either version 3 of the License, or
#  (at your option) any later version.
#
#  ARA Records Ansible is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
#
#  You should have received a copy of the GNU General Public License
#  along with ARA Records Ansible. If not, see <http://www.gnu.org/licenses/>.

- name: Recover postgresql server data
  hosts: ara-database-server
  gather_facts: yes
  vars_files:
    - vars/postgresql_tests.yaml
  tasks:
    - name: Ensure pg_dump is installed
      become: yes
      package:
        name: postgresql
        state: present

    # The zuul-output directory is retrieved by the fetch-output role
    # https://opendev.org/zuul/zuul-jobs/src/branch/master/roles/fetch-output
    - name: Create log directory
      file:
        path: "{{ ansible_user_dir }}/zuul-output/logs"
        state: directory
        recurse: yes

    - name: Set up postgre password file for passwordless commands
      lineinfile:
        path: "{{ ansible_user_dir }}/.pgpass"
        create: yes
        line: "127.0.0.1:{{ ara_api_database_port }}:{{ ara_api_database_name }}:{{ ara_api_database_user }}:{{ ara_api_database_password }}"
        mode: 0600

    # Dump is suffixed by .txt so we don't need magic mimetypes when
    # viewing on the web.
    - name: Dump database file
      command: |
        pg_dump -w \
          --host=127.0.0.1 \
          --username={{ ara_api_database_user }} \
          --dbname={{ ara_api_database_name }} \
          --file={{ ansible_user_dir }}/zuul-output/logs/pg_dump.sql.txt