Blame tests/test_style.py

Pierre-Yves Chibon 393f31
#!/usr/bin/env python
Pierre-Yves Chibon 393f31
# -*- coding: utf-8 -*-
Pierre-Yves Chibon 393f31
Pierre-Yves Chibon 393f31
"""
Pierre-Yves Chibon 393f31
 (c) 2017 - Copyright Red Hat Inc
Pierre-Yves Chibon 393f31
Pierre-Yves Chibon 393f31
 Authors:
Pierre-Yves Chibon 393f31
   Pierre-Yves Chibon <pingou@pingoured.fr></pingou@pingoured.fr>
Pierre-Yves Chibon 393f31
Pierre-Yves Chibon 393f31
Tests for flake8 compliance of the code
Pierre-Yves Chibon 393f31
Pierre-Yves Chibon 393f31
"""
Pierre-Yves Chibon 393f31
Pierre-Yves Chibon 67d1cc
from __future__ import unicode_literals, absolute_import
Aurélien Bompard dcf6f6
Pierre-Yves Chibon bd1fbf
import os
Pierre-Yves Chibon bd1fbf
import subprocess
Shengjing Zhu 77a68b
import sys
Pierre-Yves Chibon bd1fbf
import unittest
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon d5959a
import six
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon bd1fbf
REPO_PATH = os.path.abspath(
Pierre-Yves Chibon bd1fbf
    os.path.join(os.path.dirname(__file__), '..', 'pagure'))
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon bd1fbf
class TestStyle(unittest.TestCase):
Pierre-Yves Chibon bd1fbf
    """This test class contains tests pertaining to code style."""
Pierre-Yves Chibon bd1fbf
    def test_code_with_flake8(self):
Pierre-Yves Chibon bd1fbf
        """Enforce PEP-8 compliance on the codebase.
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon 140059
        This test runs flake8 on the code, and will fail if it returns a
Pierre-Yves Chibon 140059
        non-zero exit code.
Pierre-Yves Chibon bd1fbf
        """
Pierre-Yves Chibon bd1fbf
        # We ignore E712, which disallows non-identity comparisons with True and False
Pierre-Yves Chibon d5959a
        # We ignore W503, which disallows line break before binary operator
Pierre-Yves Chibon d28de1
        flake8_command = [
Pierre-Yves Chibon 140059
            sys.executable, '-m', 'flake8', '--ignore=E712,W503,E203',
Pierre-Yves Chibon 140059
            REPO_PATH
Pierre-Yves Chibon 140059
        ]
Pierre-Yves Chibon 671c79
Pierre-Yves Chibon 671c79
        # check if we have an old flake8 or not
Pierre-Yves Chibon 671c79
        import flake8
Pierre-Yves Chibon 671c79
        flake8_v = flake8.__version__.split('.')
Pierre-Yves Chibon 671c79
        for idx, val in enumerate(flake8_v):
Pierre-Yves Chibon 671c79
            try:
Pierre-Yves Chibon 671c79
                val = int(val)
Pierre-Yves Chibon 671c79
            except ValueError:
Pierre-Yves Chibon 671c79
                pass
Pierre-Yves Chibon 671c79
            flake8_v[idx] = val
Pierre-Yves Chibon 671c79
        old_flake = tuple(flake8_v) < (3, 0)
Pierre-Yves Chibon 671c79
Pierre-Yves Chibon 671c79
        if old_flake:
Pierre-Yves Chibon 671c79
            raise unittest.SkipTest("Flake8 version too old to be useful")
Pierre-Yves Chibon 671c79
Pierre-Yves Chibon 140059
        proc = subprocess.Popen(
Pierre-Yves Chibon 140059
            flake8_command,
Pierre-Yves Chibon 140059
            stdout=subprocess.PIPE,
Pierre-Yves Chibon 140059
            cwd=REPO_PATH,
Pierre-Yves Chibon 140059
            )
Pierre-Yves Chibon b18561
        print(proc.communicate())
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon b18561
        self.assertEqual(proc.returncode, 0)
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon d5959a
    @unittest.skipIf(
Pierre-Yves Chibon d5959a
        not (six.PY3 and sys.version_info.minor >=6),
Pierre-Yves Chibon d5959a
        "Black is only available in python 3.6+")
Pierre-Yves Chibon d5959a
    def test_code_with_black(self):
Pierre-Yves Chibon d5959a
        """Enforce black compliance on the codebase.
Pierre-Yves Chibon d5959a
Pierre-Yves Chibon 140059
        This test runs black on the code, and will fail if it returns a
Pierre-Yves Chibon 140059
        non-zero exit code.
Pierre-Yves Chibon d5959a
        """
Pierre-Yves Chibon 140059
        black_command = [
Pierre-Yves Chibon 140059
            sys.executable, '-m', 'black', '-l', '79', '--check', REPO_PATH
Pierre-Yves Chibon 140059
        ]
Pierre-Yves Chibon d5959a
        proc = subprocess.Popen(
Pierre-Yves Chibon 140059
            black_command,
Pierre-Yves Chibon 140059
            stdout=subprocess.PIPE,
Pierre-Yves Chibon 140059
            stderr=subprocess.PIPE,
Pierre-Yves Chibon 140059
            cwd=REPO_PATH,
Pierre-Yves Chibon 140059
        )
Pierre-Yves Chibon d5959a
        stdout, stderr = proc.communicate()
Pierre-Yves Chibon d5959a
        print('stdout: ')
Pierre-Yves Chibon d5959a
        print(stdout.decode('utf-8'))
Pierre-Yves Chibon d5959a
        print('stderr: ')
Pierre-Yves Chibon d5959a
        print(stderr.decode('utf-8'))
Pierre-Yves Chibon d5959a
Pierre-Yves Chibon d5959a
        self.assertEqual(proc.returncode, 0)
Pierre-Yves Chibon d5959a
Pierre-Yves Chibon bd1fbf
Pierre-Yves Chibon bd1fbf
if __name__ == '__main__':
Pierre-Yves Chibon bd1fbf
    unittest.main(verbosity=2)