All of lore.kernel.org
 help / color / mirror / Atom feed
* [scarthgap][PATCH] oeqa/runtime/ping: don't bother trying to ping localhost
@ 2025-10-15 20:41 Michael Haener
  2025-10-30 21:14 ` [OE-core] " Denys Dmytriyenko
  0 siblings, 1 reply; 3+ messages in thread
From: Michael Haener @ 2025-10-15 20:41 UTC (permalink / raw)
  To: openembedded-core; +Cc: Michael Haener

If SLIRP is being used instead of TAP for networking to the guest then
the target IP will be localhost.  There's no point in pinging localhost
to see if the target is up but whilst you'd think it is harmless, in
some containers ping doesn't actually have enough rights to work:

  ping: socktype: SOCK_RAW
  ping: socket: Operation not permitted
  ping: => missing cap_net_raw+p capability or setuid?

Look at the target address and if it's localhost or 127.0.0.* return
immediately.

(Backport from OE-Core rev: a06ef43d2a50e16c32bd6edbdc7b32c3528687d5)

Signed-off-by: Michael Haener <michael.haener@siemens.com>
---
 meta/lib/oeqa/runtime/cases/ping.py | 7 +++++++
 test                                | 0
 2 files changed, 7 insertions(+)
 create mode 100644 test

diff --git a/meta/lib/oeqa/runtime/cases/ping.py b/meta/lib/oeqa/runtime/cases/ping.py
index f72460e7f3..bc543f6c41 100644
--- a/meta/lib/oeqa/runtime/cases/ping.py
+++ b/meta/lib/oeqa/runtime/cases/ping.py
@@ -18,6 +18,13 @@ class PingTest(OERuntimeTestCase):
         output = ''
         count = 0
         self.assertNotEqual(len(self.target.ip), 0, msg="No target IP address set")
+
+        # If the target IP is localhost (because user-space networking is being used),
+        # then there's no point in pinging it.
+        if self.target.ip.startswith("127.0.0.") or self.target.ip in ("localhost", "::1"):
+            print("runtime/ping: localhost detected, not pinging")
+            return
+
         try:
             while count < 5:
                 cmd = 'ping -c 1 %s' % self.target.ip
diff --git a/test b/test
new file mode 100644
index 0000000000..e69de29bb2
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [OE-core] [scarthgap][PATCH] oeqa/runtime/ping: don't bother trying to ping localhost
  2025-10-15 20:41 [scarthgap][PATCH] oeqa/runtime/ping: don't bother trying to ping localhost Michael Haener
@ 2025-10-30 21:14 ` Denys Dmytriyenko
  2025-10-30 21:46   ` Haener, Michael
  0 siblings, 1 reply; 3+ messages in thread
From: Denys Dmytriyenko @ 2025-10-30 21:14 UTC (permalink / raw)
  To: michael.haener; +Cc: openembedded-core

On Wed, Oct 15, 2025 at 10:41:31PM +0200, Michael Haener via lists.openembedded.org wrote:
> If SLIRP is being used instead of TAP for networking to the guest then
> the target IP will be localhost.  There's no point in pinging localhost
> to see if the target is up but whilst you'd think it is harmless, in
> some containers ping doesn't actually have enough rights to work:
> 
>   ping: socktype: SOCK_RAW
>   ping: socket: Operation not permitted
>   ping: => missing cap_net_raw+p capability or setuid?
> 
> Look at the target address and if it's localhost or 127.0.0.* return
> immediately.
> 
> (Backport from OE-Core rev: a06ef43d2a50e16c32bd6edbdc7b32c3528687d5)
> 
> Signed-off-by: Michael Haener <michael.haener@siemens.com>
> ---
>  meta/lib/oeqa/runtime/cases/ping.py | 7 +++++++
>  test                                | 0
>  2 files changed, 7 insertions(+)
>  create mode 100644 test
> 
> diff --git a/meta/lib/oeqa/runtime/cases/ping.py b/meta/lib/oeqa/runtime/cases/ping.py
> index f72460e7f3..bc543f6c41 100644
> --- a/meta/lib/oeqa/runtime/cases/ping.py
> +++ b/meta/lib/oeqa/runtime/cases/ping.py
> @@ -18,6 +18,13 @@ class PingTest(OERuntimeTestCase):
>          output = ''
>          count = 0
>          self.assertNotEqual(len(self.target.ip), 0, msg="No target IP address set")
> +
> +        # If the target IP is localhost (because user-space networking is being used),
> +        # then there's no point in pinging it.
> +        if self.target.ip.startswith("127.0.0.") or self.target.ip in ("localhost", "::1"):
> +            print("runtime/ping: localhost detected, not pinging")
> +            return
> +
>          try:
>              while count < 5:
>                  cmd = 'ping -c 1 %s' % self.target.ip
> diff --git a/test b/test
> new file mode 100644
> index 0000000000..e69de29bb2

Should there be an empty "test" file in the root directory of OE-Core?

-- 
Denys


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [OE-core] [scarthgap][PATCH] oeqa/runtime/ping: don't bother trying to ping localhost
  2025-10-30 21:14 ` [OE-core] " Denys Dmytriyenko
