#endif
 
 
+static const char *basepath;
+static const char *basepath_r;
 static char testfile[1024];
 static char testfile2[1024];
 static char testdir[1024];
 static char zerodata[4096];
 static int testdatalen = sizeof(testdata) - 1;
 static int testdata2len = sizeof(testdata2) - 1;
-static unsigned int testnum = 1;
+static unsigned int testnum = 0;
 static unsigned int select_test = 0;
 static unsigned int skip_test = 0;
 
 {
        unsigned int n;
        va_list ap;
-       n = sprintf(testname, "%3i [", testnum++);
+       n = sprintf(testname, "%3i [", testnum);
        va_start(ap, fmt);
        n += vsprintf(testname + n, fmt, ap);
        va_end(ap);
        sprintf(testname + n, "]");
+       // Use dedicated testfile per test
+       sprintf(testfile, "%s/testfile.%d", basepath, testnum);
+       sprintf(testfile_r, "%s/testfile.%d", basepath_r, testnum);
 }
 
 #define start_test(msg, args...) { \
+       testnum++; \
        if ((select_test && testnum != select_test) || \
            (testnum == skip_test)) { \
-               testnum++; \
                return 0; \
        } \
        __start_test(msg, ##args);              \
                }
                close(fd);
        }
+
+       res = unlink(testfile);
+       if (res == -1) {
+               PERROR("unlink");
+               return -1;
+       }
+       res = check_nonexist(testfile);
+       if (res == -1)
+               return -1;
+       res = check_nonexist(testfile_r);
+       if (res == -1)
+               return -1;
+
        success();
        return 0;
 }
        if (err)
                return -1;
 
+       res = unlink(testfile);
+       if (res == -1) {
+               PERROR("unlink");
+               return -1;
+       }
+       res = check_nonexist(testfile);
+       if (res == -1)
+               return -1;
+
        success();
        return 0;
 }
 
 int main(int argc, char *argv[])
 {
-       const char *basepath;
-       const char *realpath;
        int err = 0;
        int a;
        int is_root;
                return 1;
        }
        basepath = argv[1];
-       realpath = basepath;
+       basepath_r = basepath;
        for (a = 2; a < argc; a++) {
                char *endptr;
                char *arg = argv[a];
                if (arg[0] == ':') {
-                       realpath = arg + 1;
+                       basepath_r = arg + 1;
                } else {
                        if (arg[0] == '-') {
                                arg++;
                }
        }
        assert(strlen(basepath) < 512);
-       assert(strlen(realpath) < 512);
+       assert(strlen(basepath_r) < 512);
        if (basepath[0] != '/') {
                fprintf(stderr, "testdir must be an absolute path\n");
                return 1;
        sprintf(subfile, "%s/subfile", testdir2);
        sprintf(testsock, "%s/testsock", basepath);
 
-       sprintf(testfile_r, "%s/testfile", realpath);
-       sprintf(testfile2_r, "%s/testfile2", realpath);
-       sprintf(testdir_r, "%s/testdir", realpath);
-       sprintf(testdir2_r, "%s/testdir2", realpath);
+       sprintf(testfile_r, "%s/testfile", basepath_r);
+       sprintf(testfile2_r, "%s/testfile2", basepath_r);
+       sprintf(testdir_r, "%s/testdir", basepath_r);
+       sprintf(testdir2_r, "%s/testdir2", basepath_r);
        sprintf(subfile_r, "%s/subfile", testdir2_r);
 
        is_root = (geteuid() == 0);
        err += test_create_ro_dir(O_CREAT | O_TRUNC);
        err += test_copy_file_range();
 
-       unlink(testfile);
        unlink(testfile2);
        unlink(testsock);
        rmdir(testdir);