[LTP] [PATCH v2] link/link02: Convert to new API
tangmeng
tangmeng@uniontech.com
Tue Oct 26 05:42:41 CEST 2021
Signed-off-by: tangmeng <tangmeng@uniontech.com>
---
testcases/kernel/syscalls/link/link02.c | 81 +++++++------------------
1 file changed, 23 insertions(+), 58 deletions(-)
diff --git a/testcases/kernel/syscalls/link/link02.c b/testcases/kernel/syscalls/link/link02.c
index 6ac340c72..c074d71b0 100644
--- a/testcases/kernel/syscalls/link/link02.c
+++ b/testcases/kernel/syscalls/link/link02.c
@@ -34,23 +34,14 @@
*/
/*
- * Tests that link(2) succeds.
+ * [Description]
+ *
+ * Tests that link(2) succeeds.
*/
-#include <sys/types.h>
-#include <fcntl.h>
+#include <unistd.h>
#include <sys/stat.h>
-#include <errno.h>
-#include <string.h>
-#include <signal.h>
-#include "test.h"
-#include "safe_macros.h"
-
-static void setup(void);
-static void cleanup(void);
-
-char *TCID = "link02";
-int TST_TOTAL = 1;
+#include "tst_test.h"
#define OLDPATH "oldpath"
#define NEWPATH "newpath"
@@ -59,57 +50,31 @@ static void verify_link(void)
{
struct stat fbuf, lbuf;
- TEST(link(OLDPATH, NEWPATH));
-
- if (TEST_RETURN == 0) {
- SAFE_STAT(cleanup, OLDPATH, &fbuf);
- SAFE_STAT(cleanup, NEWPATH, &lbuf);
- if (fbuf.st_nlink > 1 && lbuf.st_nlink > 1 &&
- fbuf.st_nlink == lbuf.st_nlink) {
- tst_resm(TPASS, "link("OLDPATH","NEWPATH") "
- "returned 0 and link counts match");
- } else {
- tst_resm(TFAIL, "link("OLDPATH","NEWPATH") returned 0"
- " but stat lin count do not match %d %d",
- (int)fbuf.st_nlink, (int)lbuf.st_nlink);
- }
- SAFE_UNLINK(cleanup, NEWPATH);
- } else {
- tst_resm(TFAIL | TTERRNO,
- "link("OLDPATH","NEWPATH") returned %ld",
- TEST_RETURN);
- }
-}
-
-int main(int ac, char **av)
-{
- int lc;
+ TST_EXP_PASS(link(OLDPATH, NEWPATH));
- tst_parse_opts(ac, av, NULL, NULL);
+ if (!TST_PASS)
+ return;
- setup();
+ SAFE_STAT(OLDPATH, &fbuf);
+ SAFE_STAT(NEWPATH, &lbuf);
- for (lc = 0; TEST_LOOPING(lc); lc++) {
- tst_count = 0;
- verify_link();
+ if (fbuf.st_nlink > 1 && fbuf.st_nlink == lbuf.st_nlink) {
+ tst_res(TPASS, "link("OLDPATH","NEWPATH") "
+ "returned 0 and stat link counts match");
+ } else {
+ tst_res(TFAIL, "link("OLDPATH","NEWPATH") returned 0"
+ " but stat link counts do not match %d %d",
+ (int)fbuf.st_nlink, (int)lbuf.st_nlink);
}
-
- cleanup();
- tst_exit();
}
static void setup(void)
{
- tst_sig(NOFORK, DEF_HANDLER, cleanup);
-
- TEST_PAUSE;
-
- tst_tmpdir();
-
- SAFE_TOUCH(cleanup, OLDPATH, 0700, NULL);
+ SAFE_TOUCH(OLDPATH, 0700, NULL);
}
-static void cleanup(void)
-{
- tst_rmdir();
-}
+static struct tst_test test = {
+ .test_all = verify_link,
+ .setup = setup,
+ .needs_tmpdir = 1,
+};
--
2.20.1
More information about the ltp
mailing list