2017-09-22 09:43:12 +08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
"""
|
|
|
|
Update reference results for static analyzer.
|
|
|
|
"""
|
|
|
|
|
2017-09-23 06:58:46 +08:00
|
|
|
import SATestBuild
|
|
|
|
|
|
|
|
from subprocess import check_call
|
2017-09-22 09:43:12 +08:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
Verbose = 1
|
2017-10-03 01:59:12 +08:00
|
|
|
|
|
|
|
|
2018-02-28 09:55:23 +08:00
|
|
|
def runCmd(Command, **kwargs):
|
2017-09-22 09:43:12 +08:00
|
|
|
if Verbose:
|
|
|
|
print "Executing %s" % Command
|
2018-02-28 09:55:23 +08:00
|
|
|
check_call(Command, shell=True, **kwargs)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
2017-10-03 01:59:12 +08:00
|
|
|
|
2017-09-22 09:43:12 +08:00
|
|
|
def updateReferenceResults(ProjName, ProjBuildMode):
|
|
|
|
ProjDir = SATestBuild.getProjectDir(ProjName)
|
|
|
|
|
2017-10-03 01:59:12 +08:00
|
|
|
RefResultsPath = os.path.join(
|
|
|
|
ProjDir,
|
|
|
|
SATestBuild.getSBOutputDirName(IsReferenceBuild=True))
|
|
|
|
CreatedResultsPath = os.path.join(
|
|
|
|
ProjDir,
|
|
|
|
SATestBuild.getSBOutputDirName(IsReferenceBuild=False))
|
2017-09-22 09:43:12 +08:00
|
|
|
|
|
|
|
if not os.path.exists(CreatedResultsPath):
|
|
|
|
print >> sys.stderr, "New results not found, was SATestBuild.py "\
|
|
|
|
"previously run?"
|
2017-10-26 09:13:22 +08:00
|
|
|
sys.exit(1)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
2017-10-03 01:59:12 +08:00
|
|
|
BuildLogPath = SATestBuild.getBuildLogPath(RefResultsPath)
|
2018-03-01 10:18:54 +08:00
|
|
|
Dirname = os.path.dirname(os.path.abspath(BuildLogPath))
|
|
|
|
runCmd("mkdir -p '%s'" % Dirname)
|
2017-10-03 01:59:12 +08:00
|
|
|
with open(BuildLogPath, "wb+") as PBuildLogFile:
|
2018-02-28 09:55:23 +08:00
|
|
|
# Remove reference results: in git, and then again for a good measure
|
|
|
|
# with rm, as git might not remove things fully if there are empty
|
|
|
|
# directories involved.
|
|
|
|
runCmd('git rm -r -q "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
|
|
|
|
runCmd('rm -rf "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
|
|
|
|
|
|
|
|
# Replace reference results with a freshly computed once.
|
|
|
|
runCmd('cp -r "%s" "%s"' % (CreatedResultsPath, RefResultsPath,),
|
|
|
|
stdout=PBuildLogFile)
|
|
|
|
|
|
|
|
# Run cleanup script.
|
2017-09-22 09:43:12 +08:00
|
|
|
SATestBuild.runCleanupScript(ProjDir, PBuildLogFile)
|
|
|
|
|
2018-02-28 09:55:23 +08:00
|
|
|
SATestBuild.normalizeReferenceResults(
|
|
|
|
ProjDir, RefResultsPath, ProjBuildMode)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
2018-02-28 09:55:23 +08:00
|
|
|
# Clean up the generated difference results.
|
|
|
|
SATestBuild.cleanupReferenceResults(RefResultsPath)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
2018-02-28 09:55:23 +08:00
|
|
|
runCmd('git add "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
2017-10-03 01:59:12 +08:00
|
|
|
|
2017-09-22 09:43:12 +08:00
|
|
|
def main(argv):
|
|
|
|
if len(argv) == 2 and argv[1] in ('-h', '--help'):
|
|
|
|
print >> sys.stderr, "Update static analyzer reference results based "\
|
2017-09-23 06:58:46 +08:00
|
|
|
"\non the previous run of SATestBuild.py.\n"\
|
2017-10-03 01:59:12 +08:00
|
|
|
"\nN.B.: Assumes that SATestBuild.py was just run"
|
2017-10-26 09:13:22 +08:00
|
|
|
sys.exit(1)
|
2017-09-22 09:43:12 +08:00
|
|
|
|
|
|
|
with SATestBuild.projectFileHandler() as f:
|
|
|
|
for (ProjName, ProjBuildMode) in SATestBuild.iterateOverProjects(f):
|
|
|
|
updateReferenceResults(ProjName, int(ProjBuildMode))
|
|
|
|
|
2017-10-03 01:59:12 +08:00
|
|
|
|
2017-09-22 09:43:12 +08:00
|
|
|
if __name__ == '__main__':
|
|
|
|
main(sys.argv)
|