yaffs Trying to find a bug in timothy quick tests.
[yaffs2.git] / direct / timothy_tests / quick_tests / test_yaffs_unlink_ENOENT.c
diff --git a/direct/timothy_tests/quick_tests/test_yaffs_unlink_ENOENT.c b/direct/timothy_tests/quick_tests/test_yaffs_unlink_ENOENT.c
new file mode 100644 (file)
index 0000000..50803e5
--- /dev/null
@@ -0,0 +1,50 @@
+/*
+ * YAFFS: Yet another FFS. A NAND-flash specific file system.
+ *
+ * Copyright (C) 2002-2010 Aleph One Ltd.
+ *   for Toby Churchill Ltd and Brightstar Engineering
+ *
+ * Created by Timothy Manning <timothy@yaffs.net>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#include "test_yaffs_unlink_EISDIR.h"
+
+/*EISDIR is caused by trying to unlink a directory */
+
+static int handle=0;
+int test_yaffs_unlink_ENOENT(void){
+       int output=0;
+       int error_code=0;
+       /*printf("path %s\n",path); */
+       handle=yaffs_unlink("/yaffs2/non_existant_file");
+       if (handle==-1){
+               error_code=yaffs_get_error();
+               //printf("ENOENT def %d, Error code %d\n", EISDIR,error_code);
+               if (abs(error_code)== ENOENT){
+                       return 1;
+               }
+               else {
+                       printf("different error than expected\n");
+                       return -1;
+               }
+       }
+       else if (output >=0){
+               printf("directory unlinked opened.(which is a bad thing)\n");
+               return -1;
+       }
+       /* the program should not get here but the compiler is complaining */
+       return -1;
+}
+int test_yaffs_unlink_ENOENT_clean(void){
+       if (handle >=0){
+               return yaffs_close(handle);
+       }
+       else {
+               return 1;       /* the file failed to open so there is no need to close it*/
+       }
+}
+