@ -12,17 +12,15 @@ import re
import os
import os
import time
import time
#
#
# Simple logger
# Simple logger
#
#
class Log :
class Log :
LOG_FILE = " /tmp/precommit-check.log "
def __init__ ( self , filename ) :
self . filename = filename
def __init__ ( self ) :
self . filename = Log . LOG_FILE
self . f = open ( self . filename , ' w+ ' , 0 )
self . f = open ( self . filename , ' w+ ' , 0 )
def caption ( self , str ) :
def caption ( self , str ) :
@ -52,9 +50,9 @@ class Log:
class Env ( object ) :
class Env ( object ) :
def __init__ ( self , tests ) :
def __init__ ( self , logfile , tests ) :
self . tests = tests
self . tests = tests
self . log = Log ( )
self . log = Log ( logfile )
def shell ( self , cmd , path = os . getcwd ( ) ) :
def shell ( self , cmd , path = os . getcwd ( ) ) :
if path :
if path :
@ -87,8 +85,9 @@ class Env(object):
class PreCommitChecker ( Env ) :
class PreCommitChecker ( Env ) :
def __init__ ( self , tests ) :
def __init__ ( self , args ) :
Env . __init__ ( self , tests )
Env . __init__ ( self , args . logfile , args . tests )
self . stop_on_fail = args . stop_on_fail
#
#
# Get commands for a given job from the determinator file
# Get commands for a given job from the determinator file
@ -144,6 +143,7 @@ class PreCommitChecker(Env):
self . print_row ( " TEST " , " RESULT " )
self . print_row ( " TEST " , " RESULT " )
self . print_separator ( )
self . print_separator ( )
result = True
for test in self . tests :
for test in self . tests :
start_time = time . time ( )
start_time = time . time ( )
self . print_test ( test )
self . print_test ( test )
@ -152,11 +152,14 @@ class PreCommitChecker(Env):
if not result :
if not result :
self . log . error ( " Error running test %s " % test )
self . log . error ( " Error running test %s " % test )
self . print_result ( " FAIL ( %d m) " % elapsed_min )
self . print_result ( " FAIL ( %d m) " % elapsed_min )
if self . stop_on_fail :
return False
return False
result = False
else :
self . print_result ( " PASS ( %d m) " % elapsed_min )
self . print_result ( " PASS ( %d m) " % elapsed_min )
self . print_separator ( )
self . print_separator ( )
return True
return result
#
#
# Print a line
# Print a line
@ -182,17 +185,24 @@ class PreCommitChecker(Env):
#
#
parser = argparse . ArgumentParser ( description = ' RocksDB pre-commit checker. ' )
parser = argparse . ArgumentParser ( description = ' RocksDB pre-commit checker. ' )
# --log <logfile>
parser . add_argument ( ' --logfile ' , default = ' /tmp/precommit,log ' ,
help = ' Log file. Default is /tmp/precommit.log ' )
# --stop_on_fail
parser . add_argument ( ' --stop_on_fail ' , action = ' store_false ' , default = True ,
help = ' Stop when an error occurs ' )
# <test ....>
# <test ....>
parser . add_argument ( ' test ' , nargs = ' + ' ,
parser . add_argument ( ' tests ' , nargs = ' + ' ,
help = ' CI test(s) to run. e.g: unit punit asan tsan ubsan ' )
help = ' CI test(s) to run. e.g: unit punit asan tsan ubsan ' )
print ( " Please follow log %s " % Log . LOG_FILE )
args = parser . parse_args ( )
args = parser . parse_args ( )
checker = PreCommitChecker ( args . test )
checker = PreCommitChecker ( args )
print ( " Please follow log %s " % checker . log . filename )
if not checker . run_tests ( ) :
if not checker . run_tests ( ) :
print ( " Error running tests. Please check log file %s " % Log . LOG_FILE )
print ( " Error running tests. Please check log file %s "
% checker . log . filename )
sys . exit ( 1 )
sys . exit ( 1 )
sys . exit ( 0 )
sys . exit ( 0 )