mirror of
https://github.com/ansible/awx.git
synced 2026-02-17 19:20:05 -03:30
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:
@@ -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):
|
||||||
|
|||||||
60
awx_collection/test/awx/test_inventory.py
Normal file
60
awx_collection/test/awx/test_inventory.py
Normal 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
|
||||||
Reference in New Issue
Block a user