mirror of https://github.com/djcb/mu.git
* tests: add tests for mu_util_dir_expand and mu_util_guess_maildir
This commit is contained in:
parent
afcd800a2e
commit
3b8f908fa6
|
@ -52,10 +52,9 @@ mu_util_dir_expand (const char *path)
|
|||
return dir;
|
||||
}
|
||||
|
||||
|
||||
|
||||
gboolean
|
||||
mu_util_check_dir (const gchar* path, gboolean readable, gboolean writeable)
|
||||
mu_util_check_dir (const gchar* path, gboolean readable,
|
||||
gboolean writeable)
|
||||
{
|
||||
mode_t mode;
|
||||
struct stat statbuf;
|
||||
|
@ -66,34 +65,38 @@ mu_util_check_dir (const gchar* path, gboolean readable, gboolean writeable)
|
|||
mode = F_OK | (readable ? R_OK : 0) | (writeable ? W_OK : 0);
|
||||
|
||||
if (access (path, mode) != 0) {
|
||||
MU_WRITE_LOG ("Cannot access %s: %s", path, strerror (errno));
|
||||
MU_WRITE_LOG ("Cannot access %s: %s", path,
|
||||
strerror (errno));
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (stat (path, &statbuf) != 0) {
|
||||
MU_WRITE_LOG ("Cannot stat %s: %s", path, strerror (errno));
|
||||
MU_WRITE_LOG ("Cannot stat %s: %s", path,
|
||||
strerror (errno));
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
return S_ISDIR(statbuf.st_mode);
|
||||
return S_ISDIR(statbuf.st_mode) ? TRUE: FALSE;
|
||||
}
|
||||
|
||||
|
||||
gchar*
|
||||
mu_util_guess_maildir (void)
|
||||
{
|
||||
char *dir;
|
||||
|
||||
const gchar *mdir1;
|
||||
gchar *mdir2;
|
||||
|
||||
/* first, try MAILDIR */
|
||||
dir = getenv ("MAILDIR");
|
||||
if (mu_util_check_dir (dir, TRUE, FALSE))
|
||||
return g_strdup (dir);
|
||||
mdir1 = g_getenv ("MAILDIR");
|
||||
|
||||
if (mdir1 && mu_util_check_dir (mdir1, TRUE, FALSE))
|
||||
return g_strdup (mdir1);
|
||||
|
||||
/* then, try ~/Maildir */
|
||||
dir = mu_util_dir_expand ("~/Maildir");
|
||||
if (mu_util_check_dir (dir, TRUE, FALSE))
|
||||
return dir;
|
||||
|
||||
mdir2 = mu_util_dir_expand ("~/Maildir");
|
||||
if (mu_util_check_dir (mdir2, TRUE, FALSE))
|
||||
return mdir2;
|
||||
|
||||
/* nope; nothing found */
|
||||
return NULL;
|
||||
}
|
||||
|
|
|
@ -35,8 +35,8 @@ G_BEGIN_DECLS
|
|||
char* mu_util_dir_expand (const char* path);
|
||||
|
||||
/**
|
||||
* guess the maildir; first try MAILDIR, then try ~/Maildir
|
||||
* if both fail, return NULL
|
||||
* guess the maildir; first try $MAILDIR; if it is unset or
|
||||
* non-existant, try ~/Maildir if both fail, return NULL
|
||||
*
|
||||
* @return full path of the guessed Maildir, or NULL; must be freed (gfree)
|
||||
*/
|
||||
|
|
Binary file not shown.
|
@ -23,24 +23,88 @@
|
|||
|
||||
#include <glib.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "src/mu-util.h"
|
||||
|
||||
static void
|
||||
test_mu_util_dir_expand (void)
|
||||
test_mu_util_dir_expand_01 (void)
|
||||
{
|
||||
gchar *got, *expected;
|
||||
|
||||
got = mu_util_dir_expand ("~/Desktop");
|
||||
expected = g_strdup_printf ("%s%cDesktop",
|
||||
getenv("HOME"), G_DIR_SEPARATOR);
|
||||
|
||||
|
||||
g_assert_cmpstr (got,==,expected);
|
||||
|
||||
g_free (got);
|
||||
g_free (expected);
|
||||
|
||||
}
|
||||
|
||||
static void
|
||||
test_mu_util_dir_expand_02 (void)
|
||||
{
|
||||
gchar *got, *expected, *tmp;
|
||||
|
||||
tmp = g_strdup_printf ("~%s/Desktop", getenv("LOGNAME"));
|
||||
got = mu_util_dir_expand (tmp);
|
||||
expected = g_strdup_printf ("%s%cDesktop",
|
||||
getenv("HOME"), G_DIR_SEPARATOR);
|
||||
|
||||
g_assert_cmpstr (got,==,expected);
|
||||
|
||||
g_free (tmp);
|
||||
g_free (got);
|
||||
g_free (expected);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
test_mu_util_guess_maildir_01 (void)
|
||||
{
|
||||
char *got;
|
||||
const char *expected;
|
||||
|
||||
/* skip the test if there's no /tmp */
|
||||
if (access ("/tmp", F_OK))
|
||||
return;
|
||||
|
||||
g_setenv ("MAILDIR", "/tmp", TRUE);
|
||||
|
||||
got = mu_util_guess_maildir ();
|
||||
expected = "/tmp";
|
||||
|
||||
g_assert_cmpstr (got,==,expected);
|
||||
g_free (got);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
test_mu_util_guess_maildir_02 (void)
|
||||
{
|
||||
char *got, *mdir;
|
||||
|
||||
g_unsetenv ("MAILDIR");
|
||||
|
||||
mdir = g_strdup_printf ("%s%cMaildir",
|
||||
getenv("HOME"), G_DIR_SEPARATOR);
|
||||
got = mu_util_guess_maildir ();
|
||||
|
||||
if (access (mdir, F_OK) == 0)
|
||||
g_assert_cmpstr (got, ==, mdir);
|
||||
else
|
||||
g_assert_cmpstr (got, == , NULL);
|
||||
|
||||
g_free (got);
|
||||
g_free (mdir);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
static void
|
||||
shutup (void) {}
|
||||
|
||||
|
@ -49,12 +113,22 @@ main (int argc, char *argv[])
|
|||
{
|
||||
g_test_init (&argc, &argv, NULL);
|
||||
|
||||
/* mu_util_dir_expand */
|
||||
g_test_add_func ("/mu-util/mu-util-dir-expand-01",
|
||||
test_mu_util_dir_expand);
|
||||
test_mu_util_dir_expand_01);
|
||||
g_test_add_func ("/mu-util/mu-util-dir-expand-02",
|
||||
test_mu_util_dir_expand_02);
|
||||
|
||||
/* mu_util_guess_maildir */
|
||||
g_test_add_func ("/mu-util/mu-util-guess-maildir-01",
|
||||
test_mu_util_guess_maildir_01);
|
||||
g_test_add_func ("/mu-util/mu-util-guess-maildir-02",
|
||||
test_mu_util_guess_maildir_02);
|
||||
|
||||
g_log_set_handler (NULL,
|
||||
G_LOG_LEVEL_DEBUG|G_LOG_LEVEL_MESSAGE|G_LOG_LEVEL_INFO,
|
||||
(GLogFunc)shutup, NULL);
|
||||
G_LOG_LEVEL_DEBUG|
|
||||
G_LOG_LEVEL_MESSAGE|
|
||||
G_LOG_LEVEL_INFO, (GLogFunc)shutup, NULL);
|
||||
|
||||
return g_test_run ();
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue