1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2026-03-22 05:09:12 +00:00

test(python_runner): add integration tests

This commit is contained in:
Alexei Znamensky 2026-03-22 15:47:10 +13:00
parent b4336659f6
commit aa3ce19135
4 changed files with 113 additions and 0 deletions

View file

@ -0,0 +1,25 @@
# Copyright (c) 2026, Ansible Project
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
# SPDX-License-Identifier: GPL-3.0-or-later
azp/posix/2
skip/freebsd
skip/macos
skip/osx
skip/rhel8.2
skip/rhel8.3
skip/rhel8.4
skip/rhel8.5
skip/rhel8.6
skip/rhel8.7
skip/rhel8.8
skip/rhel9.0
skip/rhel9.1
skip/rhel9.2
skip/rhel9.3
skip/rhel9.4
skip/rhel9.5
skip/rhel9.6
skip/rhel9.7
skip/rhel10.0
skip/rhel10.1

View file

@ -0,0 +1,9 @@
# Copyright (c) 2026, Alexei Znamensky <russoz@gmail.com>
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
# SPDX-License-Identifier: GPL-3.0-or-later
SECRET_KEY = "test-secret-key-for-python-runner-integration-test-do-not-use-in-production"
INSTALLED_APPS = []
DATABASES = {}

View file

@ -0,0 +1,6 @@
---
# Copyright (c) 2026, Ansible Project
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
# SPDX-License-Identifier: GPL-3.0-or-later
dependencies: []

View file

@ -0,0 +1,73 @@
# Copyright (c) 2026, Alexei Znamensky <russoz@gmail.com>
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
# SPDX-License-Identifier: GPL-3.0-or-later
- name: Create temporary directory
ansible.builtin.tempfile:
state: directory
suffix: .python_runner
register: tmp_python_runner
- name: Create virtualenv
ansible.builtin.command:
cmd: "python3 -m venv {{ tmp_python_runner.path }}/venv"
- name: Update pip in virtualenv
ansible.builtin.pip:
name: pip
state: latest
virtualenv: "{{ tmp_python_runner.path }}/venv"
- name: Install django in virtualenv
ansible.builtin.pip:
name: django
state: present
virtualenv: "{{ tmp_python_runner.path }}/venv"
- name: Copy settings file to temporary directory
ansible.builtin.copy:
src: settings.py
dest: "{{ tmp_python_runner.path }}/settings.py"
mode: "0644"
# Regression test for https://github.com/ansible-collections/community.general/issues/8884
# Bug: PythonRunner was setting path_prefix to a string instead of a list, corrupting PATH
# when venv was specified, so the venv's python could not be found.
- name: Run django_command check using virtualenv (regression test for issue 8884)
community.general.django_command:
command: check
settings: settings
pythonpath: "{{ tmp_python_runner.path }}"
venv: "{{ tmp_python_runner.path }}/venv"
register: result_check
- name: Assert django_command succeeded and returned a version
ansible.builtin.assert:
that:
- result_check is success
- result_check.version is defined
- result_check.version != ""
# Second test: mirrors the scenario from issue 8884 — a real Django project created
# with django-admin startproject, then checked via django_command with a venv.
# The original reporter was running `migrate`; we use `check` to avoid needing a database.
- name: Create Django project using venv django-admin
ansible.builtin.command:
cmd: >-
{{ tmp_python_runner.path }}/venv/bin/django-admin startproject
testproject {{ tmp_python_runner.path }}/testproject
- name: Run django_command check on the created project (issue 8884 scenario)
community.general.django_command:
command: check
settings: testproject.settings
pythonpath: "{{ tmp_python_runner.path }}/testproject"
venv: "{{ tmp_python_runner.path }}/venv"
register: result_project_check
- name: Assert project check succeeded and returned a version
ansible.builtin.assert:
that:
- result_project_check is success
- result_project_check.version is defined
- result_project_check.version != ""