Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add severity to standard output. Fixes #93 #111

Merged
merged 4 commits into from
Nov 21, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ Options:
-L list all the rules
-r RULESDIR specify one or more rules directories using one or
more -r arguments. Any -r flags override the default
rules in /path/to/salt-lint/saltlint/rules, unless
rules in /path/to/salt-lint/saltlint/rules, unless
-R is also used.
-R Use default rules in
/path/to/salt-lint/saltlint/rules in addition to any
Expand All @@ -54,6 +54,7 @@ Options:
path to directories or files to skip. This option is
repeatable.
--json parse the output as JSON
--severity add the severity to the standard output
-c C Specify configuration file to use. Defaults to
".salt-lint"
```
Expand Down Expand Up @@ -112,6 +113,7 @@ rules:
*.jinja
210:
ignore: 'exclude_this_file.sls'
severity: True
```

## Pre-commit Setup
Expand Down
4 changes: 4 additions & 0 deletions saltlint/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,8 @@ def run(args=None):
default=[])
parser.add_option('--json', dest='json', action='store_true', default=False,
help='parse the output as JSON')
parser.add_option('--severity', dest='severity', action='store_true', default=False,
help='add the severity to the standard output')
parser.add_option('-c', help='Specify configuration file to use. Defaults to ".salt-lint"')
(options, parsed_args) = parser.parse_args(args if args is not None else sys.argv[1:])

Expand Down Expand Up @@ -111,6 +113,8 @@ def run(args=None):
# Define the formatter
if config.json:
formatter = formatters.JsonFormatter()
elif config.severity:
formatter = formatters.SeverityFormatter()
else:
formatter = formatters.Formatter()

Expand Down
5 changes: 5 additions & 0 deletions saltlint/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,11 @@ def _parse(self, content):
# Parse json
self.json = self._options.get('json', False)

# Parse add severity
self.severity = self._options.get('severity', False)
if 'severity' in config:
self.severity = config['severity']

# Parse rule specific configuration, the configration can be listed by
# the rule ID and/or tag.
self.rules = dict()
Expand Down
33 changes: 33 additions & 0 deletions saltlint/formatters/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,39 @@ def format(self, match, colored=False):
match.line)


class SeverityFormatter(object):
def process(self, matches, colored=False):
for match in matches:
print(self.format(match, colored))

def format(self, match, colored=False):
formatstr = u"{0} {sev} {1}\n{2}:{3}\n{4}\n"

if colored:
color = saltcolor.get_colors()
return formatstr.format(
u'{0}[{1}]{2}'.format(color['RED'], match.rule.id,
color['ENDC']),
u'{0}{1}{2}'.format(color['LIGHT_RED'], match.message,
color['ENDC']),
u'{0}{1}{2}'.format(color['BLUE'], match.filename,
color['ENDC']),
u'{0}{1}{2}'.format(color['CYAN'], str(match.linenumber),
color['ENDC']),
u'{0}{1}{2}'.format(color['MAGENTA'], match.line, color['ENDC']),
sev=u'{0}[{1}]{2}'.format(color['RED'], match.rule.severity,
color['ENDC'])
)
else:
return formatstr.format(
u'[{0}]'.format(match.rule.id),
match.message,
match.filename,
match.linenumber,
match.line,
sev=u'[{0}]'.format(match.rule.severity))


class JsonFormatter(object):

def process(self, matches, *args, **kwargs):
Expand Down