Files @ 52bbeb1e813f
Branch filter:

Location: kallithea/pylons_app/lib/timerproxy.py

Marcin Kuzminski
Added universal cache invalidator for two cached functions.
added invalidation when repository was added or deleted, and another invalidation when there was a mercurial command involved.
from sqlalchemy.interfaces import ConnectionProxy
import time
import logging
log = logging.getLogger('timerproxy')
BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE = xrange(30, 38)

def color_sql(sql):
    COLOR_SEQ = "\033[1;%dm"
    COLOR_SQL = YELLOW
    normal = '\x1b[0m'
    return COLOR_SEQ % COLOR_SQL + sql + normal 

def format_sql(sql):
    sql = color_sql(sql)
    sql = sql.replace('SELECT', '\n    SELECT \n\t')\
        .replace('FROM', '\n    FROM')\
        .replace('ORDER BY', '\n    ORDER BY')\
        .replace('LIMIT', '\n    LIMIT')\
        .replace('WHERE', '\n    WHERE')\
        .replace('AND', '\n    AND')\
        .replace('LEFT', '\n    LEFT')\
        .replace('INNER', '\n    INNER')\
        .replace('INSERT', '\n    INSERT')\
        .replace('DELETE', '\n    DELETE')
    return sql


class TimerProxy(ConnectionProxy):
    def cursor_execute(self, execute, cursor, statement, parameters, context, executemany):
        now = time.time()
        try:
            log.info(">>>>> STARTING QUERY >>>>>")
            return execute(cursor, statement, parameters, context)
        finally:
            total = time.time() - now
            try:
                log.info(format_sql("Query: %s" % statement % parameters))
            except TypeError:
                log.info(format_sql("Query: %s %s" % (statement, parameters)))
            log.info("<<<<< TOTAL TIME: %f <<<<<" % total)