Fix failing nss/tst-nss-files-hosts-long with local resolver
authorAurelien Jarno <aurelien@aurel32.net>
Thu, 2 Sep 2021 22:28:14 +0000 (00:28 +0200)
committerAurelien Jarno <aurelien@aurel32.net>
Tue, 7 Sep 2021 19:41:38 +0000 (21:41 +0200)
When a local resolver like unbound is listening on the IPv4 loopback
address 127.0.0.1, the nss/tst-nss-files-hosts-long test fails. This is
due to:
- the default resolver in the absence of resolv.conf being 127.0.0.1
- the default DNS NSS database configuration in the absence of
  nsswitch.conf being 'hosts: dns [!UNAVAIL=return] file'

This causes the requests for 'test4' and 'test6' to first be sent to the
local resolver, which responds with NXDOMAIN in the likely case those
records do no exist. In turn that causes the access to /etc/hosts to be
skipped, which is the purpose of that test.

Fix that by providing a simple nsswitch.conf file forcing access to
/etc/hosts for that test. I have tested that the only changed result in
the testsuite is that test.

nss/tst-nss-files-hosts-long.root/etc/nsswitch.conf [new file with mode: 0644]

diff --git a/nss/tst-nss-files-hosts-long.root/etc/nsswitch.conf b/nss/tst-nss-files-hosts-long.root/etc/nsswitch.conf
new file mode 100644 (file)
index 0000000..5b0c6a4
--- /dev/null
@@ -0,0 +1 @@
+hosts: files