blob: 3f1aafa690e2affbe659df48aaae59d119e6f15e [file] [log] [blame]
George Karpenkovaff33382017-09-22 01:43:12 +00001#!/usr/bin/env python
2
3"""
4Update reference results for static analyzer.
5"""
6
George Karpenkov439a95b2017-09-22 22:58:46 +00007import SATestBuild
8
9from subprocess import check_call
George Karpenkovaff33382017-09-22 01:43:12 +000010import os
11import sys
12
George Karpenkov1f5fe112018-08-07 21:14:35 +000013Verbose = 0
George Karpenkova8076602017-10-02 17:59:12 +000014
15
George Karpenkov3f560da2018-02-28 01:55:23 +000016def runCmd(Command, **kwargs):
George Karpenkovaff33382017-09-22 01:43:12 +000017 if Verbose:
18 print "Executing %s" % Command
George Karpenkov3f560da2018-02-28 01:55:23 +000019 check_call(Command, shell=True, **kwargs)
George Karpenkovaff33382017-09-22 01:43:12 +000020
George Karpenkova8076602017-10-02 17:59:12 +000021
George Karpenkovaff33382017-09-22 01:43:12 +000022def updateReferenceResults(ProjName, ProjBuildMode):
23 ProjDir = SATestBuild.getProjectDir(ProjName)
24
George Karpenkova8076602017-10-02 17:59:12 +000025 RefResultsPath = os.path.join(
26 ProjDir,
27 SATestBuild.getSBOutputDirName(IsReferenceBuild=True))
28 CreatedResultsPath = os.path.join(
29 ProjDir,
30 SATestBuild.getSBOutputDirName(IsReferenceBuild=False))
George Karpenkovaff33382017-09-22 01:43:12 +000031
32 if not os.path.exists(CreatedResultsPath):
33 print >> sys.stderr, "New results not found, was SATestBuild.py "\
34 "previously run?"
George Karpenkov65839bd2017-10-26 01:13:22 +000035 sys.exit(1)
George Karpenkovaff33382017-09-22 01:43:12 +000036
George Karpenkova8076602017-10-02 17:59:12 +000037 BuildLogPath = SATestBuild.getBuildLogPath(RefResultsPath)
George Karpenkovdc0abcb2018-03-01 02:18:54 +000038 Dirname = os.path.dirname(os.path.abspath(BuildLogPath))
39 runCmd("mkdir -p '%s'" % Dirname)
George Karpenkova8076602017-10-02 17:59:12 +000040 with open(BuildLogPath, "wb+") as PBuildLogFile:
George Karpenkov3f560da2018-02-28 01:55:23 +000041 # Remove reference results: in git, and then again for a good measure
42 # with rm, as git might not remove things fully if there are empty
43 # directories involved.
44 runCmd('git rm -r -q "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
45 runCmd('rm -rf "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
46
47 # Replace reference results with a freshly computed once.
48 runCmd('cp -r "%s" "%s"' % (CreatedResultsPath, RefResultsPath,),
49 stdout=PBuildLogFile)
50
51 # Run cleanup script.
George Karpenkovaff33382017-09-22 01:43:12 +000052 SATestBuild.runCleanupScript(ProjDir, PBuildLogFile)
53
George Karpenkov3f560da2018-02-28 01:55:23 +000054 SATestBuild.normalizeReferenceResults(
55 ProjDir, RefResultsPath, ProjBuildMode)
George Karpenkovaff33382017-09-22 01:43:12 +000056
George Karpenkov3f560da2018-02-28 01:55:23 +000057 # Clean up the generated difference results.
58 SATestBuild.cleanupReferenceResults(RefResultsPath)
George Karpenkovaff33382017-09-22 01:43:12 +000059
George Karpenkov3f560da2018-02-28 01:55:23 +000060 runCmd('git add "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
George Karpenkovaff33382017-09-22 01:43:12 +000061
George Karpenkova8076602017-10-02 17:59:12 +000062
George Karpenkovaff33382017-09-22 01:43:12 +000063def main(argv):
64 if len(argv) == 2 and argv[1] in ('-h', '--help'):
65 print >> sys.stderr, "Update static analyzer reference results based "\
George Karpenkov439a95b2017-09-22 22:58:46 +000066 "\non the previous run of SATestBuild.py.\n"\
George Karpenkova8076602017-10-02 17:59:12 +000067 "\nN.B.: Assumes that SATestBuild.py was just run"
George Karpenkov65839bd2017-10-26 01:13:22 +000068 sys.exit(1)
George Karpenkovaff33382017-09-22 01:43:12 +000069
70 with SATestBuild.projectFileHandler() as f:
71 for (ProjName, ProjBuildMode) in SATestBuild.iterateOverProjects(f):
72 updateReferenceResults(ProjName, int(ProjBuildMode))
73
George Karpenkova8076602017-10-02 17:59:12 +000074
George Karpenkovaff33382017-09-22 01:43:12 +000075if __name__ == '__main__':
76 main(sys.argv)