Source code

Revision control

Other Tools

Test Info: Warnings

  • This test gets skipped with pattern: python == 2
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at
import os
import mozunit
import pytest
import mozpack.path as mozpath
from mozlint.result import Issue, ResultSummary
def path(filedir):
def _path(name):
return mozpath.join(filedir, name)
return _path
def linter(lintdir, request):
return os.path.join(lintdir, request.param)
def test_linter_types(lint, linter, files, path):
result = lint.roll(files)
assert isinstance(result, ResultSummary)
assert isinstance(result.issues, dict)
assert path("foobar.js") in result.issues
assert path("no_foobar.js") not in result.issues
issue = result.issues[path("foobar.js")][0]
assert isinstance(issue, Issue)
name = os.path.basename(linter).split(".")[0]
assert issue.linter.lower().startswith(name)
def test_linter_missing_files(lint, linter, filedir):
# Missing files should be caught by `mozlint.cli`, so the only way they
# could theoretically happen is if they show up from versioncontrol. So
# let's just make sure they get ignored.
files = [
os.path.join(filedir, "missing.js"),
os.path.join(filedir, ""),
result = lint.roll(files)
assert result.returncode == 0
result = lint.roll(outgoing=True)
assert result.returncode == 0
def test_no_filter(lint, lintdir, files):, "explicit_path.yml"))
result = lint.roll(files)
assert len(result.issues) == 0
lint.lintargs["use_filters"] = False
result = lint.roll(files)
assert len(result.issues) == 3
def test_global_skipped(lint, lintdir, files):, "global_skipped.yml"))
result = lint.roll(files)
assert len(result.issues) == 0
if __name__ == "__main__":