forked from security/hakurei
The sandbox which ldd(1) runs in does not inherit parent work directory, so relative pathnames will not work correctly. While it is trivial to support such a use case, the use of relative pathnames is highly error-prone and generally frowned against in this project. The Exec function remains available under the same signature until v0.4.0 where it will be removed. Signed-off-by: Ophestra <cat@gensokyo.uk>
47 lines
1.1 KiB
Go
47 lines
1.1 KiB
Go
package ldd_test
|
|
|
|
import (
|
|
"errors"
|
|
"os"
|
|
"os/exec"
|
|
"testing"
|
|
|
|
"hakurei.app/container"
|
|
"hakurei.app/container/check"
|
|
"hakurei.app/ldd"
|
|
"hakurei.app/message"
|
|
)
|
|
|
|
func TestExec(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("failure", func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
_, err := ldd.Resolve(t.Context(), nil, check.MustAbs("/proc/nonexistent"))
|
|
|
|
var exitError *exec.ExitError
|
|
if !errors.As(err, &exitError) {
|
|
t.Fatalf("Exec: error has incorrect concrete type: %#v", err)
|
|
}
|
|
|
|
const want = 1
|
|
if got := exitError.ExitCode(); got != want {
|
|
t.Fatalf("Exec: ExitCode = %d, want %d", got, want)
|
|
}
|
|
})
|
|
|
|
t.Run("success", func(t *testing.T) {
|
|
msg := message.New(nil)
|
|
msg.GetLogger().SetPrefix("check: ")
|
|
if entries, err := ldd.Resolve(t.Context(), nil, check.MustAbs(container.MustExecutable(msg))); err != nil {
|
|
t.Fatalf("Exec: error = %v", err)
|
|
} else if testing.Verbose() {
|
|
// result cannot be measured here as build information is not known
|
|
t.Logf("Exec: %q", entries)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestMain(m *testing.M) { container.TryArgv0(nil); os.Exit(m.Run()) }
|