mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Test line numbers and "fix" a bug in the scalar line counting
This commit is contained in:
parent
4a5b37542d
commit
b152275a36
2 changed files with 175 additions and 26 deletions
|
@ -35,8 +35,13 @@ class AnsibleComposer(Composer):
|
||||||
# token's line (what about multiline strings? Perhaps we also
|
# token's line (what about multiline strings? Perhaps we also
|
||||||
# need to use previous token ended
|
# need to use previous token ended
|
||||||
node.__datasource__ = self.name
|
node.__datasource__ = self.name
|
||||||
node.__line__ = self.line + 1
|
node.__line__ = self.line
|
||||||
node.__column__ = self.column + 1
|
|
||||||
|
# Need to investigate why this works...
|
||||||
|
if self.indents:
|
||||||
|
node.__column__ = self.indent + 1
|
||||||
|
else:
|
||||||
|
node.__column__ = self.column +1
|
||||||
elif isinstance(node, MappingNode):
|
elif isinstance(node, MappingNode):
|
||||||
node.__datasource__ = self.name
|
node.__datasource__ = self.name
|
||||||
|
|
||||||
|
@ -58,4 +63,3 @@ class AnsibleComposer(Composer):
|
||||||
# should be good enough to determine the error location.
|
# should be good enough to determine the error location.
|
||||||
self.__mapping_starts.append((self.line + 1, self.column + 1))
|
self.__mapping_starts.append((self.line + 1, self.column + 1))
|
||||||
return Composer.compose_mapping_node(self, anchor)
|
return Composer.compose_mapping_node(self, anchor)
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from cStringIO import StringIO
|
from StringIO import StringIO
|
||||||
from collections import Sequence, Set, Mapping
|
from collections import Sequence, Set, Mapping
|
||||||
|
|
||||||
from ansible.compat.tests import unittest
|
from ansible.compat.tests import unittest
|
||||||
|
@ -28,7 +28,7 @@ from ansible.compat.tests.mock import patch
|
||||||
|
|
||||||
from ansible.parsing.yaml.loader import AnsibleLoader
|
from ansible.parsing.yaml.loader import AnsibleLoader
|
||||||
|
|
||||||
class TestDataLoader(unittest.TestCase):
|
class TestAnsibleLoaderBasic(unittest.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
pass
|
pass
|
||||||
|
@ -40,52 +40,78 @@ class TestDataLoader(unittest.TestCase):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
1
|
1
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
loader = AnsibleLoader(stream, 'myfile.yml')
|
||||||
data = loader.get_single_data()
|
data = loader.get_single_data()
|
||||||
self.assertEqual(data, 1)
|
self.assertEqual(data, 1)
|
||||||
|
# No line/column info saved yet
|
||||||
|
|
||||||
def test_parse_string(self):
|
def test_parse_string(self):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
Ansible
|
Ansible
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
loader = AnsibleLoader(stream, 'myfile.yml')
|
||||||
data = loader.get_single_data()
|
data = loader.get_single_data()
|
||||||
self.assertEqual(data, u'Ansible')
|
self.assertEqual(data, u'Ansible')
|
||||||
self.assertIsInstance(data, unicode)
|
self.assertIsInstance(data, unicode)
|
||||||
|
|
||||||
|
self.assertEqual(data._line_number, 2)
|
||||||
|
self.assertEqual(data._column_number, 17)
|
||||||
|
self.assertEqual(data._data_source, 'myfile.yml')
|
||||||
|
|
||||||
def test_parse_utf8_string(self):
|
def test_parse_utf8_string(self):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
Cafè Eñyei
|
Cafè Eñyei
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
loader = AnsibleLoader(stream, 'myfile.yml')
|
||||||
data = loader.get_single_data()
|
data = loader.get_single_data()
|
||||||
self.assertEqual(data, u'Cafè Eñyei')
|
self.assertEqual(data, u'Cafè Eñyei')
|
||||||
self.assertIsInstance(data, unicode)
|
self.assertIsInstance(data, unicode)
|
||||||
|
|
||||||
|
self.assertEqual(data._line_number, 2)
|
||||||
|
self.assertEqual(data._column_number, 17)
|
||||||
|
self.assertEqual(data._data_source, 'myfile.yml')
|
||||||
|
|
||||||
def test_parse_dict(self):
|
def test_parse_dict(self):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
webster: daniel
|
webster: daniel
|
||||||
oed: oxford
|
oed: oxford
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
loader = AnsibleLoader(stream, 'myfile.yml')
|
||||||
data = loader.get_single_data()
|
data = loader.get_single_data()
|
||||||
self.assertEqual(data, {'webster': 'daniel', 'oed': 'oxford'})
|
self.assertEqual(data, {'webster': 'daniel', 'oed': 'oxford'})
|
||||||
self.assertEqual(len(data), 2)
|
self.assertEqual(len(data), 2)
|
||||||
self.assertIsInstance(data.keys()[0], unicode)
|
self.assertIsInstance(data.keys()[0], unicode)
|
||||||
self.assertIsInstance(data.values()[0], unicode)
|
self.assertIsInstance(data.values()[0], unicode)
|
||||||
|
|
||||||
|
# Note: this is the beginning of the first value.
|
||||||
|
# May be changed in the future to beginning of the first key
|
||||||
|
self.assertEqual(data._line_number, 2)
|
||||||
|
self.assertEqual(data._column_number, 25)
|
||||||
|
self.assertEqual(data._data_source, 'myfile.yml')
|
||||||
|
|
||||||
|
self.assertEqual(data[u'webster']._line_number, 2)
|
||||||
|
self.assertEqual(data[u'webster']._column_number, 17)
|
||||||
|
self.assertEqual(data[u'webster']._data_source, 'myfile.yml')
|
||||||
|
|
||||||
|
self.assertEqual(data[u'oed']._line_number, 3)
|
||||||
|
self.assertEqual(data[u'oed']._column_number, 17)
|
||||||
|
self.assertEqual(data[u'oed']._data_source, 'myfile.yml')
|
||||||
|
|
||||||
def test_parse_list(self):
|
def test_parse_list(self):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
- a
|
- a
|
||||||
- b
|
- b
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
loader = AnsibleLoader(stream, 'myfile.yml')
|
||||||
data = loader.get_single_data()
|
data = loader.get_single_data()
|
||||||
self.assertEqual(data, [u'a', u'b'])
|
self.assertEqual(data, [u'a', u'b'])
|
||||||
self.assertEqual(len(data), 2)
|
self.assertEqual(len(data), 2)
|
||||||
self.assertIsInstance(data[0], unicode)
|
self.assertIsInstance(data[0], unicode)
|
||||||
|
# No line/column info saved yet
|
||||||
|
|
||||||
def test_parse_play(self):
|
class TestAnsibleLoaderPlay(unittest.TestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
stream = StringIO("""
|
stream = StringIO("""
|
||||||
- hosts: localhost
|
- hosts: localhost
|
||||||
vars:
|
vars:
|
||||||
|
@ -112,29 +138,35 @@ class TestDataLoader(unittest.TestCase):
|
||||||
- name: Test 3
|
- name: Test 3
|
||||||
command: "printf 'Cafè Eñyei\\n'"
|
command: "printf 'Cafè Eñyei\\n'"
|
||||||
""")
|
""")
|
||||||
loader = AnsibleLoader(stream)
|
self.play_filename = '/path/to/myplay.yml'
|
||||||
data = loader.get_single_data()
|
stream.name = self.play_filename
|
||||||
self.assertEqual(len(data), 1)
|
self.loader = AnsibleLoader(stream)
|
||||||
self.assertIsInstance(data, list)
|
self.data = self.loader.get_single_data()
|
||||||
self.assertEqual(frozenset(data[0].keys()), frozenset((u'hosts', u'vars', u'tasks')))
|
|
||||||
|
|
||||||
self.assertEqual(data[0][u'hosts'], u'localhost')
|
def tearDown(self):
|
||||||
|
pass
|
||||||
|
|
||||||
self.assertEqual(data[0][u'vars'][u'number'], 1)
|
def test_data_complete(self):
|
||||||
self.assertEqual(data[0][u'vars'][u'string'], u'Ansible')
|
return
|
||||||
self.assertEqual(data[0][u'vars'][u'utf8_string'], u'Cafè Eñyei')
|
self.assertEqual(len(self.data), 1)
|
||||||
self.assertEqual(data[0][u'vars'][u'dictionary'],
|
self.assertIsInstance(self.data, list)
|
||||||
|
self.assertEqual(frozenset(self.data[0].keys()), frozenset((u'hosts', u'vars', u'tasks')))
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'hosts'], u'localhost')
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'number'], 1)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'string'], u'Ansible')
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'utf8_string'], u'Cafè Eñyei')
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'],
|
||||||
{u'webster': u'daniel',
|
{u'webster': u'daniel',
|
||||||
u'oed': u'oxford'})
|
u'oed': u'oxford'})
|
||||||
self.assertEqual(data[0][u'vars'][u'list'], [u'a', u'b', 1, 2])
|
self.assertEqual(self.data[0][u'vars'][u'list'], [u'a', u'b', 1, 2])
|
||||||
|
|
||||||
self.assertEqual(data[0][u'tasks'],
|
self.assertEqual(self.data[0][u'tasks'],
|
||||||
[{u'name': u'Test case', u'ping': {u'data': u'{{ utf8_string }}'}},
|
[{u'name': u'Test case', u'ping': {u'data': u'{{ utf8_string }}'}},
|
||||||
{u'name': u'Test 2', u'ping': {u'data': u'Cafè Eñyei'}},
|
{u'name': u'Test 2', u'ping': {u'data': u'Cafè Eñyei'}},
|
||||||
{u'name': u'Test 3', u'command': u'printf \'Cafè Eñyei\n\''},
|
{u'name': u'Test 3', u'command': u'printf \'Cafè Eñyei\n\''},
|
||||||
])
|
])
|
||||||
|
|
||||||
self.walk(data)
|
|
||||||
|
|
||||||
def walk(self, data):
|
def walk(self, data):
|
||||||
# Make sure there's no str in the data
|
# Make sure there's no str in the data
|
||||||
|
@ -154,3 +186,116 @@ class TestDataLoader(unittest.TestCase):
|
||||||
|
|
||||||
# Scalars were all checked so we're good to go
|
# Scalars were all checked so we're good to go
|
||||||
return
|
return
|
||||||
|
|
||||||
|
def test_no_str_in_data(self):
|
||||||
|
# Checks that no strings are str type
|
||||||
|
self.walk(self.data)
|
||||||
|
|
||||||
|
def check_vars(self):
|
||||||
|
# Numbers don't have line/col information yet
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'number']._line_number, 4)
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'number']._column_number, 21)
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'number']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'string']._line_number, 5)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'string']._column_number, 21)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'string']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'utf8_string']._line_number, 6)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'utf8_string']._column_number, 21)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'utf8_string']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary']._line_number, 8)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary']._column_number, 31)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'webster']._line_number, 8)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'webster']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'webster']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'oed']._line_number, 9)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'oed']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'vars'][u'dictionary'][u'oed']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
# Lists don't yet have line/col information
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'list']._line_number, 10)
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'list']._column_number, 21)
|
||||||
|
#self.assertEqual(self.data[0][u'vars'][u'list']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
def check_tasks(self):
|
||||||
|
#
|
||||||
|
# First Task
|
||||||
|
#
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0]._line_number, 16)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0]._column_number, 28)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0]._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'name']._line_number, 16)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'name']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'name']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'ping']._line_number, 18)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'ping']._column_number, 30)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'ping']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
#self.assertEqual(self.data[0][u'tasks'][0][u'ping'][u'data']._line_number, 18)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'ping'][u'data']._column_number, 25)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][0][u'ping'][u'data']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Second Task
|
||||||
|
#
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1]._line_number, 20)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1]._column_number, 28)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1]._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'name']._line_number, 20)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'name']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'name']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'ping']._line_number, 22)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'ping']._column_number, 30)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'ping']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
#self.assertEqual(self.data[0][u'tasks'][1][u'ping'][u'data']._line_number, 22)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'ping'][u'data']._column_number, 25)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][1][u'ping'][u'data']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Third Task
|
||||||
|
#
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2]._line_number, 24)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2]._column_number, 28)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2]._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2][u'name']._line_number, 24)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2][u'name']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2][u'name']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
#self.assertEqual(self.data[0][u'tasks'][2][u'command']._line_number, 25)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2][u'command']._column_number, 23)
|
||||||
|
self.assertEqual(self.data[0][u'tasks'][2][u'command']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
def test_line_numbers(self):
|
||||||
|
# Check the line/column numbers are correct
|
||||||
|
# Note: Remember, currently dicts begin at the start of their first entry's value
|
||||||
|
self.assertEqual(self.data[0]._line_number, 2)
|
||||||
|
self.assertEqual(self.data[0]._column_number, 25)
|
||||||
|
self.assertEqual(self.data[0]._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'hosts']._line_number, 2)
|
||||||
|
self.assertEqual(self.data[0][u'hosts']._column_number, 19)
|
||||||
|
self.assertEqual(self.data[0][u'hosts']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.assertEqual(self.data[0][u'vars']._line_number, 4)
|
||||||
|
self.assertEqual(self.data[0][u'vars']._column_number, 28)
|
||||||
|
self.assertEqual(self.data[0][u'vars']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.check_vars()
|
||||||
|
|
||||||
|
# Lists don't yet have line/col info
|
||||||
|
#self.assertEqual(self.data[0][u'tasks']._line_number, 17)
|
||||||
|
#self.assertEqual(self.data[0][u'tasks']._column_number, 28)
|
||||||
|
#self.assertEqual(self.data[0][u'tasks']._data_source, self.play_filename)
|
||||||
|
|
||||||
|
self.check_tasks()
|
||||||
|
|
Loading…
Reference in a new issue