From: "Ævar Arnfjörð Bjarmason" <avarab@gmail.com>
To: Junio C Hamano <gitster@pobox.com>
Cc: Elia Pinto <gitter.spiros@gmail.com>, git@vger.kernel.org
Subject: Re: [PATCH v2 1/1] Makefile: add a prerequisite to the coverage-report target
Date: Mon, 11 Apr 2022 23:27:42 +0200 [thread overview]
Message-ID: <220411.86fsmji970.gmgdl@evledraar.gmail.com> (raw)
In-Reply-To: <xmqqv8vfiidm.fsf@gitster.g>
On Mon, Apr 11 2022, Junio C Hamano wrote:
> Elia Pinto <gitter.spiros@gmail.com> writes:
>
>> Directly invoking make coverage-report as a target results in an error because
>> its prerequisites are missing,
>>
>> This patch adds the compile-test prerequisite, which is run only once each time
>> the compile-report target is invoked. In practice, the developer may decide to
>> review the coverage-report results without necessarily rerunning for this
>> coverage-test, if it has already been run.
>>
>> Signed-off-by: Elia Pinto <gitter.spiros@gmail.com>
>> ---
>> This is the second version of the patch.
>>
>> With respect to the first version, we tried to eliminate the inefficient
>> coverage-test invocation if the target is coverage-report, introducing a more
>> useful invocation order
>
> Thanks.
>
> I do not see why you want to make the name of coverage-test.file
> customizable. In our makefiles, it seems that these "stamp" files
> are named with the ".made" suffix
>
> $ git grep -e '\.made'
>
> so using hardcoded "coverage-test.made" (with something that removes
> *.made when "make clean" is run) may make it in line with the rest
> of the build procedure.
>
> Ævar, I had an impression that you had many Makefile patches either
> unsubmitted or work-in-progress in the dependency-tightening area,
> and am wondering if you find the dependencies (or the lack thereof)
> for coverage-report target annoying. Any good ideas?
I haven't come up with a patch for these coverage targets, but I think
it would be much more useful to:
* Not have the target itself compile git, i.e. work like SANITIZE=leak,
there's no reason you shouldn't be able to e.g. combine the two
easily, it's just a complimentary set of flags.
* We should be able to run this in parallel, see
e.g. https://stackoverflow.com/questions/14643589/code-coverage-using-gcov-on-parallel-run
for a trick for how to do that on gcc 9+, on older gcc GCOV_PREFIX*
can be used.
I.e. we'd save these in t/test-results/t0001.coverage or whatever,
and then "join" them at the end.
I wonder if the issue this patch is trying to address would then just go
away, i.e. isn't it OK that we'd re-run the tests to get the report
then? gcov doesn't add that much runtime overhead.
next prev parent reply other threads:[~2022-04-11 21:47 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-04-09 4:30 [PATCH v2 1/1] Makefile: add a prerequisite to the coverage-report target Elia Pinto
2022-04-11 18:29 ` Junio C Hamano
2022-04-11 21:27 ` Ævar Arnfjörð Bjarmason [this message]
2022-04-11 22:59 ` Junio C Hamano
2022-04-12 7:51 ` Ævar Arnfjörð Bjarmason
2022-04-12 16:02 ` Junio C Hamano
-- strict thread matches above, loose matches on Subject: below --
2022-04-08 20:10 [PATCH] " Junio C Hamano
2022-04-09 3:51 ` [PATCH v2 1/1] " Elia Pinto
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=220411.86fsmji970.gmgdl@evledraar.gmail.com \
--to=avarab@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=gitter.spiros@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.