/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/*
* Copyright © 2012 Igalia S.L.
*
* This file is part of Epiphany.
*
* Epiphany is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Epiphany is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Epiphany. If not, see .
*/
#include "config.h"
#include "ephy-debug.h"
#include "ephy-file-helpers.h"
#include "ephy-flatpak-utils.h"
#include "ephy-settings.h"
#include
#include
typedef struct {
const char *dir;
EphyFileHelpersFlags flags;
} FileInitTest;
static const FileInitTest private_tests[] = {
{ "private", EPHY_FILE_HELPERS_PRIVATE_PROFILE },
{ "private, keep-dir", EPHY_FILE_HELPERS_PRIVATE_PROFILE | EPHY_FILE_HELPERS_KEEP_DIR }
};
static void
test_ephy_file_helpers_init (void)
{
guint i;
for (i = 0; i < G_N_ELEMENTS (private_tests); i++) {
FileInitTest test;
char *tmp_dir = NULL;
char *profile_dir = NULL;
gboolean private_profile = FALSE;
gboolean keep_dir = FALSE;
gboolean ensure_exists = FALSE;
test = private_tests[i];
if (test.flags & EPHY_FILE_HELPERS_PRIVATE_PROFILE) private_profile = TRUE;
if (test.flags & EPHY_FILE_HELPERS_KEEP_DIR) keep_dir = TRUE;
if (test.flags & EPHY_FILE_HELPERS_ENSURE_EXISTS) ensure_exists = TRUE;
g_test_message ("INIT: dir: %s; private: %s; keep_dir: %s; ensure_exists: %s",
test.dir,
private_profile ? "TRUE" : "FALSE",
keep_dir ? "TRUE" : "FALSE",
ensure_exists ? "TRUE" : "FALSE");
g_assert_null (ephy_profile_dir ());
g_assert_true (ephy_file_helpers_init (NULL, test.flags, NULL));
tmp_dir = g_strdup (ephy_file_tmp_dir ());
profile_dir = g_strdup (ephy_profile_dir ());
g_assert_nonnull (tmp_dir);
g_assert_nonnull (profile_dir);
/* Should always exist after ephy_file_tmp_dir(). */
g_assert_true (g_file_test (tmp_dir, G_FILE_TEST_EXISTS));
g_assert_true (g_file_test (profile_dir, G_FILE_TEST_EXISTS) == ensure_exists);
ephy_file_helpers_shutdown ();
/* Private profiles have their profile_dir inside tmp_dir. */
g_assert_true (g_file_test (tmp_dir, G_FILE_TEST_EXISTS) == keep_dir);
g_assert_true (g_file_test (profile_dir, G_FILE_TEST_EXISTS) == (keep_dir && ensure_exists));
/* Cleanup dir left behind. */
if (keep_dir) {
/* As a safety measure, only try recursive delete on paths
* prefixed with /tmp. */
if (g_str_has_prefix (tmp_dir, "/tmp"))
g_assert_true (ephy_file_delete_dir_recursively (tmp_dir, NULL));
else
g_warning ("INIT: dangerous path returned as tmp_dir: %s", tmp_dir);
}
g_free (tmp_dir);
g_free (profile_dir);
}
}
typedef struct {
const char *key_value;
const char *expected;
GUserDirectory user_dir;
gboolean in_flatpak;
} DownloadsDirTest;
static const DownloadsDirTest downloads_tests[] = {
{ "Desktop", NULL, G_USER_DIRECTORY_DESKTOP, FALSE },
{ "Downloads", NULL, G_USER_DIRECTORY_DOWNLOAD, TRUE },
{ "invalid-keyword", NULL, G_USER_DIRECTORY_DOWNLOAD, TRUE },
{ "/tmp/Downloads", "/tmp/Downloads", -1, FALSE },
};
static void
test_ephy_file_get_downloads_dir (void)
{
guint i;
gboolean in_flatpak = ephy_is_running_inside_flatpak ();
ephy_file_helpers_init (NULL, EPHY_FILE_HELPERS_PRIVATE_PROFILE, NULL);
for (i = 0; i < G_N_ELEMENTS (downloads_tests); i++) {
DownloadsDirTest test;
char *downloads_dir = NULL;
const char *expected_dir = NULL;
test = downloads_tests[i];
if (in_flatpak && !test.in_flatpak)
continue;
if (test.expected != NULL)
expected_dir = test.expected;
else
expected_dir = g_get_user_special_dir (test.user_dir);
g_test_message ("DOWNLOADS: key_value: %s; expected: %s;",
test.key_value,
expected_dir);
g_settings_set_string (EPHY_SETTINGS_STATE,
EPHY_PREFS_STATE_DOWNLOAD_DIR,
test.key_value);
downloads_dir = ephy_file_get_downloads_dir ();
g_assert_cmpstr (downloads_dir, ==, expected_dir);
g_free (downloads_dir);
}
ephy_file_helpers_shutdown ();
}
typedef struct {
const char *dir;
gboolean exists;
gboolean can_create;
gboolean can_delete;
} DirTest;
static const DirTest dir_tests[] = {
{ "/tmp/ephy-test-dir", FALSE, TRUE, TRUE },
/* Unreadable */
{ "/root/ephy-test-dir", FALSE, FALSE, FALSE },
/* Unwritable */
{ "/non-existant/ephy-test-dir", FALSE, FALSE, FALSE },
};
static void
test_ephy_file_create_delete_dir (void)
{
guint i;
ephy_file_helpers_init (NULL, EPHY_FILE_HELPERS_PRIVATE_PROFILE, NULL);
for (i = 0; i < G_N_ELEMENTS (dir_tests); i++) {
DirTest test;
GError *error = NULL;
test = dir_tests[i];
g_test_message ("DIR: testing for %s", test.dir);
g_assert_true (g_file_test (test.dir, G_FILE_TEST_EXISTS) == test.exists);
g_assert_true (ephy_ensure_dir_exists (test.dir, NULL) == (test.exists || test.can_create));
g_assert_true (g_file_test (test.dir, G_FILE_TEST_EXISTS) == (test.exists || test.can_create));
g_assert_true (ephy_file_delete_dir_recursively (test.dir, &error) == test.can_delete);
if (error)
g_error_free (error);
if (test.exists)
g_assert_true (g_file_test (test.dir, G_FILE_TEST_EXISTS) != test.can_delete);
}
ephy_file_helpers_shutdown ();
}
static void
test_ephy_file_desktop_dir (void)
{
char *desktop_dir;
const char *xdg_desktop;
ephy_file_helpers_init (NULL, EPHY_FILE_HELPERS_PRIVATE_PROFILE, NULL);
desktop_dir = ephy_file_desktop_dir ();
xdg_desktop = g_get_user_special_dir (G_USER_DIRECTORY_DESKTOP);
g_assert_cmpstr (desktop_dir, ==, xdg_desktop);
g_free (desktop_dir);
ephy_file_helpers_shutdown ();
}
static void
delete_uri (const char *uri)
{
g_autoptr (GFile) file = NULL;
g_assert_nonnull (uri);
file = g_file_new_for_uri (uri);
g_assert_true (g_file_delete (file, NULL, NULL));
}
static void
test_ephy_file_create_delete_tmp (void)
{
char *tmp_file = NULL;
char *tmp_path = NULL;
char *tmp_uri = NULL;
char *tmp_path_prefix = NULL;
ephy_file_helpers_init (NULL, EPHY_FILE_HELPERS_PRIVATE_PROFILE, NULL);
/* Fails because filename has no "XXXXXX" keyword. */
tmp_file = ephy_file_tmp_filename ("test-ephy", NULL);
tmp_path = g_build_filename (ephy_file_tmp_dir (), "test-ephy", NULL);
g_assert_null (tmp_file);
g_assert_false (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
g_free (tmp_path);
g_free (tmp_file);
/* Simple creation. */
tmp_file = ephy_file_tmp_filename ("test-ephy-XXXXXX", NULL);
tmp_path = g_build_filename (ephy_file_tmp_dir (), tmp_file, NULL);
g_test_message ("TMP: %s", tmp_path);
g_assert_false (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
g_assert_true (g_file_set_contents (tmp_path, "test", -1, NULL));
g_assert_true (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
tmp_uri = g_filename_to_uri (tmp_path, NULL, NULL);
delete_uri (tmp_uri);
g_assert_false (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
g_free (tmp_uri);
g_free (tmp_path);
g_free (tmp_file);
/* Creation with suffix. */
tmp_file = ephy_file_tmp_filename ("test-ephy-XXXXXX", "test-ext");
tmp_path = g_build_filename (ephy_file_tmp_dir (), tmp_file, NULL);
g_assert_false (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
g_assert_true (g_file_set_contents (tmp_path, "test", -1, NULL));
g_assert_true (g_file_test (tmp_path, G_FILE_TEST_EXISTS));
tmp_path_prefix = g_build_filename (ephy_file_tmp_dir (), "test-ephy-", NULL);
g_test_message ("TMP: %s", tmp_path);
g_assert_true (g_str_has_suffix (tmp_path, "test-ext"));
g_assert_true (g_str_has_prefix (tmp_path, tmp_path_prefix));
tmp_uri = g_filename_to_uri (tmp_path, NULL, NULL);
delete_uri (tmp_uri);
g_assert_false (g_file_test (tmp_file, G_FILE_TEST_EXISTS));
g_free (tmp_uri);
g_free (tmp_path_prefix);
g_free (tmp_path);
g_free (tmp_file);
ephy_file_helpers_shutdown ();
}
typedef struct {
const char *filename;
const char *expected;
} SanitizeFilenameTest;
static const SanitizeFilenameTest sanitize_filename_tests[] = {
{ "Normal Filename", "Normal Filename" },
{ "filename/with/slashes", "filename_with_slashes" }
};
static void
test_ephy_sanitize_filename (void)
{
guint i;
ephy_file_helpers_init (NULL, EPHY_FILE_HELPERS_PRIVATE_PROFILE, NULL);
for (i = 0; i < G_N_ELEMENTS (sanitize_filename_tests); i++) {
SanitizeFilenameTest test;
char *filename;
test = sanitize_filename_tests[i];
g_test_message ("SANITIZE FILENAME: testing for %s", test.filename);
filename = g_strdup (test.filename);
g_assert_cmpstr (ephy_sanitize_filename (filename), ==, test.expected);
g_free (filename);
}
ephy_file_helpers_shutdown ();
}
int
main (int argc,
char *argv[])
{
int ret;
/* This should affect only this test, we use it so we can test for
* default directory changes. */
g_setenv ("GSETTINGS_BACKEND", "memory", TRUE);
/* Set our custom user-dirs.dirs, to control the output of
* g_get_user_special_dir. The values there are the ones we should
* check for in the test. */
g_setenv ("XDG_CONFIG_HOME", SOURCE_ROOT "/tests/data/", TRUE);
gtk_test_init (&argc, &argv);
ephy_debug_init ();
g_test_add_func ("/lib/ephy-file-helpers/init",
test_ephy_file_helpers_init);
g_test_add_func ("/lib/ephy-file-helpers/get_downloads_dir",
test_ephy_file_get_downloads_dir);
if (!ephy_is_running_inside_flatpak ())
g_test_add_func ("/lib/ephy-file-helpers/create_delete_dir",
test_ephy_file_create_delete_dir);
g_test_add_func ("/lib/ephy-file-helpers/desktop_dir",
test_ephy_file_desktop_dir);
g_test_add_func ("/lib/ephy-file-helpers/create_delete_tmp",
test_ephy_file_create_delete_tmp);
g_test_add_func ("/lib/ephy-file-helpers/sanitize_filename",
test_ephy_sanitize_filename);
ret = g_test_run ();
return ret;
}