summaryrefslogtreecommitdiffstats
path: root/nova/hacking/checks.py
blob: 89ad7c554ef7293640ea4b1be69917f2486b7458 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# Copyright (c) 2012, Cloudscaling
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
#      http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.


def import_no_db_in_virt(logical_line, filename):
    """Check for db calls from nova/virt

    As of grizzly-2 all the database calls have been removed from
    nova/virt, and we want to keep it that way.

    N307
    """
    if "nova/virt" in filename and not filename.endswith("fake.py"):
        if logical_line.startswith("from nova import db"):
            yield (0, "N307: nova.db import not allowed in nova/virt/*")


def except_python3x_compatible(logical_line, filename):
    """Check for except statements to be Python 3.x compatible

    As of Python 3.x, the construct "except x,y:" has been removed.

    N308
    """

    def is_old_style_except(logical_line):
        # Should match:
        #     except ProcessExecutionError, exn:
        # Should not match:
        #     except UncodeError:
        #     except (x,y):
        return (',' in logical_line
                and ')' not in logical_line.rpartition(',')[2])

    if ("except " in logical_line
            and logical_line.endswith(':')
            and is_old_style_except(logical_line)):
        yield(0, "N308: Python 3.x incompatible 'except x,y:' construct")


def factory(register):
    register(import_no_db_in_virt)
    register(except_python3x_compatible)