Skip to content

Commit

Permalink
Improve handling of invalid workdir creation
Browse files Browse the repository at this point in the history
  • Loading branch information
LegenJCdary committed Mar 31, 2022
1 parent 2c436f9 commit 353f89e
Show file tree
Hide file tree
Showing 6 changed files with 89 additions and 20 deletions.
28 changes: 27 additions & 1 deletion .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ jobs:
- run:
command: dnf install -y epel-release
- run:
command: dnf install -y ansible python3 python3-pip
command: dnf install -y ansible python3 python3-pip e2fsprogs
- checkout
- run:
name: "Install ansible-deployer"
Expand All @@ -30,12 +30,35 @@ jobs:
gpasswd -a root test_group
groups
/bin/bash -lc 'groups'
run_tests:
docker:
- image: almalinux
user: nobody
resource_class: small
steps:
- checkout
- run:
name: "Run shell script for argument parsing"
command: |
./tests/01-test_argument_parsing.sh
./tests/02-checkrun.sh
./tests/05-permission_checks.sh
- run:
name: "Create invalid workdir"
command: |
cp ./tests/files/etc/ansible-deploy_workdir.yaml /etc/ansible-deploy/ansible-deploy.yaml
mkdir /tmp/workdir
chmod 0400 /tmp/workdir
- run:
name: "Workdir not writable tests"
user: nobody
command: |
chmod 0400 /tmp/workdir
./tests/06-error_create_workdir.sh
- run:
name: "Reset global configuration"
command: cp ./etc/ansible-deploy.yaml /etc/ansible-deploy/
- run:
name: "Copy failing hooks"
command: cp ./tests/files/etc/hooks/* /etc/ansible-deploy/hooks
Expand Down Expand Up @@ -87,6 +110,9 @@ workflows:
tests-without-ansible-playbook:
jobs:
- prepare_env
- run_tests
requires:
- prepare_env
# - install_and_exec:
# requires:
# - prepare_env
Expand Down
43 changes: 24 additions & 19 deletions ansible_deployer/command_line.py
Original file line number Diff line number Diff line change
Expand Up @@ -112,29 +112,34 @@ def create_workdir(timestamp: str):
#
#TODO: Add locking of the directory

if short_ts not in os.listdir(conf["global_paths"]["work_dir"]):
seq_path = os.path.join(date_dir, f"{conf['file_naming']['sequence_prefix']}0000")
try:
os.mkdir(date_dir)
os.chmod(date_dir, int(conf["permissions"]["parent_workdir"].split("o")[1], 8))
logger.debug("Successfully created parent work dir: %s", seq_path)
except Exception as e:
logger.critical("Failed to create parent work dir: %s error was: %s", seq_path, e,
file=sys.stderr)
sys.exit(90)
else:
sequence_list = os.listdir(date_dir)
sequence_list.sort()
new_sequence = int(sequence_list[-1].split(conf['file_naming']['sequence_prefix'])[1]) + 1
seq_path = os.path.join(date_dir, f"{conf['file_naming']['sequence_prefix']}"
f"{new_sequence:04d}")
try:
if short_ts not in os.listdir(conf["global_paths"]["work_dir"]):
seq_path = os.path.join(date_dir, f"{conf['file_naming']['sequence_prefix']}0000")
try:
os.mkdir(date_dir)
os.chmod(date_dir, int(conf["permissions"]["parent_workdir"].split("o")[1], 8))
logger.debug("Successfully created parent work dir: %s", date_dir)
except Exception as e:
logger.critical("Failed to create parent work dir: %s error was: %s", date_dir, e)
sys.exit(90)
else:
sequence_list = os.listdir(date_dir)
sequence_list.sort()
new_sequence = int(sequence_list[-1].split(conf['file_naming']['sequence_prefix'])[1])\
+ 1
seq_path = os.path.join(date_dir, f"{conf['file_naming']['sequence_prefix']}"
f"{new_sequence:04d}")

except Exception as exc:
logger.critical("Failed to list work dir due to: %s", exc)
sys.exit(91)

try:
os.mkdir(seq_path)
os.chdir(seq_path)
except Exception as e:
logger.critical("Failed to create work dir: %s error was: %s", seq_path, e, file=sys.stderr)
sys.exit(91)
except Exception as exc:
logger.critical("Failed to create work dir: %s due to: %s", seq_path, exc)
sys.exit(92)
logger.debug("Successfully created workdir: %s", seq_path)
return seq_path

Expand Down
9 changes: 9 additions & 0 deletions tests/06-error_create_parent_workdir.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash -l


source ./tests/testing_lib.sh

ls -ld /tmp/workdir
ansible-deployer run -t task_exec_bin_true -s prod -i testInfra -d

check_message_in_output 'ansible-deployer run -t task_exec_bin_true -s prod -i testInfra' '\[CRITICAL\]: Failed to create parent work dir'
10 changes: 10 additions & 0 deletions tests/06-error_create_workdir.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/bin/bash -l


source ./tests/testing_lib.sh

ls -ld /tmp/workdir
whoami
ansible-deployer run -t task_exec_bin_true -s prod -i testInfra -d

check_message_in_output 'ansible-deployer run -t task_exec_bin_true -s prod -i testInfra' '\[CRITICAL\]: Failed to create work dir'
9 changes: 9 additions & 0 deletions tests/06-error_list_workdir.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash -l


source ./tests/testing_lib.sh

ls -ld /tmp/workdir
ansible-deployer run -t task_exec_bin_true -s prod -i testInfra -d

check_message_in_output 'ansible-deployer run -t task_exec_bin_true -s prod -i testInfra' '\[CRITICAL\]: Failed to list work dir due to'
10 changes: 10 additions & 0 deletions tests/files/etc/ansible-deploy_workdir.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
global_paths:
work_dir: "/tmp/workdir"
config_dir: "/etc/ansible-deploy"

file_naming:
log_file_name_frmt: "ansible-deploy_execution_{}.log"
sequence_prefix: "SEQ"

permissions:
parent_workdir: "0o1750"

0 comments on commit 353f89e

Please sign in to comment.