Blame tests/xml/test-load.c

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
}