提交 9190c372 编写于 作者: A Andrea Bolognani

tests: Mock virFileCanonicalizePath()

We're going to need this later on.
Signed-off-by: NAndrea Bolognani <abologna@redhat.com>
Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
上级 026606ca
......@@ -43,6 +43,7 @@ static char *(*real_canonicalize_file_name)(const char *path);
static int (*real_open)(const char *path, int flags, ...);
static int (*real_close)(int fd);
static DIR * (*real_opendir)(const char *name);
static char *(*real_virFileCanonicalizePath)(const char *path);
/* Don't make static, since it causes problems with clang
* when passed as an arg to virAsprintf()
......@@ -814,6 +815,7 @@ init_syms(void)
VIR_MOCK_REAL_INIT(open);
VIR_MOCK_REAL_INIT(close);
VIR_MOCK_REAL_INIT(opendir);
VIR_MOCK_REAL_INIT(virFileCanonicalizePath);
}
static void
......@@ -1046,6 +1048,28 @@ close(int fd)
return -1;
return real_close(fd);
}
char *
virFileCanonicalizePath(const char *path)
{
char *ret;
init_syms();
if (STRPREFIX(path, SYSFS_PCI_PREFIX)) {
char *newpath;
if (getrealpath(&newpath, path) < 0)
return NULL;
ret = real_virFileCanonicalizePath(newpath);
VIR_FREE(newpath);
} else {
ret = real_virFileCanonicalizePath(path);
}
return ret;
}
#else
/* Nothing to override on non-__linux__ platforms */
#endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册