diff mbox series

t/lib-httpd: pass LANG to Apache

Message ID 3b370f7b-df84-0629-d334-aa9dfbca1c05@web.de (mailing list archive)
State New, archived
Headers show
Series t/lib-httpd: pass LANG to Apache | expand

Commit Message

René Scharfe Oct. 4, 2022, 5:42 p.m. UTC
t5411 starts a web server with no explicit language setting, so it uses
the system default.  Ten of its tests expect it to return error messages
containing the prefix "fatal: ", emitted by die().  This prefix can be
localized since a1fd2cf8cd (i18n: mark message helpers prefix for
translation, 2022-06-21), however.  As a result these ten tests break
for me on a system with LANG="de_DE.UTF-8" because the web server sends
localized messages with "Schwerwiegend: " instead of "fatal: ".

Fix these tests by passing LANG to the web server, which is set to "C"
by t/test-lib.sh, to get untranslated messages on both sides.

Signed-off-by: René Scharfe <l.s.r@web.de>
---
 t/lib-httpd/apache.conf | 1 +
 1 file changed, 1 insertion(+)

--
2.37.3

Comments

Junio C Hamano Oct. 5, 2022, 7:50 p.m. UTC | #1
René Scharfe <l.s.r@web.de> writes:

> t5411 starts a web server with no explicit language setting, so it uses
> the system default.  Ten of its tests expect it to return error messages
> containing the prefix "fatal: ", emitted by die().  This prefix can be
> localized since a1fd2cf8cd (i18n: mark message helpers prefix for
> translation, 2022-06-21), however.  As a result these ten tests break
> for me on a system with LANG="de_DE.UTF-8" because the web server sends
> localized messages with "Schwerwiegend: " instead of "fatal: ".
>
> Fix these tests by passing LANG to the web server, which is set to "C"
> by t/test-lib.sh, to get untranslated messages on both sides.

It is a good thing to do, but we seem to be extra conservative and
set both LC_ALL=C LANG=C (presumably by following the habit acquired
back when locale support were being introduced to various systems
with different degree, which way predates Git itself) and export
them in the main part of the test framework.

Shouldn't we be doing the same here?

> Signed-off-by: René Scharfe <l.s.r@web.de>
> ---
>  t/lib-httpd/apache.conf | 1 +
>  1 file changed, 1 insertion(+)
>
> diff --git a/t/lib-httpd/apache.conf b/t/lib-httpd/apache.conf
> index 497b9b9d92..1e2295a7cb 100644
> --- a/t/lib-httpd/apache.conf
> +++ b/t/lib-httpd/apache.conf
> @@ -80,6 +80,7 @@ PassEnv LSAN_OPTIONS
>  PassEnv GIT_TRACE
>  PassEnv GIT_CONFIG_NOSYSTEM
>  PassEnv GIT_TEST_SIDEBAND_ALL
> +PassEnv LANG
>
>  Alias /dumb/ www/
>  Alias /auth/dumb/ www/auth/dumb/
> --
> 2.37.3
Jeff King Oct. 5, 2022, 9:20 p.m. UTC | #2
On Wed, Oct 05, 2022 at 12:50:53PM -0700, Junio C Hamano wrote:

> René Scharfe <l.s.r@web.de> writes:
> 
> > t5411 starts a web server with no explicit language setting, so it uses
> > the system default.  Ten of its tests expect it to return error messages
> > containing the prefix "fatal: ", emitted by die().  This prefix can be
> > localized since a1fd2cf8cd (i18n: mark message helpers prefix for
> > translation, 2022-06-21), however.  As a result these ten tests break
> > for me on a system with LANG="de_DE.UTF-8" because the web server sends
> > localized messages with "Schwerwiegend: " instead of "fatal: ".
> >
> > Fix these tests by passing LANG to the web server, which is set to "C"
> > by t/test-lib.sh, to get untranslated messages on both sides.
> 
> It is a good thing to do, but we seem to be extra conservative and
> set both LC_ALL=C LANG=C (presumably by following the habit acquired
> back when locale support were being introduced to various systems
> with different degree, which way predates Git itself) and export
> them in the main part of the test framework.
> 
> Shouldn't we be doing the same here?

I think setting both probably is overkill. But if we are going to set
one, the important one is LC_ALL. It overrides specific LC_* variables,
which in turn override LANG. So just setting LANG would get confused if
LC_MESSAGES were set, for example.

That said, there probably is no downside to passing through both, so we
might as well do so.

Other than that, the patch is obviously the right thing to be doing. I'm
surprised it took this long for it to be a problem. ;)

-Peff
Junio C Hamano Oct. 6, 2022, 4:20 p.m. UTC | #3
Jeff King <peff@peff.net> writes:

>> Shouldn't we be doing the same here?
>
> I think setting both probably is overkill. But if we are going to set
> one, the important one is LC_ALL. It overrides specific LC_* variables,
> which in turn override LANG. So just setting LANG would get confused if
> LC_MESSAGES were set, for example.
>
> That said, there probably is no downside to passing through both, so we
> might as well do so.

Yup.  I suspect that the habit dates back to before LC_* was widespread
and some platforms needed LANG.  On modern systems that understand i18n
and do not need to set NO_GETTEXT, forcing LC_ALL should be sufficient.

> Other than that, the patch is obviously the right thing to be doing. I'm
> surprised it took this long for it to be a problem. ;)

Thanks.
diff mbox series

Patch

diff --git a/t/lib-httpd/apache.conf b/t/lib-httpd/apache.conf
index 497b9b9d92..1e2295a7cb 100644
--- a/t/lib-httpd/apache.conf
+++ b/t/lib-httpd/apache.conf
@@ -80,6 +80,7 @@  PassEnv LSAN_OPTIONS
 PassEnv GIT_TRACE
 PassEnv GIT_CONFIG_NOSYSTEM
 PassEnv GIT_TEST_SIDEBAND_ALL
+PassEnv LANG

 Alias /dumb/ www/
 Alias /auth/dumb/ www/auth/dumb/