diff mbox series

[v1] Add link01 test

Message ID 20240119090713.13753-1-andrea.cervesato@suse.de
State Rejected
Headers show
Series [v1] Add link01 test | expand

Commit Message

Andrea Cervesato Jan. 19, 2024, 9:07 a.m. UTC
From: Andrea Cervesato <andrea.cervesato@suse.com>

This test verifies that link() is working correctly on symlink()
generated files, renaming the symbolic link and checking that
stat() information are preserved.

Signed-off-by: Andrea Cervesato <andrea.cervesato@suse.com>
---
 runtest/syscalls                        |  2 +-
 testcases/kernel/syscalls/link/link01.c | 47 +++++++++++++++++++++++++
 2 files changed, 48 insertions(+), 1 deletion(-)
 create mode 100644 testcases/kernel/syscalls/link/link01.c

Comments

Andrea Cervesato Feb. 20, 2024, 12:53 p.m. UTC | #1
Hi!
please ignore this patch since the test case is covered by link02 already.

Andrea

On 1/19/24 10:07, Andrea Cervesato wrote:
> From: Andrea Cervesato <andrea.cervesato@suse.com>
>
> This test verifies that link() is working correctly on symlink()
> generated files, renaming the symbolic link and checking that
> stat() information are preserved.
>
> Signed-off-by: Andrea Cervesato <andrea.cervesato@suse.com>
> ---
>   runtest/syscalls                        |  2 +-
>   testcases/kernel/syscalls/link/link01.c | 47 +++++++++++++++++++++++++
>   2 files changed, 48 insertions(+), 1 deletion(-)
>   create mode 100644 testcases/kernel/syscalls/link/link01.c
>
> diff --git a/runtest/syscalls b/runtest/syscalls
> index 68460de0b..00a0dd87e 100644
> --- a/runtest/syscalls
> +++ b/runtest/syscalls
> @@ -692,7 +692,7 @@ lchown03_16 lchown03_16
>   lgetxattr01 lgetxattr01
>   lgetxattr02 lgetxattr02
>   
> -link01 symlink01 -T link01
> +link01 link01
>   link02 link02
>   link04 link04
>   link05 link05
> diff --git a/testcases/kernel/syscalls/link/link01.c b/testcases/kernel/syscalls/link/link01.c
> new file mode 100644
> index 000000000..e1cda7054
> --- /dev/null
> +++ b/testcases/kernel/syscalls/link/link01.c
> @@ -0,0 +1,47 @@
> +// SPDX-License-Identifier: GPL-2.0-or-later
> +/*
> + * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
> + *    Author: David Fenner
> + *    Copilot: Jon Hendrickson
> + * Copyright (C) 2024 Andrea Cervesato andrea.cervesato@suse.com
> + */
> +
> +/*\
> + * [Description]
> + *
> + * This test verifies that link() is working correctly on symlink()
> + * generated files, renaming the symbolic link and checking that
> + * stat() information are preserved.
> + */
> +
> +#include "tst_test.h"
> +
> +static void run(void)
> +{
> +	struct stat oldlink_stat;
> +	struct stat newlink_stat;
> +	char *symname0 = "my_symlink0";
> +	char *symname1 = "my_symlink1";
> +
> +	SAFE_SYMLINK(tst_get_tmpdir(), symname0);
> +	SAFE_STAT(symname0, &oldlink_stat);
> +
> +	SAFE_LINK(symname0, symname1);
> +	SAFE_STAT(symname1, &newlink_stat);
> +
> +	TST_EXP_EQ_LI(oldlink_stat.st_ino, newlink_stat.st_ino);
> +	TST_EXP_EQ_LI(oldlink_stat.st_nlink, newlink_stat.st_nlink);
> +
> +	if (TST_RET == -1) {
> +		SAFE_UNLINK(symname0);
> +		remove(symname1);
> +	} else {
> +		SAFE_UNLINK(symname1);
> +		remove(symname0);
> +	}
> +}
> +
> +static struct tst_test test = {
> +	.test_all = run,
> +	.needs_tmpdir = 1,
> +};
diff mbox series

Patch

diff --git a/runtest/syscalls b/runtest/syscalls
index 68460de0b..00a0dd87e 100644
--- a/runtest/syscalls
+++ b/runtest/syscalls
@@ -692,7 +692,7 @@  lchown03_16 lchown03_16
 lgetxattr01 lgetxattr01
 lgetxattr02 lgetxattr02
 
-link01 symlink01 -T link01
+link01 link01
 link02 link02
 link04 link04
 link05 link05
diff --git a/testcases/kernel/syscalls/link/link01.c b/testcases/kernel/syscalls/link/link01.c
new file mode 100644
index 000000000..e1cda7054
--- /dev/null
+++ b/testcases/kernel/syscalls/link/link01.c
@@ -0,0 +1,47 @@ 
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * Copyright (c) 2000 Silicon Graphics, Inc.  All Rights Reserved.
+ *    Author: David Fenner
+ *    Copilot: Jon Hendrickson
+ * Copyright (C) 2024 Andrea Cervesato andrea.cervesato@suse.com
+ */
+
+/*\
+ * [Description]
+ *
+ * This test verifies that link() is working correctly on symlink()
+ * generated files, renaming the symbolic link and checking that
+ * stat() information are preserved.
+ */
+
+#include "tst_test.h"
+
+static void run(void)
+{
+	struct stat oldlink_stat;
+	struct stat newlink_stat;
+	char *symname0 = "my_symlink0";
+	char *symname1 = "my_symlink1";
+
+	SAFE_SYMLINK(tst_get_tmpdir(), symname0);
+	SAFE_STAT(symname0, &oldlink_stat);
+
+	SAFE_LINK(symname0, symname1);
+	SAFE_STAT(symname1, &newlink_stat);
+
+	TST_EXP_EQ_LI(oldlink_stat.st_ino, newlink_stat.st_ino);
+	TST_EXP_EQ_LI(oldlink_stat.st_nlink, newlink_stat.st_nlink);
+
+	if (TST_RET == -1) {
+		SAFE_UNLINK(symname0);
+		remove(symname1);
+	} else {
+		SAFE_UNLINK(symname1);
+		remove(symname0);
+	}
+}
+
+static struct tst_test test = {
+	.test_all = run,
+	.needs_tmpdir = 1,
+};