extend url database unit testing to cover more API

This commit is contained in:
Vincent Sanders 2016-08-09 12:26:37 +01:00
parent d35ad1b8e7
commit 115985f069
3 changed files with 120 additions and 16 deletions

View File

@ -2801,8 +2801,16 @@ bool urldb_add_url(nsurl *url)
h = urldb_add_host(host_str); h = urldb_add_host(host_str);
/* Get path entry */ /* Get path entry */
p = (h != NULL) ? urldb_add_path(scheme, port_int, h, path_query, if (h != NULL) {
fragment, url) : NULL; p = urldb_add_path(scheme,
port_int,
h,
path_query,
fragment,
url);
} else {
p = NULL;
}
lwc_string_unref(scheme); lwc_string_unref(scheme);
if (fragment != NULL) if (fragment != NULL)
@ -3074,23 +3082,29 @@ bool urldb_get_cert_permissions(nsurl *url)
/* exported interface documented in content/urldb.h */ /* exported interface documented in content/urldb.h */
void urldb_set_thumbnail(nsurl *url, struct bitmap *bitmap) bool urldb_set_thumbnail(nsurl *url, struct bitmap *bitmap)
{ {
struct path_data *p; struct path_data *p;
assert(url); assert(url);
/* add url, in case it's missing */
urldb_add_url(url);
p = urldb_find_url(url); p = urldb_find_url(url);
if (p != NULL) { if (p == NULL) {
return false;
}
LOG("Setting bitmap on %s", nsurl_access(url)); LOG("Setting bitmap on %s", nsurl_access(url));
if (p->thumb && p->thumb != bitmap) { if ((p->thumb) && (p->thumb != bitmap)) {
guit->bitmap->destroy(p->thumb); guit->bitmap->destroy(p->thumb);
} }
p->thumb = bitmap; p->thumb = bitmap;
}
return true;
} }

View File

