|
Packit |
bc1512 |
/*
|
|
Packit |
bc1512 |
* This program is free software; you can redistribute it and/or modify
|
|
Packit |
bc1512 |
* it under the terms of the GNU General Public License as published by
|
|
Packit |
bc1512 |
* the Free Software Foundation; either version 3 of the License, or
|
|
Packit |
bc1512 |
* (at your option) any later version.
|
|
Packit |
bc1512 |
*
|
|
Packit |
bc1512 |
* This program is distributed in the hope that it will be useful,
|
|
Packit |
bc1512 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
bc1512 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
Packit |
bc1512 |
* GNU General Public License for more details.
|
|
Packit |
bc1512 |
*
|
|
Packit |
bc1512 |
* You should have received a copy of the GNU General Public License
|
|
Packit |
bc1512 |
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
Packit |
bc1512 |
*
|
|
Packit |
bc1512 |
* Copyright (C) 2011 Jon Nordby <jononor@gmail.com>
|
|
Packit |
bc1512 |
*/
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Test loading/de-serialization of graphs from XML */
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
#include <glib.h>
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
#include <gegl.h>
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
#include "common.c"
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Loading an empty graph should result a valid GeglNode with no children.
|
|
Packit |
bc1512 |
*
|
|
Packit |
bc1512 |
* Kind-of a sanity test, should run before other tests. */
|
|
Packit |
bc1512 |
static void
|
|
Packit |
bc1512 |
test_load_empty_graph (void)
|
|
Packit |
bc1512 |
{
|
|
Packit |
bc1512 |
const gchar * const xml = "\n<gegl>\n</gegl>\n";
|
|
Packit |
bc1512 |
GeglNode *graph;
|
|
Packit |
bc1512 |
GSList *children;
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
graph = gegl_node_new_from_xml(xml, "");
|
|
Packit |
bc1512 |
g_assert(graph);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
children = gegl_node_get_children(graph);
|
|
Packit |
bc1512 |
g_assert_cmpuint(g_slist_length(children), ==, 0);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
g_slist_free(children);
|
|
Packit |
bc1512 |
g_object_unref(graph);
|
|
Packit |
bc1512 |
}
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Loading a graph with X child nodes should result in
|
|
Packit |
bc1512 |
* a GeglNode with X children, where the bottom-most node
|
|
Packit |
bc1512 |
* is child 0.
|
|
Packit |
bc1512 |
*
|
|
Packit |
bc1512 |
* Note: Properties are not tested. */
|
|
Packit |
bc1512 |
static void
|
|
Packit |
bc1512 |
test_load_multiple_nodes (void)
|
|
Packit |
bc1512 |
{
|
|
Packit |
bc1512 |
const gchar * const xml = \
|
|
Packit |
bc1512 |
"\n\
|
|
Packit |
bc1512 |
<gegl>\n\
|
|
Packit |
bc1512 |
<node operation='gegl:invert'>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
<node operation='gegl:crop'>\n\
|
|
Packit |
bc1512 |
<params>\n\
|
|
Packit |
bc1512 |
<param name='x'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='y'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='width'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='height'>0</param>\n\
|
|
Packit |
bc1512 |
</params>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
</gegl>\n";
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
GeglNode *graph, *node;
|
|
Packit |
bc1512 |
GSList *children;
|
|
Packit |
bc1512 |
gchar *op_name;
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
graph = gegl_node_new_from_xml(xml, "");
|
|
Packit |
bc1512 |
g_assert(graph);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
children = gegl_node_get_children(graph);
|
|
Packit |
bc1512 |
g_assert_cmpuint(g_slist_length(children), ==, 2);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(children, 0));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, "gegl:crop");
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(children, 1));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, "gegl:invert");
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
g_slist_free(children);
|
|
Packit |
bc1512 |
g_object_unref(graph);
|
|
Packit |
bc1512 |
}
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Test that loading a subgraph works */
|
|
Packit |
bc1512 |
static void
|
|
Packit |
bc1512 |
test_load_subgraph (void)
|
|
Packit |
bc1512 |
{
|
|
Packit |
bc1512 |
const gchar * const xml = \
|
|
Packit |
bc1512 |
"\n\
|
|
Packit |
bc1512 |
<gegl>\n\
|
|
Packit |
bc1512 |
<node>\n\
|
|
Packit |
bc1512 |
<node operation='gegl:invert'>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
<node operation='gegl:crop'>\n\
|
|
Packit |
bc1512 |
<params>\n\
|
|
Packit |
bc1512 |
<param name='x'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='y'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='width'>0</param>\n\
|
|
Packit |
bc1512 |
<param name='height'>0</param>\n\
|
|
Packit |
bc1512 |
</params>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
<node operation='gegl:crop'>\n\
|
|
Packit |
bc1512 |
</node>\n\
|
|
Packit |
bc1512 |
</gegl>\n";
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
GeglNode *graph, *node;
|
|
Packit |
bc1512 |
GSList *toplevel_children, *subgraph_children;
|
|
Packit |
bc1512 |
gchar *op_name;
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
graph = gegl_node_new_from_xml(xml, "");
|
|
Packit |
bc1512 |
g_assert(graph);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
toplevel_children = gegl_node_get_children(graph);
|
|
Packit |
bc1512 |
g_assert_cmpuint(g_slist_length(toplevel_children), ==, 2);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(toplevel_children, 0));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, "gegl:crop");
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(toplevel_children, 1));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, ""); // Meta-operation
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Subgraph */
|
|
Packit |
bc1512 |
subgraph_children = gegl_node_get_children(node);
|
|
Packit |
bc1512 |
g_assert_cmpuint(g_slist_length(toplevel_children), ==, 2);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(subgraph_children, 0));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, "gegl:crop");
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
node = GEGL_NODE(g_slist_nth_data(subgraph_children, 1));
|
|
Packit |
bc1512 |
gegl_node_get(node, "operation", &op_name, NULL);
|
|
Packit |
bc1512 |
g_assert_cmpstr(op_name, ==, "gegl:invert");
|
|
Packit |
bc1512 |
g_free(op_name);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
g_slist_free(subgraph_children);
|
|
Packit |
bc1512 |
g_slist_free(toplevel_children);
|
|
Packit |
bc1512 |
g_object_unref(graph);
|
|
Packit |
bc1512 |
}
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
int
|
|
Packit |
bc1512 |
main (int argc, char *argv[])
|
|
Packit |
bc1512 |
{
|
|
Packit |
bc1512 |
int result = -1;
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
gegl_init(&argc, &argv);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
g_test_init(&argc, &argv, NULL);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
g_test_add_func("/xml/load/empty_graph", test_load_empty_graph);
|
|
Packit |
bc1512 |
g_test_add_func("/xml/load/multiple_nodes", test_load_multiple_nodes);
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
/* Expected failure: not implemented
|
|
Packit |
bc1512 |
g_test_add_func("/xml/load/subgraph", test_load_subgraph);
|
|
Packit |
bc1512 |
*/
|
|
Packit |
bc1512 |
|
|
Packit |
bc1512 |
result = g_test_run();
|
|
Packit |
bc1512 |
gegl_exit();
|
|
Packit |
bc1512 |
return result;
|
|
Packit |
bc1512 |
}
|