From 614ad86a5bb5d2acbf195d175e1e7c7287c7d467 Mon Sep 17 00:00:00 2001 From: Ophestra Date: Thu, 26 Dec 2024 15:29:26 +0900 Subject: [PATCH] dbus: fail on LookPath error An absolute path to xdg-dbus-proxy is required. Signed-off-by: Ophestra --- dbus/dbus_test.go | 12 +++++++++++- dbus/run.go | 6 ++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/dbus/dbus_test.go b/dbus/dbus_test.go index 8e267c7..717ded7 100644 --- a/dbus/dbus_test.go +++ b/dbus/dbus_test.go @@ -124,6 +124,8 @@ func testProxyStartWaitCloseString(t *testing.T, sandbox bool) { t.Run("proxy for "+id, func(t *testing.T) { helper.InternalReplaceExecCommand(t) + overridePath(t) + p := dbus.New(tc[0].bus, tc[1].bus) output := new(strings.Builder) @@ -174,7 +176,7 @@ func testProxyStartWaitCloseString(t *testing.T, sandbox bool) { t.Run("sealed start of "+id, func(t *testing.T) { if err := p.Start(nil, output, sandbox); err != nil { - t.Errorf("Start(nil, nil) error = %v", + t.Fatalf("Start(nil, nil) error = %v", err) } @@ -213,3 +215,11 @@ func testProxyStartWaitCloseString(t *testing.T, sandbox bool) { }) } } + +func overridePath(t *testing.T) { + proxyName := dbus.ProxyName + dbus.ProxyName = "/nonexistent-xdg-dbus-proxy" + t.Cleanup(func() { + dbus.ProxyName = proxyName + }) +} diff --git a/dbus/run.go b/dbus/run.go index bea820e..f648f00 100644 --- a/dbus/run.go +++ b/dbus/run.go @@ -46,14 +46,16 @@ func (p *Proxy) Start(ready chan error, output io.Writer, sandbox bool) error { // look up absolute path if name is just a file name toolPath := p.name if filepath.Base(p.name) == p.name { - if s, err := exec.LookPath(p.name); err == nil { + if s, err := exec.LookPath(p.name); err != nil { + return err + } else { toolPath = s } } // resolve libraries by parsing ldd output var proxyDeps []*ldd.Entry - if path.IsAbs(toolPath) { + if toolPath != "/nonexistent-xdg-dbus-proxy" { if l, err := ldd.Exec(toolPath); err != nil { return err } else {