summaryrefslogtreecommitdiff
path: root/tests-clar
diff options
context:
space:
mode:
authorRussell Belfer <rb@github.com>2012-11-20 11:34:12 -0800
committerRussell Belfer <rb@github.com>2012-11-20 11:34:12 -0800
commitf0ebf82e1afe4736dc294c16431c15685294f0b6 (patch)
tree4e4c50f75e6b3838eda53217072057c4a3918e0a /tests-clar
parenta9069f6154d34c93d644a9eb4c2da55b01468982 (diff)
parentcf0dadcf6ed2cfe52e2df68165f6448b6f26dbbc (diff)
downloadlibgit2-f0ebf82e1afe4736dc294c16431c15685294f0b6.tar.gz
Merge pull request #1089 from edubart/fix_win32_lstat
Fix win32 lstat
Diffstat (limited to 'tests-clar')
-rw-r--r--tests-clar/core/stat.c36
1 files changed, 8 insertions, 28 deletions
diff --git a/tests-clar/core/stat.c b/tests-clar/core/stat.c
index cbfc66c32..2e4abfb79 100644
--- a/tests-clar/core/stat.c
+++ b/tests-clar/core/stat.c
@@ -15,13 +15,6 @@ void test_core_stat__cleanup(void)
git_futils_rmdir_r("root", NULL, GIT_RMDIR_REMOVE_FILES);
}
-#ifdef GIT_WIN32
-#define cl_assert_last_error(val) \
- do { werr = GetLastError(); cl_assert_equal_i((val), (int)werr); } while (0)
-#else
-#define cl_assert_last_error(val)
-#endif
-
#define cl_assert_error(val) \
do { err = errno; cl_assert_equal_i((val), err); } while (0)
@@ -29,66 +22,45 @@ void test_core_stat__0(void)
{
struct stat st;
int err;
-#ifdef GIT_WIN32
- DWORD werr;
-#endif
cl_assert_equal_i(0, p_lstat("root", &st));
cl_assert(S_ISDIR(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert_equal_i(0, p_lstat("root/", &st));
cl_assert(S_ISDIR(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert_equal_i(0, p_lstat("root/file", &st));
cl_assert(S_ISREG(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert_equal_i(0, p_lstat("root/d1", &st));
cl_assert(S_ISDIR(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert_equal_i(0, p_lstat("root/d1/", &st));
cl_assert(S_ISDIR(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert_equal_i(0, p_lstat("root/d1/file", &st));
cl_assert(S_ISREG(st.st_mode));
- cl_assert_last_error(0);
cl_assert_error(0);
cl_assert(p_lstat("root/missing", &st) < 0);
- cl_assert_last_error(ERROR_FILE_NOT_FOUND);
cl_assert_error(ENOENT);
cl_assert(p_lstat("root/missing/but/could/be/created", &st) < 0);
- cl_assert_last_error(ERROR_PATH_NOT_FOUND);
-#ifdef GIT_WIN32
- cl_assert_error(ENOTDIR);
-#else
cl_assert_error(ENOENT);
-#endif
cl_assert(p_lstat_posixly("root/missing/but/could/be/created", &st) < 0);
cl_assert_error(ENOENT);
cl_assert(p_lstat("root/d1/missing", &st) < 0);
- cl_assert_last_error(ERROR_FILE_NOT_FOUND);
cl_assert_error(ENOENT);
cl_assert(p_lstat("root/d1/missing/deeper/path", &st) < 0);
- cl_assert_last_error(ERROR_PATH_NOT_FOUND);
-#ifdef GIT_WIN32
- cl_assert_error(ENOTDIR);
-#else
cl_assert_error(ENOENT);
-#endif
cl_assert(p_lstat_posixly("root/d1/missing/deeper/path", &st) < 0);
cl_assert_error(ENOENT);
@@ -97,13 +69,21 @@ void test_core_stat__0(void)
cl_assert_error(ENOTDIR);
cl_assert(p_lstat("root/file/invalid", &st) < 0);
+#ifdef GIT_WIN32
+ cl_assert_error(ENOENT);
+#else
cl_assert_error(ENOTDIR);
+#endif
cl_assert(p_lstat_posixly("root/file/invalid", &st) < 0);
cl_assert_error(ENOTDIR);
cl_assert(p_lstat("root/file/invalid/deeper_path", &st) < 0);
+#ifdef GIT_WIN32
+ cl_assert_error(ENOENT);
+#else
cl_assert_error(ENOTDIR);
+#endif
cl_assert(p_lstat_posixly("root/file/invalid/deeper_path", &st) < 0);
cl_assert_error(ENOTDIR);