blob: 8cda8d16b251cf1bf71f5d7a7d8dea39a5282b7b [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
13Verbose = 1
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)
38 with open(BuildLogPath, "wb+") as PBuildLogFile:
George Karpenkov3f560da2018-02-28 01:55:23 +000039 # Remove reference results: in git, and then again for a good measure
40 # with rm, as git might not remove things fully if there are empty
41 # directories involved.
42 runCmd('git rm -r -q "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
43 runCmd('rm -rf "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
44
45 # Replace reference results with a freshly computed once.
46 runCmd('cp -r "%s" "%s"' % (CreatedResultsPath, RefResultsPath,),
47 stdout=PBuildLogFile)
48
49 # Run cleanup script.
George Karpenkovaff33382017-09-22 01:43:12 +000050 SATestBuild.runCleanupScript(ProjDir, PBuildLogFile)
51
George Karpenkov3f560da2018-02-28 01:55:23 +000052 SATestBuild.normalizeReferenceResults(
53 ProjDir, RefResultsPath, ProjBuildMode)
George Karpenkovaff33382017-09-22 01:43:12 +000054
George Karpenkov3f560da2018-02-28 01:55:23 +000055 # Clean up the generated difference results.
56 SATestBuild.cleanupReferenceResults(RefResultsPath)
George Karpenkovaff33382017-09-22 01:43:12 +000057
George Karpenkov3f560da2018-02-28 01:55:23 +000058 runCmd('git add "%s"' % (RefResultsPath,), stdout=PBuildLogFile)
George Karpenkovaff33382017-09-22 01:43:12 +000059
George Karpenkova8076602017-10-02 17:59:12 +000060
George Karpenkovaff33382017-09-22 01:43:12 +000061def main(argv):
62 if len(argv) == 2 and argv[1] in ('-h', '--help'):
63 print >> sys.stderr, "Update static analyzer reference results based "\
George Karpenkov439a95b2017-09-22 22:58:46 +000064 "\non the previous run of SATestBuild.py.\n"\
George Karpenkova8076602017-10-02 17:59:12 +000065 "\nN.B.: Assumes that SATestBuild.py was just run"
George Karpenkov65839bd2017-10-26 01:13:22 +000066 sys.exit(1)
George Karpenkovaff33382017-09-22 01:43:12 +000067
68 with SATestBuild.projectFileHandler() as f:
69 for (ProjName, ProjBuildMode) in SATestBuild.iterateOverProjects(f):
70 updateReferenceResults(ProjName, int(ProjBuildMode))
71
George Karpenkova8076602017-10-02 17:59:12 +000072
George Karpenkovaff33382017-09-22 01:43:12 +000073if __name__ == '__main__':
74 main(sys.argv)