diff --git a/contrib/terraform/openstack/.gitignore b/contrib/terraform/openstack/.gitignore
index 55d775bf01675e10a5774e89f9668ff8debeebda..7e4921aa2c5e5ad96c4288c8e4cf64163ef44ee9 100644
--- a/contrib/terraform/openstack/.gitignore
+++ b/contrib/terraform/openstack/.gitignore
@@ -1,5 +1,5 @@
 .terraform
 *.tfvars
-!sample-inventory\/cluster.tfvars
+!sample-inventory/cluster.tfvars
 *.tfstate
 *.tfstate.backup
diff --git a/docs/ansible.md b/docs/ansible.md
index 9a3110b3a3f371279b1a6f115425905bb7733908..63cc1d768c4922869536e8c4f87879869f6ad3de 100644
--- a/docs/ansible.md
+++ b/docs/ansible.md
@@ -32,7 +32,7 @@ Based on the table below and the available python version for your ansible host
 
 | Ansible Version | Python Version |
 |-----------------|----------------|
-| 2.14            | 3.9-3.11       |
+| >= 2.15.5       | 3.9-3.11       |
 
 ## Inventory
 
diff --git a/meta/runtime.yml b/meta/runtime.yml
index be99ccf4b82d08b9df3385e8c6e753d1193211c7..0b870b6984a9f798ac432693d866595eadd8b4db 100644
--- a/meta/runtime.yml
+++ b/meta/runtime.yml
@@ -1,2 +1,2 @@
 ---
-requires_ansible: '>=2.14.0'
+requires_ansible: '>=2.15.5'
diff --git a/playbooks/ansible_version.yml b/playbooks/ansible_version.yml
index 840749af5e28d0fd061c6b5ea0e222c994a88645..f6cebdff73d3c9616cde0424a371cb18ddf4c6b1 100644
--- a/playbooks/ansible_version.yml
+++ b/playbooks/ansible_version.yml
@@ -4,8 +4,8 @@
   gather_facts: false
   become: no
   vars:
-    minimal_ansible_version: 2.14.0
-    maximal_ansible_version: 2.15.0
+    minimal_ansible_version: 2.15.5  # 2.15 versions before 2.15.5 are known to be buggy for kubespray
+    maximal_ansible_version: 2.17.0
     ansible_connection: local
   tags: always
   tasks:
diff --git a/requirements.txt b/requirements.txt
index 2420014f8d3b8e64174b47a7f205b9801a50a280..47a76fcfe8d314418e4c372f2979ca8a5e65f5af 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -1,9 +1,9 @@
-ansible==7.6.0
-cryptography==41.0.1
+ansible==8.5.0
+cryptography==41.0.4
 jinja2==3.1.2
 jmespath==1.0.1
 MarkupSafe==2.1.3
-netaddr==0.8.0
+netaddr==0.9.0
 pbr==5.11.1
