{
int i;
+ /* For children, we don't care if they "failed" the testing. */
+ if (control_fd != -1)
+ status = 0;
+
if (forced_cleanup)
history_num--;
/* Cleanup everything, in reverse order. */
- for (i = history_num - 1; i >= 0; i--)
- if (history[i].cleanup)
- history[i].cleanup(&history[i].u);
+ for (i = history_num - 1; i >= 0; i--) {
+ if (!history[i].cleanup)
+ continue;
+ if (!forced_cleanup) {
+ printf("Leak at %s:%u\n",
+ history[i].file, history[i].line);
+ status = 1;
+ }
+ history[i].cleanup(&history[i].u);
+ }
free_everything();
-
- if (control_fd == -1)
- exit(status);
-
tell_parent(SUCCESS);
- exit(0);
+ exit(status);
}
static bool should_fail(struct failtest_call *call)
/* Include the C files directly. */
#include <ccan/failtest/failtest.c>
-int main(void)
+int main(int argc, char *argv[])
{
int fd;
char *p;
char buf[] = "Hello world!";
plan_tests(5);
+ failtest_init(argc, argv);
- fd = failtest_open("run-write-scratchpad", "run-write.c", 1,
+ fd = failtest_open("run-write-scratchpad", __FILE__, __LINE__,
O_RDWR|O_CREAT, 0600);
/* Child will fail, ignore. */
if (fd < 0)
write(fd, buf, strlen(buf));
ok1(lseek(fd, 0, SEEK_CUR) == strlen(buf));
- p = failtest_malloc(100, "run-write.c", 1);
+ p = failtest_malloc(100, __FILE__, __LINE__);
if (!p) {
/* We are the child. Do a heap of writes. */
unsigned int i;
for (i = 0; i < strlen(buf)+1; i++)
- if (failtest_write(fd, "x", 1, "run-write.c", 1) == 1)
+ if (failtest_write(fd, "x", 1, __FILE__, __LINE__)
+ == 1)
break;
+ failtest_close(fd, __FILE__, __LINE__);
failtest_exit(0);
}
lseek(fd, 0, SEEK_SET);
ok1(read(fd, buf, strlen(buf)) == strlen("Hello world!"));
ok1(strcmp(buf, "Hello world!") == 0);
+ failtest_close(fd, __FILE__, __LINE__);
return exit_status();
}