Merge pull request #6253 from AlanCoding/smart_error

Fix server error creating smart inventories

Reviewed-by: https://github.com/apps/softwarefactory-project-zuul
This commit is contained in:
softwarefactory-project-zuul[bot]
2020-03-11 13:08:00 +00:00
committed by GitHub
2 changed files with 61 additions and 1 deletions

View File

@@ -1600,7 +1600,7 @@ class InventorySerializer(BaseSerializerWithVariables):
}) })
SmartFilter().query_from_string(host_filter) SmartFilter().query_from_string(host_filter)
except RuntimeError as e: except RuntimeError as e:
raise models.base.ValidationError(e) raise models.base.ValidationError(str(e))
return host_filter return host_filter
def validate(self, attrs): def validate(self, attrs):

View File

@@ -0,0 +1,60 @@
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type
import pytest
from awx.main.models import Inventory
@pytest.mark.django_db
def test_inventory_create(run_module, admin_user, organization):
result = run_module('tower_inventory', {
'name': 'foo-inventory',
'organization': organization.name,
'variables': {'foo': 'bar', 'another-foo': {'barz': 'bar2'}},
'state': 'present'
}, admin_user)
inv = Inventory.objects.get(name='foo-inventory')
assert inv.variables == '{"foo": "bar", "another-foo": {"barz": "bar2"}}'
result.pop('module_args', None)
result.pop('invocation', None)
assert result == {
"name": "foo-inventory",
"id": inv.id,
"changed": True
}
assert inv.organization_id == organization.id
@pytest.mark.django_db
def test_invalid_smart_inventory_create(run_module, admin_user, organization):
result = run_module('tower_inventory', {
'name': 'foo-inventory',
'organization': organization.name,
'kind': 'smart',
'host_filter': 'ansible',
'state': 'present'
}, admin_user)
assert result.get('failed', False), result
assert 'Invalid query ansible' in result['msg']
@pytest.mark.django_db
def test_valid_smart_inventory_create(run_module, admin_user, organization):
result = run_module('tower_inventory', {
'name': 'foo-inventory',
'organization': organization.name,
'kind': 'smart',
'host_filter': 'name=my_host',
'state': 'present'
}, admin_user)
assert not result.get('failed', False), result
inv = Inventory.objects.get(name='foo-inventory')
assert inv.host_filter == 'name=my_host'
assert inv.kind == 'smart'
assert inv.organization_id == organization.id