Skip to content

Commit

Permalink
Merge branch 'master' into imp/lexer-errors
Browse files Browse the repository at this point in the history
  • Loading branch information
NiumXp authored Feb 19, 2024
2 parents fac99b4 + 6448e7c commit cfc9433
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 4 deletions.
2 changes: 1 addition & 1 deletion norminette/__main__.py
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ def main():
except KeyboardInterrupt:
sys.exit(1)
errors = format(files)
print(errors)
print(errors, end='')
sys.exit(1 if len(file.errors) else 0)


Expand Down
3 changes: 2 additions & 1 deletion norminette/errors.py
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ def __str__(self) -> str:
highlight = error.highlights[0]
output += f"\n{error.level}: {error.name:<20} "
output += f"(line: {highlight.lineno:>3}, col: {highlight.column:>3}):\t{error.text}"
output += '\n'
return output


Expand All @@ -194,7 +195,7 @@ def __str__(self):
output = {
"files": files,
}
return json.dumps(output, separators=(',', ':'))
return json.dumps(output, separators=(',', ':')) + '\n'


formatters = (
Expand Down
2 changes: 1 addition & 1 deletion tests/rules/rules_generator_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def test_rule_for_file(file, capsys):
context = Context(file, list(lexer), debug=2)
registry.run(context)
errors = HumanizedErrorsFormatter(file)
print(errors)
print(errors, end='')
captured = capsys.readouterr()

assert captured.out == out_content
58 changes: 57 additions & 1 deletion tests/test_errors.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,69 @@
from dataclasses import astuple

import pytest
from unittest.mock import patch

from norminette.file import File
from norminette.lexer import Lexer
from norminette.context import Context
from norminette.registry import Registry
from norminette.errors import JSONErrorsFormatter
from norminette.errors import Error, Errors, Highlight as H
from norminette.errors import HumanizedErrorsFormatter


@pytest.mark.parametrize("files, expected_result, ", [it.values() for it in [
{
"files": [
File("/nium/a.c", "#include <stdio.h>"),
File("/nium/b.c", "int\tmain(void)\n{\n\treturn (1);\n}\n"),
File("/nium/c.c", "int\tfn(int n);\n"),
],
"expected_result": "a.c: OK!\nb.c: OK!\nc.c: OK!\n",
},
{
"files": [
File("skyfall.c", "// Hello"),
],
"expected_result": "skyfall.c: OK!\n",
},
{
"files": [
File("/nium/mortari.c", "#define TRUE 1"),
File("/nium/gensler.c", "int\tmain();\n"),
],
"expected_result": (
"mortari.c: OK!\n"
"gensler.c: Error!\n"
"Error: NO_ARGS_VOID (line: 1, col: 10):\tEmpty function argument requires void\n"
)
},
{
"files": [
File("/nium/john.c", "#define x"),
File("/nium/galt.c", "#define x"),
],
"expected_result": (
"john.c: Error!\n"
"Error: MACRO_NAME_CAPITAL (line: 1, col: 9):\tMacro name must be capitalized\n"
"galt.c: Error!\n"
"Error: MACRO_NAME_CAPITAL (line: 1, col: 9):\tMacro name must be capitalized\n"
)
},
]
])
def test_humanized_formatter_errored_file(files, expected_result):
registry = Registry()

with patch("norminette.rules.check_header.CheckHeader.run") as _:
for file in files:
lexer = Lexer(file)
context = Context(file, lexer.get_tokens())
registry.run(context)

formatter = HumanizedErrorsFormatter(files)
assert str(formatter) == expected_result


tests = [
{
Expand Down Expand Up @@ -47,7 +103,7 @@ def test_json_formatter_errored_file(file, test):
Registry().run(context)

formatter = JSONErrorsFormatter(file)
assert str(formatter) == json.dumps(test, separators=(',', ':'))
assert str(formatter) == json.dumps(test, separators=(',', ':')) + '\n'


def test_error_from_name():
Expand Down

0 comments on commit cfc9433

Please sign in to comment.