Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 1 | __copyright__ = """ |
| 2 | /* |
Xinyu Zhang | ebc400c | 2022-09-14 11:58:58 +0800 | [diff] [blame] | 3 | * Copyright (c) 2018-2022, Arm Limited. All rights reserved. |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 4 | * |
| 5 | * SPDX-License-Identifier: BSD-3-Clause |
| 6 | * |
| 7 | */ |
| 8 | """ |
| 9 | |
| 10 | """ |
| 11 | Module with helper functions for code coverage reports. |
| 12 | """ |
| 13 | |
| 14 | import os |
| 15 | import subprocess |
Paul Sokolovsky | 75eee75 | 2023-04-10 18:57:57 +0300 | [diff] [blame] | 16 | import logging |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 17 | |
| 18 | from lava_helper import test_lava_dispatch_credentials |
| 19 | |
| 20 | |
Paul Sokolovsky | 75eee75 | 2023-04-10 18:57:57 +0300 | [diff] [blame] | 21 | _log = logging.getLogger(__name__) |
| 22 | |
| 23 | |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 24 | def run(cmd, cwd=None): |
| 25 | print("+ %s" % cmd, flush=True) |
| 26 | subprocess.check_call(cmd, shell=True, cwd=cwd) |
| 27 | |
| 28 | |
Paul Sokolovsky | c2d6d88 | 2022-02-25 19:11:18 +0300 | [diff] [blame] | 29 | def extract_trace_data(lava_log_fname, job_dir): |
| 30 | last_fname = None |
| 31 | f_out = None |
| 32 | with open(lava_log_fname) as f_in: |
| 33 | for l in f_in: |
| 34 | if l.startswith("covtrace-"): |
| 35 | fname, l = l.split(" ", 1) |
| 36 | if fname != last_fname: |
| 37 | if f_out: |
| 38 | f_out.close() |
| 39 | f_out = open(job_dir + "/" + fname, "w") |
| 40 | last_fname = fname |
| 41 | f_out.write(l) |
| 42 | |
| 43 | |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 44 | def coverage_reports(jobs, user_args): |
| 45 | lava = test_lava_dispatch_credentials(user_args) |
| 46 | for job_id, info in jobs.items(): |
| 47 | job_dir = info["job_dir"] |
| 48 | metadata = info["metadata"] |
| 49 | |
| 50 | if os.getenv("CODE_COVERAGE_EN") == "TRUE" and info["device_type"] == "fvp": |
| 51 | |
| 52 | def dl_artifact(fname): |
| 53 | lava.fetch_file( |
Paul Sokolovsky | 2bf6049 | 2023-12-01 21:51:45 +0300 | [diff] [blame] | 54 | metadata["build_job_url"] + "artifact/ci_build/" + fname, |
| 55 | os.path.join(job_dir, os.path.basename(fname)) |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 56 | ) |
| 57 | |
Paul Sokolovsky | 6e83a23 | 2024-03-11 15:30:04 +0700 | [diff] [blame] | 58 | _log.info("Producing coverage report for job %s", job_id) |
Paul Sokolovsky | 2bf6049 | 2023-12-01 21:51:45 +0300 | [diff] [blame] | 59 | dl_artifact("spe/bin/bl2.axf") |
| 60 | dl_artifact("spe/bin/tfm_s.axf") |
| 61 | dl_artifact("nspe/bin/tfm_ns.axf") |
Paul Sokolovsky | d584804 | 2023-12-02 08:22:22 +0300 | [diff] [blame] | 62 | |
| 63 | script_dir = os.path.dirname(__file__) |
| 64 | run("python3 $SHARE_FOLDER/qa-tools/coverage-tool/coverage-reporting/intermediate_layer.py --config-json %s/trace2covjson.json --local-workspace $SHARE_FOLDER" % script_dir, cwd=job_dir) |
Paul Sokolovsky | 2512ec5 | 2022-03-04 00:15:39 +0300 | [diff] [blame] | 65 | run("python3 $SHARE_FOLDER/qa-tools/coverage-tool/coverage-reporting/generate_info_file.py --workspace $SHARE_FOLDER --json covjson.json", cwd=job_dir) |
Paul Sokolovsky | 375c9db | 2022-12-27 23:50:39 +0300 | [diff] [blame] | 66 | # Remove sources, coverage of which we're not interested in (e.g. |
| 67 | # 3rd party code). |
| 68 | run( |
| 69 | "lcov %s -rc lcov_branch_coverage=1 -r coverage.info " |
| 70 | "'*/trusted-firmware-m/platform/*' '*/trusted-firmware-m/lib/ext/*' " |
| 71 | "'*/tf-m-tests/*' '*/mbedtls/*' '*/mcuboot/*' '*/psa-arch-tests/*' " |
| 72 | "'*/QCBOR/*' -o coverage.info.tmp" % os.getenv("LCOV_FLAGS", ""), |
| 73 | cwd=job_dir |
| 74 | ) |
Paul Sokolovsky | 9b881e1 | 2022-07-12 15:34:05 +0300 | [diff] [blame] | 75 | run("mv coverage.info.tmp coverage.info", cwd=job_dir) |
Paul Sokolovsky | 55dffeb | 2022-04-30 10:58:03 +0300 | [diff] [blame] | 76 | run("genhtml --branch-coverage coverage.info --output-directory trace_report | grep -v -E '^Processing file '", cwd=job_dir) |