/* Copyright (C) 2009 Christian Dywan This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. See the file COPYING for the full license text. */ #include "midori.h" #include const gpointer magic = (gpointer)0xdeadbeef; static void extension_activate_cb (MidoriExtension* extension, MidoriApp* app) { g_object_set_data (G_OBJECT (extension), "activated", magic); } static void extension_deactivate_cb (MidoriExtension* extension) { g_object_set_data (G_OBJECT (extension), "deactivated", magic); } static void extension_create (void) { MidoriApp* app; MidoriExtension* extension; app = midori_app_new (NULL); extension = g_object_new (MIDORI_TYPE_EXTENSION, NULL); g_assert (!midori_extension_is_prepared (extension)); g_object_set (extension, "name", "TestExtension", "version", "1.0", NULL); g_assert (!midori_extension_is_prepared (extension)); g_object_set (extension, "description", "Nothing but a test.", "authors", "John Doe", NULL); /* FIXME: We should require to connect to "activate" g_assert (!midori_extension_is_prepared (extension)); */ g_signal_connect (extension, "activate", G_CALLBACK (extension_activate_cb), NULL); g_assert (midori_extension_is_prepared (extension)); g_assert (!midori_extension_is_active (extension)); g_signal_emit_by_name (extension, "activate", app); g_assert (midori_extension_is_active (extension)); g_assert (midori_extension_get_app (extension) == app); g_assert (g_object_get_data (G_OBJECT (extension), "activated") == magic); g_signal_connect (extension, "deactivate", G_CALLBACK (extension_deactivate_cb), NULL); midori_extension_deactivate (extension); g_assert (!midori_extension_is_active (extension)); g_assert (g_object_get_data (G_OBJECT (extension), "deactivated") == magic); } static MidoriExtension* extension_mock_object (void) { MidoriExtension* extension; extension = g_object_new (MIDORI_TYPE_EXTENSION, "name", "TestExtension", "version", "1.0", "description", "Nothing but a test.", "authors", "John Doe", NULL); return extension; } static void katze_assert_cmpstrv (gchar** values1, gsize length1, gchar** values2, gsize length2) { gsize i; g_assert ((values1 && values2) || (!values1 && !values2)); /* g_assert_cmpint (length1, ==, length2); */ for (i = 0; i < length1; i++) g_assert_cmpstr (values1[i], ==, values2[i]); } static void extension_settings (void) { MidoriApp* app; MidoriExtension* extension; gboolean nihilist; gint age; const gchar* lastname; gchar* pet_names[] = {"Tiger", "Bonzo", "Streuner", NULL}; gchar** names; gsize names_n; app = midori_app_new (NULL); extension = extension_mock_object (); midori_extension_install_boolean (extension, "nihilist", TRUE); nihilist = midori_extension_get_boolean (extension, "nihilist"); g_assert (!nihilist); g_signal_connect (extension, "activate", G_CALLBACK (extension_activate_cb), NULL); g_signal_emit_by_name (extension, "activate", app); nihilist = midori_extension_get_boolean (extension, "nihilist"); g_assert (nihilist); midori_extension_set_boolean (extension, "nihilist", FALSE); nihilist = midori_extension_get_boolean (extension, "nihilist"); g_assert (!nihilist); midori_extension_deactivate (extension); extension = extension_mock_object (); midori_extension_install_integer (extension, "age", 88); age = midori_extension_get_integer (extension, "age"); g_assert_cmpint (age, ==, 0); g_signal_connect (extension, "activate", G_CALLBACK (extension_activate_cb), NULL); g_signal_emit_by_name (extension, "activate", app); age = midori_extension_get_integer (extension, "age"); g_assert_cmpint (age, ==, 88); midori_extension_set_integer (extension, "age", 66); age = midori_extension_get_integer (extension, "age"); g_assert_cmpint (age, ==, 66); midori_extension_deactivate (extension); extension = extension_mock_object (); midori_extension_install_string (extension, "lastname", "Thomas Mann"); lastname = midori_extension_get_string (extension, "lastname"); g_assert_cmpstr (lastname, ==, NULL); g_signal_connect (extension, "activate", G_CALLBACK (extension_activate_cb), NULL); g_signal_emit_by_name (extension, "activate", app); lastname = midori_extension_get_string (extension, "lastname"); g_assert_cmpstr (lastname, ==, "Thomas Mann"); midori_extension_set_string (extension, "lastname", "Theodor Fontane"); lastname = midori_extension_get_string (extension, "lastname"); g_assert_cmpstr (lastname, ==, "Theodor Fontane"); midori_extension_deactivate (extension); extension = extension_mock_object (); midori_extension_install_string_list (extension, "pets", pet_names, 3); names = midori_extension_get_string_list (extension, "pets", &names_n); katze_assert_cmpstrv (NULL, 0, names, names_n); g_strfreev (names); g_signal_emit_by_name (extension, "activate", app); names = midori_extension_get_string_list (extension, "pets", &names_n); katze_assert_cmpstrv (pet_names, 3, names, names_n); g_strfreev (names); /* names = g_strsplit ("Carla,Fluffy,Goro,Kitty", ",", 0); midori_extension_set_string_list (extension, "pets", names, G_MAXSIZE); g_strfreev (names); names = midori_extension_get_string_list (extension, "pets", &names_n); g_assert_cmpint (names_n, ==, 4); */ names = g_strsplit ("Carla,Fluffy,Goro,Kitty", ",", 0); midori_extension_set_string_list (extension, "pets", names, 2); g_strfreev (names); names = midori_extension_get_string_list (extension, "pets", &names_n); g_assert_cmpint (names_n, ==, 2); midori_extension_deactivate (extension); } static void extension_activate (gconstpointer data) { MidoriApp* app = midori_app_new (NULL); g_object_set (app, "settings", midori_web_settings_new (), NULL); midori_extension_activate (G_OBJECT (data), NULL, TRUE, app); /* TODO: MidoriCompletion */ g_object_unref (app); } static void extension_load (const gchar* extension_path, GDir* extension_dir) { const gchar* filename; while ((filename = g_dir_read_name (extension_dir))) { GObject* extension = midori_extension_load_from_file (extension_path, filename, FALSE, TRUE); if (KATZE_IS_ARRAY (extension)) { MidoriExtension* extension_item; KATZE_ARRAY_FOREACH_ITEM (extension_item, KATZE_ARRAY (extension)) if (MIDORI_IS_EXTENSION (extension_item)) { gchar* key = katze_object_get_object (extension_item, "key"); gchar* path = g_strdup_printf ("/extensions/%s/%s", filename, key); g_test_add_data_func (path, extension_item, extension_activate); g_free (path); g_free (key); } } else if (extension != NULL) { gchar* path = g_strconcat ("/extensions/", filename, NULL); g_test_add_data_func (path, extension, extension_activate); g_free (path); } } } static void extension_config (void) { gchar* filename = midori_paths_get_extension_config_dir ("adblock"); g_assert (g_access (filename, F_OK) == 0); } int main (int argc, char** argv) { g_test_init (&argc, &argv, NULL); midori_app_setup (&argc, &argv, NULL); midori_paths_init (MIDORI_RUNTIME_MODE_NORMAL, NULL); #ifndef HAVE_WEBKIT2 soup_session_add_feature_by_type (webkit_get_default_session (), SOUP_TYPE_COOKIE_JAR); #endif g_test_add_func ("/extensions/create", extension_create); g_test_add_func ("/extensions/settings", extension_settings); g_test_add_func ("/extensions/config", extension_config); if (g_module_supported ()) { gchar* extension_path = midori_paths_get_lib_path (PACKAGE_NAME); GDir* extension_dir = g_dir_open (extension_path, 0, NULL); g_assert (extension_dir != NULL); /* We require that extensions can be loaded repeatedly */ extension_load (extension_path, extension_dir); extension_load (extension_path, extension_dir); g_dir_close (extension_dir); g_free (extension_path); } return g_test_run (); }