Хук перед проверкой проверяет исходный код перед фиксацией

Я ищу простой скрипт, который проверяет исходный код перед фиксацией.

Я хочу отклонить все файлы, которые содержат "logging.info(...)", так как мы хотим использовать этот шаблон сейчас:

import logging
logger=logging.getLogger(__name__)
del(logging)

#...
logger.info()

1 ответ

Так как я не мог найти решение, я написал это сам:

#!/usr/bin/env python
# scp svn@svnserver:REPOSITORY/hooks/
# ssh svn@svnserver chmod a+rx REPOSITORY/hooks/pre-commit
# Above chmod is important!
import re, sys, subprocess
sys.stdout=sys.stderr
svnlookPath = 'svnlook'

not_allowed=[
    (re.compile(r'^\s*logging\.(error|info|debug).*'), u'use logger!'),
    ]

def main():
    changed=[]

    # sys.argv ['/svn/modwork/hooks/pre-commit', '/svn/modwork', '4508-bm']
    pipe = subprocess.Popen([svnlookPath, 'changed', sys.argv[1], '--transaction', sys.argv[2]], stdout=subprocess.PIPE)
    for line in pipe.stdout:
        change_type, fn = line.split(' ', 1)
        if not change_type[0] in 'AUC':
            continue # skip, not a source code change: delete or meta data update.
        changed.append(fn.strip())
    ret=pipe.wait()
    if ret:
        sys.exit(ret)
    for fn in changed:
        if not fn.endswith('.py'):
            continue
        pipe = subprocess.Popen([svnlookPath, 'cat', sys.argv[1], '--transaction', sys.argv[2], fn], stdout=subprocess.PIPE)
        for line in pipe.stdout:
            for regex, help in not_allowed:
                if regex.match(line):
                    print 'Content in file %s is not allowed: %s: %r' % (fn, help, line.strip())
                    sys.exit(1)
                #print 'OK', fn, repr(line)

        ret=pipe.wait()
        if ret:
            sys.exit(ret)

if __name__=='__main__':
    main()
Другие вопросы по тегам