blob: 9258ba788874ecda871d731f5068489b431f0bfd [file] [log] [blame]
Gilles Peskine3d4ea542022-11-30 17:35:44 +01001#!/bin/sh
2
Gilles Peskineeff88032022-11-30 17:51:44 +01003help () {
4 cat <<EOF
Gilles Peskine749a0d72022-11-30 18:08:14 +01005Usage: $0 [-r]
Gilles Peskineeff88032022-11-30 17:51:44 +01006Collect coverage statistics of library code into an HTML report.
7
8General instructions:
Gilles Peskine202b1a02022-12-01 17:41:36 +010091. Build the library with CFLAGS="--coverage -O0 -g3" and link the test
10 programs with LDFLAGS="--coverage".
Gilles Peskineeff88032022-11-30 17:51:44 +010011 This can be an out-of-tree build.
Gilles Peskine202b1a02022-12-01 17:41:36 +010012 For example (in-tree):
13 make CFLAGS="--coverage -O0 -g3" LDFLAGS="--coverage"
14 Or (out-of-tree):
15 mkdir build-coverage && cd build-coverage &&
16 cmake -D CMAKE_BUILD_TYPE=Coverage .. && make
Gilles Peskineeff88032022-11-30 17:51:44 +0100172. Run whatever tests you want.
183. Run this script from the parent of the directory containing the library
19 object files and coverage statistics files.
204. Browse the coverage report in Coverage/index.html.
Gilles Peskine749a0d72022-11-30 18:08:14 +0100215. After rework, run "$0 -r", then re-test and run "$0" to get a fresh report.
22
23Options
24 -r Reset traces. Run this before re-testing to get fresh measurements.
Gilles Peskineeff88032022-11-30 17:51:44 +010025EOF
26}
27
28# Copyright The Mbed TLS Contributors
Dave Rodgman16799db2023-11-02 19:47:20 +000029# SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Gilles Peskineeff88032022-11-30 17:51:44 +010030
31set -eu
32
Thomas Daubney11120f92023-10-19 15:27:59 +010033# Repository detection
Thomas Daubneyc0ae5692023-10-23 17:25:52 +010034in_mbedtls_build_dir () {
35 test -d library
Thomas Daubney11120f92023-10-19 15:27:59 +010036 }
37
Gilles Peskine749a0d72022-11-30 18:08:14 +010038# Collect stats and build a HTML report.
39lcov_library_report () {
Gilles Peskineeff88032022-11-30 17:51:44 +010040 rm -rf Coverage
Gilles Peskinee628f292022-11-30 17:56:58 +010041 mkdir Coverage Coverage/tmp
Thomas Daubney11120f92023-10-19 15:27:59 +010042 lcov --capture --initial --directory $library_dir -o Coverage/tmp/files.info
43 lcov --rc lcov_branch_coverage=1 --capture --directory $library_dir -o Coverage/tmp/tests.info
Gilles Peskinee628f292022-11-30 17:56:58 +010044 lcov --rc lcov_branch_coverage=1 --add-tracefile Coverage/tmp/files.info --add-tracefile Coverage/tmp/tests.info -o Coverage/tmp/all.info
45 lcov --rc lcov_branch_coverage=1 --remove Coverage/tmp/all.info -o Coverage/tmp/final.info '*.h'
46 gendesc tests/Descriptions.txt -o Coverage/tmp/descriptions
Thomas Daubney11120f92023-10-19 15:27:59 +010047 genhtml --title "$title" --description-file Coverage/tmp/descriptions --keep-descriptions --legend --branch-coverage -o Coverage Coverage/tmp/final.info
Gilles Peskinee628f292022-11-30 17:56:58 +010048 rm -f Coverage/tmp/*.info Coverage/tmp/descriptions
Gilles Peskineeff88032022-11-30 17:51:44 +010049 echo "Coverage report in: Coverage/index.html"
50}
51
Gilles Peskine749a0d72022-11-30 18:08:14 +010052# Reset the traces to 0.
53lcov_reset_traces () {
54 # Location with plain make
Thomas Daubney11120f92023-10-19 15:27:59 +010055 rm -f $library_dir/*.gcda
Gilles Peskine749a0d72022-11-30 18:08:14 +010056 # Location with CMake
Thomas Daubney11120f92023-10-19 15:27:59 +010057 rm -f $library_dir/CMakeFiles/*.dir/*.gcda
Gilles Peskine749a0d72022-11-30 18:08:14 +010058}
59
Gilles Peskineeff88032022-11-30 17:51:44 +010060if [ $# -gt 0 ] && [ "$1" = "--help" ]; then
61 help
62 exit
63fi
64
Thomas Daubneyc0ae5692023-10-23 17:25:52 +010065if in_mbedtls_build_dir; then
Thomas Daubney11120f92023-10-19 15:27:59 +010066 library_dir='library'
67 title='Mbed TLS'
68else
Thomas Daubneyc0ae5692023-10-23 17:25:52 +010069 library_dir='core'
Thomas Daubney11120f92023-10-19 15:27:59 +010070 title='TF-PSA-Crypto'
71fi
72
Gilles Peskine749a0d72022-11-30 18:08:14 +010073main=lcov_library_report
74while getopts r OPTLET; do
75 case $OPTLET in
76 r) main=lcov_reset_traces;;
77 *) help 2>&1; exit 120;;
78 esac
79done
80shift $((OPTIND - 1))
81
82"$main" "$@"