* [PATCH] tests(junit-xml): avoid invalid XML
@ 2020-03-23 12:44 Johannes Schindelin via GitGitGadget
2020-03-23 16:28 ` Junio C Hamano
0 siblings, 1 reply; 3+ messages in thread
From: Johannes Schindelin via GitGitGadget @ 2020-03-23 12:44 UTC (permalink / raw)
To: git; +Cc: Johannes Schindelin, Johannes Schindelin
From: Johannes Schindelin <johannes.schindelin@gmx.de>
When a test case is run in a subshell, we finalize the JUnit-style XML
when said subshell exits. But then we continue to write into that XML as
if nothing had happened.
This leads to Azure Pipelines' Publish Test Results task complaining:
Failed to read /home/vsts/work/1/s/t/out/TEST-t0000-basic.xml.
Error : Unexpected end tag. Line 110, position 5.
And indeed, the resulting XML is incorrect.
Let's "re-open" the XML in such a case, i.e. remove the previously added
closing tags.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
---
Fix Azure Pipelines for t0000
When running t0000 in our Azure Pipeline, the "Publish Test Results"
step complains about an invalid JUnit-style XML, and it is correct.
Let's fix that.
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-732%2Fdscho%2Fci-xml-error-v1
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-732/dscho/ci-xml-error-v1
Pull-Request: https://github.com/git/git/pull/732
t/test-lib.sh | 1 +
1 file changed, 1 insertion(+)
diff --git a/t/test-lib.sh b/t/test-lib.sh
index 0ea1e5a05ed..7f0c02c016b 100644
--- a/t/test-lib.sh
+++ b/t/test-lib.sh
@@ -1085,6 +1085,7 @@ finalize_junit_xml () {
junit_time=$(test-tool date getnanos $junit_suite_start)
sed -e "s/\(<testsuite.*\) time=\"[^\"]*\"/\1/" \
-e "s/<testsuite [^>]*/& time=\"$junit_time\"/" \
+ -e '/^ *<\/testsuite/d' \
<"$junit_xml_path" >"$junit_xml_path.new"
mv "$junit_xml_path.new" "$junit_xml_path"
base-commit: be8661a3286c67a5d4088f4226cbd7f8b76544b0
--
gitgitgadget
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] tests(junit-xml): avoid invalid XML
2020-03-23 12:44 [PATCH] tests(junit-xml): avoid invalid XML Johannes Schindelin via GitGitGadget
@ 2020-03-23 16:28 ` Junio C Hamano
2020-03-23 20:56 ` Johannes Schindelin
0 siblings, 1 reply; 3+ messages in thread
From: Junio C Hamano @ 2020-03-23 16:28 UTC (permalink / raw)
To: Johannes Schindelin via GitGitGadget; +Cc: git, Johannes Schindelin
"Johannes Schindelin via GitGitGadget" <gitgitgadget@gmail.com>
writes:
> From: Johannes Schindelin <johannes.schindelin@gmx.de>
>
> When a test case is run in a subshell, we finalize the JUnit-style XML
> when said subshell exits. But then we continue to write into that XML as
> if nothing had happened.
>
> This leads to Azure Pipelines' Publish Test Results task complaining:
>
> Failed to read /home/vsts/work/1/s/t/out/TEST-t0000-basic.xml.
> Error : Unexpected end tag. Line 110, position 5.
>
> And indeed, the resulting XML is incorrect.
>
> Let's "re-open" the XML in such a case, i.e. remove the previously added
> closing tags.
>
> Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
> ---
> Fix Azure Pipelines for t0000
>
> When running t0000 in our Azure Pipeline, the "Publish Test Results"
> step complains about an invalid JUnit-style XML, and it is correct.
> Let's fix that.
Hmph, I have a vague recollection that I've seen this one, looked at
the patch and even understood the issue. Did I then forget to apply
it back then? If so, apologies for failing to do so before the
release.
Will queue.
Thanks.
> Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-732%2Fdscho%2Fci-xml-error-v1
> Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-732/dscho/ci-xml-error-v1
> Pull-Request: https://github.com/git/git/pull/732
>
> t/test-lib.sh | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/t/test-lib.sh b/t/test-lib.sh
> index 0ea1e5a05ed..7f0c02c016b 100644
> --- a/t/test-lib.sh
> +++ b/t/test-lib.sh
> @@ -1085,6 +1085,7 @@ finalize_junit_xml () {
> junit_time=$(test-tool date getnanos $junit_suite_start)
> sed -e "s/\(<testsuite.*\) time=\"[^\"]*\"/\1/" \
> -e "s/<testsuite [^>]*/& time=\"$junit_time\"/" \
> + -e '/^ *<\/testsuite/d' \
> <"$junit_xml_path" >"$junit_xml_path.new"
> mv "$junit_xml_path.new" "$junit_xml_path"
>
>
> base-commit: be8661a3286c67a5d4088f4226cbd7f8b76544b0
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] tests(junit-xml): avoid invalid XML
2020-03-23 16:28 ` Junio C Hamano
@ 2020-03-23 20:56 ` Johannes Schindelin
0 siblings, 0 replies; 3+ messages in thread
From: Johannes Schindelin @ 2020-03-23 20:56 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Johannes Schindelin via GitGitGadget, git
Hi Junio,
On Mon, 23 Mar 2020, Junio C Hamano wrote:
> "Johannes Schindelin via GitGitGadget" <gitgitgadget@gmail.com>
> writes:
>
> > From: Johannes Schindelin <johannes.schindelin@gmx.de>
> >
> > When a test case is run in a subshell, we finalize the JUnit-style XML
> > when said subshell exits. But then we continue to write into that XML as
> > if nothing had happened.
> >
> > This leads to Azure Pipelines' Publish Test Results task complaining:
> >
> > Failed to read /home/vsts/work/1/s/t/out/TEST-t0000-basic.xml.
> > Error : Unexpected end tag. Line 110, position 5.
> >
> > And indeed, the resulting XML is incorrect.
> >
> > Let's "re-open" the XML in such a case, i.e. remove the previously added
> > closing tags.
> >
> > Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
> > ---
> > Fix Azure Pipelines for t0000
> >
> > When running t0000 in our Azure Pipeline, the "Publish Test Results"
> > step complains about an invalid JUnit-style XML, and it is correct.
> > Let's fix that.
>
> Hmph, I have a vague recollection that I've seen this one, looked at
> the patch and even understood the issue. Did I then forget to apply
> it back then? If so, apologies for failing to do so before the
> release.
I suspect that you think of 076ee3e8a2a6 (tests: fix --write-junit-xml
with subshells, 2020-02-12) which you indeed applied. This patch addresses
a different issue that I had not noticed until two weeks ago. I
purposefully held back on contributing it during the feature freeze phase.
> Will queue.
Thanks,
Dscho
>
> Thanks.
>
> > Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-732%2Fdscho%2Fci-xml-error-v1
> > Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-732/dscho/ci-xml-error-v1
> > Pull-Request: https://github.com/git/git/pull/732
> >
> > t/test-lib.sh | 1 +
> > 1 file changed, 1 insertion(+)
> >
> > diff --git a/t/test-lib.sh b/t/test-lib.sh
> > index 0ea1e5a05ed..7f0c02c016b 100644
> > --- a/t/test-lib.sh
> > +++ b/t/test-lib.sh
> > @@ -1085,6 +1085,7 @@ finalize_junit_xml () {
> > junit_time=$(test-tool date getnanos $junit_suite_start)
> > sed -e "s/\(<testsuite.*\) time=\"[^\"]*\"/\1/" \
> > -e "s/<testsuite [^>]*/& time=\"$junit_time\"/" \
> > + -e '/^ *<\/testsuite/d' \
> > <"$junit_xml_path" >"$junit_xml_path.new"
> > mv "$junit_xml_path.new" "$junit_xml_path"
> >
> >
> > base-commit: be8661a3286c67a5d4088f4226cbd7f8b76544b0
>
>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2020-03-23 20:56 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-03-23 12:44 [PATCH] tests(junit-xml): avoid invalid XML Johannes Schindelin via GitGitGadget
2020-03-23 16:28 ` Junio C Hamano
2020-03-23 20:56 ` Johannes Schindelin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).