mirror of
https://github.com/ansible/awx.git
synced 2026-03-06 19:21:06 -03:30
cleanup of Job Template tests and fixtures
This commit is contained in:
@@ -4,6 +4,7 @@ import mock
|
|||||||
# AWX
|
# AWX
|
||||||
from awx.api.serializers import JobTemplateSerializer
|
from awx.api.serializers import JobTemplateSerializer
|
||||||
from awx.main.models.jobs import JobTemplate
|
from awx.main.models.jobs import JobTemplate
|
||||||
|
from awx.main.models.projects import ProjectOptions
|
||||||
|
|
||||||
# Django
|
# Django
|
||||||
from django.test.client import RequestFactory
|
from django.test.client import RequestFactory
|
||||||
@@ -11,16 +12,15 @@ from django.core.urlresolvers import reverse
|
|||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def jt_copy_edit(project):
|
def jt_copy_edit(job_template_factory, project):
|
||||||
return JobTemplate.objects.create(
|
objects = job_template_factory(
|
||||||
job_type='run',
|
'copy-edit-job-template',
|
||||||
project=project,
|
project=project)
|
||||||
playbook='hello_world.yml',
|
return objects.job_template
|
||||||
ask_inventory_on_launch=True,
|
|
||||||
ask_credential_on_launch=True,
|
|
||||||
name='copy-edit-job-template'
|
|
||||||
)
|
|
||||||
|
|
||||||
|
@property
|
||||||
|
def project_playbooks(self):
|
||||||
|
return ['mocked', 'mocked.yml', 'alt-mocked.yml']
|
||||||
|
|
||||||
@pytest.mark.django_db
|
@pytest.mark.django_db
|
||||||
def test_job_template_role_user(post, organization_factory, job_template_factory):
|
def test_job_template_role_user(post, organization_factory, job_template_factory):
|
||||||
@@ -149,25 +149,20 @@ def test_proj_jt_admin_copy_edit(jt_copy_edit, rando):
|
|||||||
# Functional tests - create new JT with all returned fields, as the UI does
|
# Functional tests - create new JT with all returned fields, as the UI does
|
||||||
|
|
||||||
@pytest.mark.django_db
|
@pytest.mark.django_db
|
||||||
|
@mock.patch.object(ProjectOptions, "playbooks", project_playbooks)
|
||||||
def test_org_admin_copy_edit_functional(jt_copy_edit, org_admin, get, post):
|
def test_org_admin_copy_edit_functional(jt_copy_edit, org_admin, get, post):
|
||||||
get_response = get(reverse('api:job_template_detail', args=[jt_copy_edit.pk]), user=org_admin)
|
get_response = get(reverse('api:job_template_detail', args=[jt_copy_edit.pk]), user=org_admin)
|
||||||
|
|
||||||
post_data = get_response.data
|
|
||||||
post_data['name'] = '%s @ 12:19:47 pm' % post_data['name']
|
|
||||||
|
|
||||||
assert get_response.status_code == 200
|
assert get_response.status_code == 200
|
||||||
assert get_response.data['summary_fields']['can_copy']
|
assert get_response.data['summary_fields']['can_copy']
|
||||||
|
|
||||||
with mock.patch(
|
post_data = get_response.data
|
||||||
'awx.main.models.projects.ProjectOptions.playbooks',
|
post_data['name'] = '%s @ 12:19:47 pm' % post_data['name']
|
||||||
new_callable=mock.PropertyMock(return_value=['hello_world.yml'])):
|
post_response = post(reverse('api:job_template_list', args=[]), user=org_admin, data=post_data)
|
||||||
post_response = post(reverse('api:job_template_list', args=[]), user=org_admin, data=post_data)
|
|
||||||
|
|
||||||
print '\n post_response: ' + str(post_response.data)
|
|
||||||
assert post_response.status_code == 201
|
assert post_response.status_code == 201
|
||||||
assert post_response.data['name'] == 'copy-edit-job-template @ 12:19:47 pm'
|
assert post_response.data['name'] == 'copy-edit-job-template @ 12:19:47 pm'
|
||||||
|
|
||||||
@pytest.mark.django_db
|
@pytest.mark.django_db
|
||||||
|
@mock.patch.object(ProjectOptions, "playbooks", project_playbooks)
|
||||||
def test_jt_admin_copy_edit_functional(jt_copy_edit, rando, get, post):
|
def test_jt_admin_copy_edit_functional(jt_copy_edit, rando, get, post):
|
||||||
|
|
||||||
# Grant random user JT admin access only
|
# Grant random user JT admin access only
|
||||||
@@ -175,17 +170,10 @@ def test_jt_admin_copy_edit_functional(jt_copy_edit, rando, get, post):
|
|||||||
jt_copy_edit.save()
|
jt_copy_edit.save()
|
||||||
|
|
||||||
get_response = get(reverse('api:job_template_detail', args=[jt_copy_edit.pk]), user=rando)
|
get_response = get(reverse('api:job_template_detail', args=[jt_copy_edit.pk]), user=rando)
|
||||||
|
|
||||||
assert get_response.status_code == 200
|
assert get_response.status_code == 200
|
||||||
assert not get_response.data['summary_fields']['can_copy']
|
assert not get_response.data['summary_fields']['can_copy']
|
||||||
|
|
||||||
post_data = get_response.data
|
post_data = get_response.data
|
||||||
post_data['name'] = '%s @ 12:19:47 pm' % post_data['name']
|
post_data['name'] = '%s @ 12:19:47 pm' % post_data['name']
|
||||||
|
post_response = post(reverse('api:job_template_list', args=[]), user=rando, data=post_data)
|
||||||
with mock.patch(
|
|
||||||
'awx.main.models.projects.ProjectOptions.playbooks',
|
|
||||||
new_callable=mock.PropertyMock(return_value=['hello_world.yml'])):
|
|
||||||
post_response = post(reverse('api:job_template_list', args=[]), user=rando, data=post_data)
|
|
||||||
|
|
||||||
print '\n post_response: ' + str(post_response.data)
|
|
||||||
assert post_response.status_code == 403
|
assert post_response.status_code == 403
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ from django.core.urlresolvers import reverse
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def project_playbooks(self):
|
def project_playbooks(self):
|
||||||
return ['mocked.yml', 'alt-mocked.yml']
|
return ['mocked', 'mocked.yml', 'alt-mocked.yml']
|
||||||
|
|
||||||
@pytest.mark.django_db
|
@pytest.mark.django_db
|
||||||
@mock.patch.object(ProjectOptions, "playbooks", project_playbooks)
|
@mock.patch.object(ProjectOptions, "playbooks", project_playbooks)
|
||||||
@@ -87,8 +87,6 @@ def test_edit_playbook(patch, job_template_factory, alice):
|
|||||||
def test_edit_nonsenstive(patch, job_template_factory, alice):
|
def test_edit_nonsenstive(patch, job_template_factory, alice):
|
||||||
objs = job_template_factory('jt', organization='org1', project='prj', inventory='inv', credential='cred')
|
objs = job_template_factory('jt', organization='org1', project='prj', inventory='inv', credential='cred')
|
||||||
jt = objs.job_template
|
jt = objs.job_template
|
||||||
jt.playbook = 'mocked.yml'
|
|
||||||
jt.save()
|
|
||||||
jt.admin_role.members.add(alice)
|
jt.admin_role.members.add(alice)
|
||||||
|
|
||||||
res = patch(reverse('api:job_template_detail', args=(jt.id,)), {
|
res = patch(reverse('api:job_template_detail', args=(jt.id,)), {
|
||||||
|
|||||||
@@ -1,9 +1,6 @@
|
|||||||
import pytest
|
|
||||||
|
|
||||||
from awx.main.tests.factories import create_job_template
|
from awx.main.tests.factories import create_job_template
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.django_db
|
|
||||||
def test_missing_project_error():
|
def test_missing_project_error():
|
||||||
objects = create_job_template(
|
objects = create_job_template(
|
||||||
'missing-project-jt',
|
'missing-project-jt',
|
||||||
@@ -16,7 +13,6 @@ def test_missing_project_error():
|
|||||||
validation_errors, resources_needed_to_start = obj.resource_validation_data()
|
validation_errors, resources_needed_to_start = obj.resource_validation_data()
|
||||||
assert 'project' in validation_errors
|
assert 'project' in validation_errors
|
||||||
|
|
||||||
@pytest.mark.django_db
|
|
||||||
def test_inventory_credential_need_to_start():
|
def test_inventory_credential_need_to_start():
|
||||||
objects = create_job_template(
|
objects = create_job_template(
|
||||||
'job-template-few-resources',
|
'job-template-few-resources',
|
||||||
@@ -26,7 +22,6 @@ def test_inventory_credential_need_to_start():
|
|||||||
assert 'inventory' in obj.resources_needed_to_start
|
assert 'inventory' in obj.resources_needed_to_start
|
||||||
assert 'credential' in obj.resources_needed_to_start
|
assert 'credential' in obj.resources_needed_to_start
|
||||||
|
|
||||||
@pytest.mark.django_db
|
|
||||||
def test_inventory_credential_contradictions():
|
def test_inventory_credential_contradictions():
|
||||||
objects = create_job_template(
|
objects = create_job_template(
|
||||||
'job-template-paradox',
|
'job-template-paradox',
|
||||||
@@ -38,4 +33,3 @@ def test_inventory_credential_contradictions():
|
|||||||
validation_errors, resources_needed_to_start = obj.resource_validation_data()
|
validation_errors, resources_needed_to_start = obj.resource_validation_data()
|
||||||
assert 'inventory' in validation_errors
|
assert 'inventory' in validation_errors
|
||||||
assert 'credential' in validation_errors
|
assert 'credential' in validation_errors
|
||||||
|
|
||||||
Reference in New Issue
Block a user