-ruamel.yaml==0.17.31
-ruamel.yaml.clib==0.2.7
+ruamel.yaml==0.17.35
+ruamel.yaml.clib==0.2.8
diff --git a/roles/adduser/molecule/default/tests/test_default.py b/roles/adduser/molecule/default/tests/test_default.py
deleted file mode 100644
index 7e8649d141d554ec51d4882b0c6138e3993005d8..0000000000000000000000000000000000000000
--- a/roles/adduser/molecule/default/tests/test_default.py
+++ /dev/null
@@ -1,43 +0,0 @@
-import os
-from pathlib import Path
-
-import testinfra.utils.ansible_runner
-import yaml
-from ansible.cli.playbook import PlaybookCLI
-from ansible.playbook import Playbook
-
-testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
-    os.environ["MOLECULE_INVENTORY_FILE"]
-).get_hosts("all")
-
-
-def read_playbook(playbook):
-    cli_args = [os.path.realpath(playbook), testinfra_hosts]
-    cli = PlaybookCLI(cli_args)
-    cli.parse()
-    loader, inventory, variable_manager = cli._play_prereqs()
-
-    pb = Playbook.load(cli.args[0], variable_manager, loader)
-
-    for play in pb.get_plays():
-        yield variable_manager.get_vars(play)
-
-
-def get_playbook():
-    playbooks_path = Path(__file__).parent.parent
-    with open(os.path.join(playbooks_path, "molecule.yml"), "r") as yamlfile:
-        data = yaml.load(yamlfile, Loader=yaml.FullLoader)
-        if "playbooks" in data["provisioner"].keys():
-            if "converge" in data["provisioner"]["playbooks"].keys():
-                return data["provisioner"]["playbooks"]["converge"]
-        else:
-            return os.path.join(playbooks_path, "converge.yml")
-
-
-def test_user(host):
-    for vars in read_playbook(get_playbook()):
-        assert host.user(vars["user"]["name"]).exists
-        if "group" in vars["user"].keys():
-            assert host.group(vars["user"]["group"]).exists
-        else:
-            assert host.group(vars["user"]["name"]).exists
diff --git a/roles/bastion-ssh-config/molecule/default/tests/test_default.py b/roles/bastion-ssh-config/molecule/default/tests/test_default.py
deleted file mode 100644
index cce719de192b757c9727fc3865858de3fb711113..0000000000000000000000000000000000000000
--- a/roles/bastion-ssh-config/molecule/default/tests/test_default.py
+++ /dev/null
@@ -1,40 +0,0 @@
-import os
-from pathlib import Path
-
-import testinfra.utils.ansible_runner
-import yaml
-from ansible.cli.playbook import PlaybookCLI
-from ansible.playbook import Playbook
-
-testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
-    os.environ["MOLECULE_INVENTORY_FILE"]
-).get_hosts("all")
-
-
-def read_playbook(playbook):
-    cli_args = [os.path.realpath(playbook), testinfra_hosts]
-    cli = PlaybookCLI(cli_args)
-    cli.parse()
-    loader, inventory, variable_manager = cli._play_prereqs()
-
-    pb = Playbook.load(cli.args[0], variable_manager, loader)
-
-    for play in pb.get_plays():
-        yield variable_manager.get_vars(play)
-
-
-def get_playbook():
-    playbooks_path = Path(__file__).parent.parent
-    with open(os.path.join(playbooks_path, "molecule.yml"), "r") as yamlfile:
-        data = yaml.load(yamlfile, Loader=yaml.FullLoader)
-        if "playbooks" in data["provisioner"].keys():
-            if "converge" in data["provisioner"]["playbooks"].keys():
-                return data["provisioner"]["playbooks"]["converge"]
-        else:
-            return os.path.join(playbooks_path, "converge.yml")
-
-
-def test_ssh_config(host):
-    for vars in read_playbook(get_playbook()):
-        assert host.file(vars["ssh_bastion_confing__name"]).exists
-        assert host.file(vars["ssh_bastion_confing__name"]).is_file
diff --git a/tests/requirements.txt b/tests/requirements.txt
index 19474ab0945b65fa03fbd365618ddf80454b5743..51bc76efbf607ae16043269a66bc0cf33aefa152 100644
--- a/tests/requirements.txt
+++ b/tests/requirements.txt
@@ -1,11 +1,12 @@
 -r ../requirements.txt
-ansible-lint==6.16.2
-apache-libcloud==3.7.0
-ara[server]==1.6.1
+ansible-lint==6.20.3
+apache-libcloud==3.8.0
+ara[server]==1.7.0
 dopy==0.3.7
-molecule==5.0.1
-molecule-plugins[vagrant]==23.4.1
+molecule==6.0.2
+molecule-plugins[vagrant]==23.5.0
 python-vagrant==1.0.0
-pytest-testinfra==8.1.0
-tox==4.5.2
+pytest-testinfra==9.0.0
+tox==4.11.3
 yamllint==1.32.0
+tzdata==2023.3