mirror of https://github.com/ansible/ansible.git
[unarchive] work on older RHEL with group: <gid> (#72098)
Change: - No longer fail due to old Fedora/RHEL and our failure to try to cast gids to integers before trying to pass them to getgrgid() before trying to use them. - Add tests for user/mode for various unarchive formats. Test Plan: - New integration tests, ran against centos6 container Tickets: - Fixes #71903pull/72138/head
parent
a90e37d017
commit
ebc91a9b93
@ -0,0 +1,2 @@
|
||||
bugfixes:
|
||||
- unarchive - ``zip`` unarchive no longer errors on RHEL/CentOS 6 and old Fedora when attempting to use a numeric gid (https://github.com/ansible/ansible/issues/71903).
|
@ -0,0 +1,162 @@
|
||||
- block:
|
||||
- name: Create a group to chown to
|
||||
group:
|
||||
name: testgroup
|
||||
register: testgroup
|
||||
|
||||
- name: Create a user to chown to
|
||||
user:
|
||||
name: testuser
|
||||
groups:
|
||||
- testgroup
|
||||
register: testuser
|
||||
|
||||
- set_fact:
|
||||
outdir: '{{remote_tmp_dir}}/test-unarchive-{{ ext | replace(".", "_") }}'
|
||||
|
||||
- debug:
|
||||
msg: Username test
|
||||
|
||||
# username
|
||||
- name: create our unarchive destinations
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: directory
|
||||
|
||||
- name: unarchive a file
|
||||
unarchive:
|
||||
src: '{{remote_tmp_dir}}/{{archive}}'
|
||||
dest: '{{outdir}}'
|
||||
list_files: True
|
||||
remote_src: yes
|
||||
owner: testuser
|
||||
|
||||
- name: stat an output file
|
||||
stat:
|
||||
path: '{{outdir}}/{{testfile}}'
|
||||
register: stat
|
||||
|
||||
- name: verify that the file has the right owner
|
||||
assert:
|
||||
that:
|
||||
- stat.stat.exists
|
||||
- stat.stat.pw_name == testuser.name
|
||||
- stat.stat.uid == testuser.uid
|
||||
|
||||
- name: nuke destination
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: absent
|
||||
|
||||
- debug:
|
||||
msg: uid test
|
||||
|
||||
# uid
|
||||
- name: create our unarchive destinations
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: directory
|
||||
|
||||
- name: unarchive a file
|
||||
unarchive:
|
||||
src: '{{remote_tmp_dir}}/{{archive}}'
|
||||
dest: '{{outdir}}'
|
||||
list_files: True
|
||||
remote_src: yes
|
||||
owner: '{{ testuser.uid }}'
|
||||
|
||||
- name: stat an output file
|
||||
stat:
|
||||
path: '{{outdir}}/{{testfile}}'
|
||||
register: stat
|
||||
|
||||
- name: verify that the file has the right owner
|
||||
assert:
|
||||
that:
|
||||
- stat.stat.exists
|
||||
- stat.stat.pw_name == testuser.name
|
||||
- stat.stat.uid == testuser.uid
|
||||
|
||||
- name: nuke destination
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: absent
|
||||
|
||||
- debug:
|
||||
msg: groupname test
|
||||
|
||||
# groupname
|
||||
- name: create our unarchive destinations
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: directory
|
||||
|
||||
- name: unarchive a file
|
||||
unarchive:
|
||||
src: '{{remote_tmp_dir}}/{{archive}}'
|
||||
dest: '{{outdir}}'
|
||||
list_files: True
|
||||
remote_src: yes
|
||||
group: testgroup
|
||||
|
||||
- name: stat an output file
|
||||
stat:
|
||||
path: '{{outdir}}/{{testfile}}'
|
||||
register: stat
|
||||
|
||||
- name: verify that the file has the right owner
|
||||
assert:
|
||||
that:
|
||||
- stat.stat.exists
|
||||
- stat.stat.gr_name == testgroup.name
|
||||
- stat.stat.gid == testgroup.gid
|
||||
|
||||
- name: nuke destination
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: absent
|
||||
|
||||
- debug:
|
||||
msg: gid test
|
||||
|
||||
# gid
|
||||
- name: create our unarchive destinations
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: directory
|
||||
|
||||
- name: unarchive a file
|
||||
unarchive:
|
||||
src: '{{remote_tmp_dir}}/{{archive}}'
|
||||
dest: '{{outdir}}'
|
||||
list_files: True
|
||||
remote_src: yes
|
||||
group: '{{ testgroup.gid }}'
|
||||
|
||||
- name: stat an output file
|
||||
stat:
|
||||
path: '{{outdir}}/{{testfile}}'
|
||||
register: stat
|
||||
|
||||
- name: verify that the file has the right owner
|
||||
assert:
|
||||
that:
|
||||
- stat.stat.exists
|
||||
- stat.stat.gr_name == testgroup.name
|
||||
- stat.stat.gid == testgroup.gid
|
||||
|
||||
- name: nuke destination
|
||||
file:
|
||||
path: '{{outdir}}'
|
||||
state: absent
|
||||
|
||||
always:
|
||||
- name: Remove testuser
|
||||
user:
|
||||
name: testuser
|
||||
state: absent
|
||||
|
||||
- name: Remove testgroup
|
||||
group:
|
||||
name: testgroup
|
||||
state: absent
|
Loading…
Reference in New Issue