|
|
|
|
@ -21,8 +21,10 @@ __metaclass__ = type
|
|
|
|
|
|
|
|
|
|
import fnmatch
|
|
|
|
|
import os
|
|
|
|
|
import sys
|
|
|
|
|
import re
|
|
|
|
|
import itertools
|
|
|
|
|
import traceback
|
|
|
|
|
|
|
|
|
|
from operator import attrgetter
|
|
|
|
|
from random import shuffle
|
|
|
|
|
@ -276,10 +278,12 @@ class InventoryManager(object):
|
|
|
|
|
break
|
|
|
|
|
except AnsibleParserError as e:
|
|
|
|
|
display.debug('%s was not parsable by %s' % (source, plugin_name))
|
|
|
|
|
failures.append({'src': source, 'plugin': plugin_name, 'exc': e})
|
|
|
|
|
tb = ''.join(traceback.format_tb(sys.exc_info()[2]))
|
|
|
|
|
failures.append({'src': source, 'plugin': plugin_name, 'exc': e, 'tb': tb})
|
|
|
|
|
except Exception as e:
|
|
|
|
|
display.debug('%s failed to parse %s' % (plugin_name, source))
|
|
|
|
|
failures.append({'src': source, 'plugin': plugin_name, 'exc': AnsibleError(e)})
|
|
|
|
|
display.debug('%s failed while attempting to parse %s' % (plugin_name, source))
|
|
|
|
|
tb = ''.join(traceback.format_tb(sys.exc_info()[2]))
|
|
|
|
|
failures.append({'src': source, 'plugin': plugin_name, 'exc': AnsibleError(e), 'tb': tb})
|
|
|
|
|
else:
|
|
|
|
|
display.v('%s did not meet %s requirements, check plugin documentation if this is unexpected' % (source, plugin_name))
|
|
|
|
|
else:
|
|
|
|
|
@ -287,8 +291,8 @@ class InventoryManager(object):
|
|
|
|
|
# only if no plugin processed files should we show errors.
|
|
|
|
|
for fail in failures:
|
|
|
|
|
display.warning(u'\n* Failed to parse %s with %s plugin: %s' % (to_text(fail['src']), fail['plugin'], to_text(fail['exc'])))
|
|
|
|
|
if hasattr(fail['exc'], 'tb'):
|
|
|
|
|
display.vvv(to_text(fail['exc'].tb))
|
|
|
|
|
if 'tb' in fail:
|
|
|
|
|
display.vvv(to_text(fail['tb']))
|
|
|
|
|
if C.INVENTORY_ANY_UNPARSED_IS_FAILED:
|
|
|
|
|
raise AnsibleError(u'Completely failed to parse inventory source %s' % (source))
|
|
|
|
|
if not parsed:
|
|
|
|
|
|