@ 2025-10-30 21:46   ` Haener, Michael
  0 siblings, 0 replies; 3+ messages in thread
From: Haener, Michael @ 2025-10-30 21:46 UTC (permalink / raw)
  To: denis@denix.org; +Cc: openembedded-core@lists.openembedded.org

On Thu, 2025-10-30 at 17:14 -0400, Denys Dmytriyenko wrote:
> [You don't often get email from denis@denix.org. Learn why this is
> important at https://aka.ms/LearnAboutSenderIdentification ]
> 
> On Wed, Oct 15, 2025 at 10:41:31PM +0200, Michael Haener via
> lists.openembedded.org wrote:
> > If SLIRP is being used instead of TAP for networking to the guest
> > then
> > the target IP will be localhost.  There's no point in pinging
> > localhost
> > to see if the target is up but whilst you'd think it is harmless,
> > in
> > some containers ping doesn't actually have enough rights to work:
> > 
> >   ping: socktype: SOCK_RAW
> >   ping: socket: Operation not permitted
> >   ping: => missing cap_net_raw+p capability or setuid?
> > 
> > Look at the target address and if it's localhost or 127.0.0.*
> > return
> > immediately.
> > 
> > (Backport from OE-Core rev:
> > a06ef43d2a50e16c32bd6edbdc7b32c3528687d5)
> > 
> > Signed-off-by: Michael Haener <michael.haener@siemens.com>
> > ---
> >  meta/lib/oeqa/runtime/cases/ping.py | 7 +++++++
> >  test                                | 0
> >  2 files changed, 7 insertions(+)
> >  create mode 100644 test
> > 
> > diff --git a/meta/lib/oeqa/runtime/cases/ping.py
> > b/meta/lib/oeqa/runtime/cases/ping.py
> > index f72460e7f3..bc543f6c41 100644
> > --- a/meta/lib/oeqa/runtime/cases/ping.py
> > +++ b/meta/lib/oeqa/runtime/cases/ping.py
> > @@ -18,6 +18,13 @@ class PingTest(OERuntimeTestCase):
> >          output = ''
> >          count = 0
> >          self.assertNotEqual(len(self.target.ip), 0, msg="No target
> > IP address set")
> > +
> > +        # If the target IP is localhost (because user-space
> > networking is being used),
> > +        # then there's no point in pinging it.
> > +        if self.target.ip.startswith("127.0.0.") or self.target.ip
> > in ("localhost", "::1"):
> > +            print("runtime/ping: localhost detected, not pinging")
> > +            return
> > +
> >          try:
> >              while count < 5:
> >                  cmd = 'ping -c 1 %s' % self.target.ip
> > diff --git a/test b/test
> > new file mode 100644
> > index 0000000000..e69de29bb2
> 
> Should there be an empty "test" file in the root directory of OE-
> Core?
> 
> --
> Denys

I still don't quite understand how this could have happened during
cherry-picking. This test file does not belong there and has no
functionality in the commit. Thank you for pointing this out.

Michael

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2025-10-30 21:46 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-10-15 20:41 [scarthgap][PATCH] oeqa/runtime/ping: don't bother trying to ping localhost Michael Haener
2025-10-30 21:14 ` [OE-core] " Denys Dmytriyenko
2025-10-30 21:46   ` Haener, Michael

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.