Skip to content

Commit

Permalink
[ci] run new coverage for line/toggle coverage
Browse files Browse the repository at this point in the history
Signed-off-by: Clo91eaf <[email protected]>
  • Loading branch information
Clo91eaf committed Jan 9, 2025
1 parent 3497df8 commit 07cb03a
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 6 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/t1rocket.yml
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,9 @@ jobs:
- name: "Build vcs emulator"
run: |
nix build '.#t1.${{ matrix.config }}.${{ env.EMU_TOP }}.vcs-emu' --impure --no-link
- name: "Build vcs emulator for running coverage"
run: |
nix build '.#t1.${{ matrix.config }}.${{ env.EMU_TOP }}.vcs-emu-cover-full' --impure --no-link
- name: "Build all testcases"
run: |
nix build ".#t1.${{ matrix.config }}.${{ env.EMU_TOP }}.cases._all" --max-jobs auto --no-link --cores 64
Expand Down
4 changes: 3 additions & 1 deletion nix/t1/run/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
, vcs-emu
, vcs-emu-rtlink
, vcs-emu-cover
, vcs-emu-cover-full
, vcs-emu-trace
, vcs-dpi-lib
, cases
Expand Down Expand Up @@ -40,6 +41,7 @@ let
verilator-emu-trace = runVerilatorEmu verilator-emu-trace case;
vcs-emu = runVCSEmu vcs-emu-rtlink case;
vcs-emu-cover = runVCSEmu vcs-emu-cover case;
vcs-emu-cover-full = runVCSEmu vcs-emu-cover-full case;
vcs-emu-trace = runVCSEmu vcs-emu-trace case;
vcs-prof-vcd = runFsdb2vcd (runVCSEmu vcs-emu-trace case);
};
Expand Down Expand Up @@ -92,7 +94,7 @@ let
in
runCommand "catch-${configName}-all-emu-result-for-ci" { } script;

_vcsEmuResult = runCommand "get-vcs-emu-result" { __noChroot = true; emuOutput = _getAllResult "vcs-emu-cover"; } ''
_vcsEmuResult = runCommand "get-vcs-emu-result" { __noChroot = true; emuOutput = _getAllResult "vcs-emu-cover-full"; } ''
cp -vr $emuOutput $out
chmod -R u+w $out
Expand Down
25 changes: 20 additions & 5 deletions script/ci/src/Main.scala
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@ object Main:
val testAttr = emuLib.toLowerCase() match
case "verilator" => s".#t1.$config.$top.run.$caseName.verilator-emu"
// TODO: should not be cover for every test case
case "vcs" => s".#t1.$config.$top.run.$caseName.vcs-emu-cover"
case "vcs" => s".#t1.$config.$top.run.$caseName.vcs-emu-cover-full"
case _ => Logger.fatal(s"Invalid test type ${emuLib}")
val testResultPath =
try
Expand Down Expand Up @@ -280,23 +280,38 @@ object Main:
Logger.info("Filtering urg report")
val finalMdPath = os.Path(urgReportFilePath.get, os.pwd)
val urgAssertFile = emuResultPath / "urgReport" / "asserts.txt"
val summaryHeading = "^Summary for Cover Properties$".r
val urgSummaryFile = emuResultPath / "urgReport" / "tests.txt"

val summaryHeading = "^Total Coverage Summary$".r
val summaryStr =
os.read(urgSummaryFile)
.lines()
.dropWhile(!summaryHeading.matches(_))
.takeWhile(!_.trim.isEmpty)
.toArray
.mkString("\n")

val coverSummaryHeading = "^Summary for Cover Properties$".r
val coverSummaryStr =
os.read(urgAssertFile)
.lines()
.dropWhile(!summaryHeading.matches(_))
.dropWhile(!coverSummaryHeading.matches(_))
.takeWhile(_.distinct != "-")
.toArray
.mkString("\n")
val detailHeading = "^Detail Report for Cover Properties$".r

val copverDetailHeading = "^Detail Report for Cover Properties$".r
val coverDetailStr =
os.read(urgAssertFile)
.lines()
.dropWhile(!detailHeading.matches(_))
.dropWhile(!copverDetailHeading.matches(_))
.toArray
.mkString("\n")

os.write.append(finalMdPath, s"### Coverage for $config \n")
os.write.append(finalMdPath, "```text\n")
os.write.append(finalMdPath, summaryStr)
os.write.append(finalMdPath, "----------------------\n")
os.write.append(finalMdPath, coverSummaryStr)
os.write.append(finalMdPath, "----------------------\n")
os.write.append(finalMdPath, coverDetailStr)
Expand Down

0 comments on commit 07cb03a

Please sign in to comment.