@ -111,8 +111,9 @@ bool urldb_get_cert_permissions(struct nsurl *url);
* *
* \param url Absolute URL to consider * \param url Absolute URL to consider
* \param bitmap Opaque pointer to thumbnail data, or NULL to invalidate * \param bitmap Opaque pointer to thumbnail data, or NULL to invalidate
* \return true on sucessful setting else false
*/ */
void urldb_set_thumbnail(struct nsurl *url, struct bitmap *bitmap); bool urldb_set_thumbnail(struct nsurl *url, struct bitmap *bitmap);
/** /**

View File

@ -38,7 +38,9 @@
#include "utils/nsoption.h" #include "utils/nsoption.h"
#include "netsurf/url_db.h" #include "netsurf/url_db.h"
#include "netsurf/cookie_db.h" #include "netsurf/cookie_db.h"
#include "netsurf/bitmap.h"
#include "content/urldb.h" #include "content/urldb.h"
#include "desktop/gui_internal.h"
#include "desktop/cookie_manager.h" #include "desktop/cookie_manager.h"
const char *test_urldb_path = "test/data/urldb"; const char *test_urldb_path = "test/data/urldb";
@ -122,10 +124,27 @@ static char *test_urldb_get_cookie(const char *url)
/*************************************************/ /*************************************************/
/* mock table callbacks */
static void destroy_bitmap(void *b)
{
}
struct gui_bitmap_table tst_bitmap_table = {
.destroy = destroy_bitmap,
};
struct netsurf_table tst_table = {
.bitmap = &tst_bitmap_table,
};
/** urldb create fixture */ /** urldb create fixture */
static void urldb_create(void) static void urldb_create(void)
{ {
nserror res; nserror res;
/* mock bitmap interface */
guit = &tst_table;
res = corestrings_init(); res = corestrings_init();
ck_assert_int_eq(res, NSERROR_OK); ck_assert_int_eq(res, NSERROR_OK);
} }
@ -135,6 +154,9 @@ static void urldb_create_loaded(void)
{ {
nserror res; nserror res;
/* mock bitmap interface */
guit = &tst_table;
res = corestrings_init(); res = corestrings_init();
ck_assert_int_eq(res, NSERROR_OK); ck_assert_int_eq(res, NSERROR_OK);
@ -440,10 +462,13 @@ static TCase *urldb_session_case_create(void)
return tc; return tc;
} }
static int cb_count;
static bool urldb_iterate_entries_cb(nsurl *url, const struct url_data *data) static bool urldb_iterate_entries_cb(nsurl *url, const struct url_data *data)
{ {
LOG("url: %s", nsurl_access(url)); LOG("url: %s", nsurl_access(url));
/* fprintf(stderr, "url:%s\ntitle:%s\n\n",nsurl_access(url), data->title); */ /* fprintf(stderr, "url:%s\ntitle:%s\n\n",nsurl_access(url), data->title); */
cb_count++;
return true; return true;
} }
@ -453,9 +478,19 @@ START_TEST(urldb_iterate_entries_test)
} }
END_TEST END_TEST
/**
* iterate through partial matches
*/
START_TEST(urldb_iterate_partial_test) START_TEST(urldb_iterate_partial_test)
{ {
cb_count = 0;
urldb_iterate_partial("www", urldb_iterate_entries_cb); urldb_iterate_partial("www", urldb_iterate_entries_cb);
ck_assert_int_eq(cb_count, 7);
cb_count = 0;
urldb_iterate_partial("/", urldb_iterate_entries_cb);
ck_assert_int_eq(cb_count, 0);
} }
END_TEST END_TEST
@ -476,12 +511,23 @@ START_TEST(urldb_auth_details_test)
} }
END_TEST END_TEST
START_TEST(urldb_set_thumbnail_test)
START_TEST(urldb_thumbnail_test)
{ {
nsurl *url; nsurl *url;
struct bitmap *bmap;
struct bitmap *res;
bool set;
url = make_url("http://www.wikipedia.org/"); url = make_url("http://www.wikipedia.org/");
urldb_set_thumbnail(url, NULL); bmap = (struct bitmap*)url;
set = urldb_set_thumbnail(url, bmap);
ck_assert(set == true);
res = urldb_get_thumbnail(url);
ck_assert(res != NULL);
ck_assert(res == bmap);
nsurl_unref(url); nsurl_unref(url);
} }
@ -510,6 +556,47 @@ START_TEST(urldb_cert_permissions_test)
} }
END_TEST END_TEST
START_TEST(urldb_update_visit_test)
{
nsurl *url;
url = make_url("http://www.wikipedia.org/");
urldb_update_url_visit_data(url);
/** \todo test needs to check results */
nsurl_unref(url);
}
END_TEST
START_TEST(urldb_reset_visit_test)
{
nsurl *url;
url = make_url("http://www.wikipedia.org/");
urldb_reset_url_visit_data(url);
/** \todo test needs to check results */
nsurl_unref(url);
}
END_TEST
START_TEST(urldb_persistence_test)
{
nsurl *url;
url = make_url("http://www.wikipedia.org/");
urldb_set_url_persistence(url, true);
urldb_set_url_persistence(url, false);
/** \todo test needs to check results */
nsurl_unref(url);
}
END_TEST
static TCase *urldb_case_create(void) static TCase *urldb_case_create(void)
{ {
@ -524,8 +611,10 @@ static TCase *urldb_case_create(void)
tcase_add_test(tc, urldb_iterate_entries_test); tcase_add_test(tc, urldb_iterate_entries_test);
tcase_add_test(tc, urldb_iterate_partial_test); tcase_add_test(tc, urldb_iterate_partial_test);
tcase_add_test(tc, urldb_auth_details_test); tcase_add_test(tc, urldb_auth_details_test);
tcase_add_test(tc, urldb_set_thumbnail_test); tcase_add_test(tc, urldb_thumbnail_test);
tcase_add_test(tc, urldb_cert_permissions_test); tcase_add_test(tc, urldb_cert_permissions_test);
tcase_add_test(tc, urldb_update_visit_test);
tcase_add_test(tc, urldb_reset_visit_test);
return tc; return tc;
} }