2019-07-25 23:29:23 -07:00
|
|
|
"""Sanity test for the sanity ignore file."""
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
|
|
|
|
2019-07-30 16:03:27 -07:00
|
|
|
import os
|
|
|
|
|
2019-08-06 14:43:29 -07:00
|
|
|
from ..sanity import (
|
2019-07-25 23:29:23 -07:00
|
|
|
SanityFailure,
|
|
|
|
SanityIgnoreParser,
|
2019-07-26 16:46:52 -07:00
|
|
|
SanityVersionNeutral,
|
2019-07-25 23:29:23 -07:00
|
|
|
SanitySuccess,
|
|
|
|
SanityMessage,
|
|
|
|
)
|
|
|
|
|
2019-08-06 14:43:29 -07:00
|
|
|
from ..test import (
|
2019-07-25 23:29:23 -07:00
|
|
|
calculate_confidence,
|
|
|
|
calculate_best_confidence,
|
|
|
|
)
|
|
|
|
|
2019-08-06 14:43:29 -07:00
|
|
|
from ..config import (
|
2019-07-25 23:29:23 -07:00
|
|
|
SanityConfig,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2019-07-26 16:46:52 -07:00
|
|
|
class IgnoresTest(SanityVersionNeutral):
|
2019-07-25 23:29:23 -07:00
|
|
|
"""Sanity test for sanity test ignore entries."""
|
|
|
|
@property
|
|
|
|
def can_ignore(self): # type: () -> bool
|
|
|
|
"""True if the test supports ignore entries."""
|
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
2019-07-30 11:10:55 -07:00
|
|
|
def no_targets(self): # type: () -> bool
|
|
|
|
"""True if the test does not use test targets. Mutually exclusive with all_targets."""
|
|
|
|
return True
|
2019-07-25 23:29:23 -07:00
|
|
|
|
|
|
|
# noinspection PyUnusedLocal
|
|
|
|
def test(self, args, targets): # pylint: disable=locally-disabled, unused-argument
|
|
|
|
"""
|
|
|
|
:type args: SanityConfig
|
|
|
|
:type targets: SanityTargets
|
|
|
|
:rtype: TestResult
|
|
|
|
"""
|
|
|
|
sanity_ignore = SanityIgnoreParser.load(args)
|
|
|
|
|
|
|
|
messages = []
|
|
|
|
|
|
|
|
# parse errors
|
|
|
|
|
|
|
|
messages.extend(SanityMessage(
|
|
|
|
message=message,
|
|
|
|
path=sanity_ignore.relative_path,
|
|
|
|
line=line,
|
|
|
|
column=column,
|
|
|
|
confidence=calculate_confidence(sanity_ignore.path, line, args.metadata) if args.metadata.changes else None,
|
|
|
|
) for line, column, message in sanity_ignore.parse_errors)
|
|
|
|
|
|
|
|
# file not found errors
|
|
|
|
|
|
|
|
messages.extend(SanityMessage(
|
2019-07-30 16:03:27 -07:00
|
|
|
message="%s '%s' does not exist" % ("Directory" if path.endswith(os.path.sep) else "File", path),
|
2019-07-25 23:29:23 -07:00
|
|
|
path=sanity_ignore.relative_path,
|
|
|
|
line=line,
|
|
|
|
column=1,
|
|
|
|
confidence=calculate_best_confidence(((sanity_ignore.path, line), (path, 0)), args.metadata) if args.metadata.changes else None,
|
|
|
|
) for line, path in sanity_ignore.file_not_found_errors)
|
|
|
|
|
|
|
|
# conflicting ignores and skips
|
|
|
|
|
|
|
|
for test_name, ignores in sanity_ignore.ignores.items():
|
|
|
|
for ignore_path, ignore_entry in ignores.items():
|
|
|
|
skip_line_no = sanity_ignore.skips.get(test_name, {}).get(ignore_path)
|
|
|
|
|
|
|
|
if not skip_line_no:
|
|
|
|
continue
|
|
|
|
|
|
|
|
for ignore_line_no in ignore_entry.values():
|
|
|
|
messages.append(SanityMessage(
|
|
|
|
message="Ignoring '%s' is unnecessary due to skip entry on line %d" % (ignore_path, skip_line_no),
|
|
|
|
path=sanity_ignore.relative_path,
|
|
|
|
line=ignore_line_no,
|
|
|
|
column=1,
|
|
|
|
confidence=calculate_confidence(sanity_ignore.path, ignore_line_no, args.metadata) if args.metadata.changes else None,
|
|
|
|
))
|
|
|
|
|
|
|
|
if messages:
|
|
|
|
return SanityFailure(self.name, messages=messages)
|
|
|
|
|
|
|
|
return SanitySuccess(self.name)
|