Browse Source

Implement test for parsing failures

pull/172/head
Oliverpool 9 years ago
parent
commit
5eae2230b2
  1. 3
      patacrep/songs/chordpro/syntax.py
  2. 0
      test/test_chordpro/errors/invalid_content.source
  3. 1
      test/test_chordpro/invalid_content.sgc
  4. 26
      test/test_chordpro/test_parser.py

3
patacrep/songs/chordpro/syntax.py

@ -320,6 +320,5 @@ def parse_song(content, filename=None):
) )
if parsed_content is None: if parsed_content is None:
# There was a fatal error parsing the content # There was a fatal error parsing the content
# TODO: implement error handling by looking into parser raise SyntaxError('Fatal error during song parsing: {}'.format(filename))
raise Exception('The song could not be parsed')
return parsed_content return parsed_content

0
test/test_chordpro/invalid_content.source → test/test_chordpro/errors/invalid_content.source

1
test/test_chordpro/invalid_content.sgc

@ -1 +0,0 @@
{lang: en}

26
test/test_chordpro/test_parser.py

@ -91,6 +91,14 @@ class FileTest(unittest.TestCase, metaclass=dynamic.DynamicTest):
cls._create_test(base, dest), cls._create_test(base, dest),
) )
with files.chdir('errors'):
for source in sorted(glob.glob('*.source')):
base = source[:-len(".source")]
yield (
"test_{}_failure".format(base),
cls._create_failure(base),
)
@classmethod @classmethod
def _create_test(cls, base, dest): def _create_test(cls, base, dest):
"""Return a function testing that `base` compilation in `dest` format. """Return a function testing that `base` compilation in `dest` format.
@ -105,6 +113,24 @@ class FileTest(unittest.TestCase, metaclass=dynamic.DynamicTest):
).format(base=os.path.basename(base), format=dest) ).format(base=os.path.basename(base), format=dest)
return test_parse_render return test_parse_render
@classmethod
def _create_failure(cls, base):
"""Return a function testing that `base` fails.
"""
def test_parse_render(self):
"""Test that `base` parsing fails."""
sourcename = "{}.source".format(base)
with self.chdir():
with files.chdir('errors'):
parser = self.song_plugins[LANGUAGES['sgc']]['sgc']
self.assertRaises(SyntaxError, parser, sourcename, self.config)
test_parse_render.__doc__ = (
"Test that '{base}' parsing fails."
).format(base=os.path.basename(base))
return test_parse_render
@classmethod @classmethod
def _overwrite_clrf(cls): def _overwrite_clrf(cls):
"""Overwrite `*.crlf.source` files to force the CRLF line endings. """Overwrite `*.crlf.source` files to force the CRLF line endings.

Loading…
Cancel
Save