Re: [PATCH 3/3] selftests/nolibc: Add test for getcwd() and readlink()

From: Thomas Weißschuh

Date: Sat May 02 2026 - 09:44:12 EST


May 2, 2026 09:25:45 Daniel Palmer <daniel@xxxxxxxxx>:

> Add a test for getcwd() that uses readlink() so tests that
> at the same time.
>
> This is very basic, just getting what should be the same
> string via getcwd() and readlink() and then checking they
> are the same.
>
> Signed-off-by: Daniel Palmer <daniel@xxxxxxxxx>
> ---
> tools/testing/selftests/nolibc/nolibc-test.c | 26 ++++++++++++++++++++
> 1 file changed, 26 insertions(+)
>
> diff --git a/tools/testing/selftests/nolibc/nolibc-test.c b/tools/testing/selftests/nolibc/nolibc-test.c
> index 08610cacf030..54513fb9a16a 100644
> --- a/tools/testing/selftests/nolibc/nolibc-test.c
> +++ b/tools/testing/selftests/nolibc/nolibc-test.c
> @@ -849,6 +849,31 @@ static int test_dirent(void)
>     return 0;
> }
>
> +static int test_getcwd(void)
> +{
> +   char cwd_syscall[1024];
> +   char cwd_proc[1024];
> +   ssize_t len;
> +
> +   /* Read where the link /proc/self/cwd points */
> +   len = readlink("/proc/self/cwd", cwd_proc, sizeof(cwd_proc) - 1);
> +   if (len <= 0)
> +       return -1;
> +
> +   /* Terminate the string from readlink() */
> +   cwd_proc[len] = '\0';
> +
> +   /* Get the cwd via syscall */
> +   if (getcwd(cwd_syscall, sizeof(cwd_syscall)) == NULL)
> +       return -1;
> +
> +   /* Fail if they aren't the same */
> +   if (strcmp(cwd_proc, cwd_syscall) != 0)
> +       return -1;
> +
> +   return 0;
> +}
> +
> int test_getrandom(void)
> {
>     uint64_t rng = 0;
> @@ -1477,6 +1502,7 @@ int run_syscall(int min, int max)
>         CASE_TEST(clock_getres);      EXPECT_SYSZR(1, clock_getres(CLOCK_MONOTONIC, &ts)); break;
>         CASE_TEST(clock_gettime);     EXPECT_SYSZR(1, clock_gettime(CLOCK_MONOTONIC, &ts)); break;
>         CASE_TEST(clock_settime);     EXPECT_SYSER(1, clock_settime(CLOCK_MONOTONIC, &ts), -1, EINVAL); break;
> +       CASE_TEST(getcwd);            EXPECT_SYSZR(1, test_getcwd()); break;

EXPECT_SYSZR(proc, ...)

>         CASE_TEST(getpid);            EXPECT_SYSNE(1, getpid(), -1); break;
>         CASE_TEST(getppid);           EXPECT_SYSNE(1, getppid(), -1); break;
>         CASE_TEST(gettid);            EXPECT_SYSNE(has_gettid, gettid(), -1); break;
> --
> 2.53.0