[glom/glom-1-20] Tests: Add a shared get_field_on_layout() function.
- From: Murray Cumming <murrayc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glom/glom-1-20] Tests: Add a shared get_field_on_layout() function.
- Date: Mon, 5 Dec 2011 15:24:13 +0000 (UTC)
commit 67aafec1c2aa22702d309144464200791d6d6c55
Author: Murray Cumming <murrayc murrayc com>
Date: Sat Dec 3 14:42:15 2011 +0100
Tests: Add a shared get_field_on_layout() function.
* tests/test_document_load.cc: Move get_field_on_layout() to
* Makefile_tests.am:
* tests/test_utils.[h|cc]: here.
Conflicts:
tests/test_document_load.cc
ChangeLog | 9 +++++++
Makefile_tests.am | 5 +++-
tests/test_document_load.cc | 34 ++++----------------------
tests/test_utils.cc | 54 +++++++++++++++++++++++++++++++++++++++++++
tests/test_utils.h | 31 ++++++++++++++++++++++++
5 files changed, 104 insertions(+), 29 deletions(-)
---
diff --git a/ChangeLog b/ChangeLog
index 1b84669..75c5815 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2011-12-03 Murray Cumming <murrayc murrayc com>
+
+ Tests: Add a shared get_field_on_layout() function.
+
+ * tests/test_document_load.cc: Move get_field_on_layout() to
+ * Makefile_tests.am:
+ * tests/test_utils.[h|cc]: here.
+
+
2011-12-02 Murray Cumming <murrayc murrayc com>
DbUtils::recreate_database_from_document(): Set table privileges too.
diff --git a/Makefile_tests.am b/Makefile_tests.am
index 1516c55..02451c6 100644
--- a/Makefile_tests.am
+++ b/Makefile_tests.am
@@ -96,7 +96,7 @@ glom_libglom_test_sharedptr_layoutitem_SOURCES = glom/libglom/test_sharedptr_lay
glom_libglom_test_sharedptr_layoutitem_LDADD = $(tests_ldadd)
glom_libglom_test_sharedptr_layoutitem_CPPFLAGS = $(tests_cppflags)
-tests_test_document_load_SOURCES = tests/test_document_load.cc
+tests_test_document_load_SOURCES = tests/test_document_load.cc $(sources_test_utils)
tests_test_document_load_LDADD = $(tests_ldadd)
tests_test_document_load_CPPFLAGS = $(tests_cppflags)
@@ -158,6 +158,9 @@ tests_import_test_signals_LDADD = $(tests_ldadd)
tests_import_test_signals_CPPFLAGS = $(tests_cppflags)
+sources_test_utils = tests/test_utils.h \
+ tests/test_utils.cc
+
sources_test_selfhosting_utils = tests/test_selfhosting_utils.h \
tests/test_selfhosting_utils.cc
diff --git a/tests/test_document_load.cc b/tests/test_document_load.cc
index ca68a8b..a68dd70 100644
--- a/tests/test_document_load.cc
+++ b/tests/test_document_load.cc
@@ -18,6 +18,7 @@
* Boston, MA 02111-1307, USA.
*/
+#include "tests/test_utils.h"
#include <libglom/document/document.h>
#include <libglom/init.h>
#include <libglom/db_utils.h>
@@ -45,35 +46,12 @@ bool contains_named(const T_Container& container, const Glib::ustring& name)
return iter != container.end();
}
-static Glom::sharedptr<const Glom::LayoutItem_Field> get_field_on_layout(const Glom::Document& document, const Glib::ustring& layout_table_name, const Glib::ustring& table_name, const Glib::ustring& field_name)
+static bool groups_contain_named(const Glom::Document::type_list_groups& container, const Glib::ustring& name)
{
- const Glom::Document::type_list_layout_groups groups =
- document.get_data_layout_groups("details", layout_table_name);
-
- for(Glom::Document::type_list_layout_groups::const_iterator iter = groups.begin(); iter != groups.end(); ++iter)
- {
- const Glom::sharedptr<const Glom::LayoutGroup> group = *iter;
- if(!group)
- continue;
-
- const Glom::LayoutGroup::type_list_const_items items = group->get_items_recursive();
- for(Glom::LayoutGroup::type_list_const_items::const_iterator iter = items.begin(); iter != items.end(); ++iter)
- {
- const Glom::sharedptr<const Glom::LayoutItem> layout_item = *iter;
- const Glom::sharedptr<const Glom::LayoutItem_Field> layout_item_field =
- Glom::sharedptr<const Glom::LayoutItem_Field>::cast_dynamic(layout_item);
- if(!layout_item_field)
- continue;
-
- if( (layout_item_field->get_table_used(layout_table_name) == table_name) &&
- (layout_item_field->get_name() == field_name) )
- {
- return layout_item_field;
- }
- }
- }
-
- return Glom::sharedptr<const Glom::LayoutItem_Field>();
+ const Glom::Document::type_list_groups::const_iterator iter =
+ std::find_if(container.begin(), container.end(),
+ Glom::predicate_FieldHasName<Glom::GroupInfo>(name));
+ return iter != container.end();
}
static bool needs_navigation(Glom::Document& document, const Glib::ustring& table_name, const Glib::ustring& field_name)
diff --git a/tests/test_utils.cc b/tests/test_utils.cc
new file mode 100644
index 0000000..ada0ea5
--- /dev/null
+++ b/tests/test_utils.cc
@@ -0,0 +1,54 @@
+/* Glom
+ *
+ * Copyright (C) 2011 Murray Cumming
+ *
+ * This program 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 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program 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 this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include "tests/test_utils.h"
+
+Glom::sharedptr<const Glom::LayoutItem_Field> get_field_on_layout(const Glom::Document& document, const Glib::ustring& layout_table_name, const Glib::ustring& table_name, const Glib::ustring& field_name)
+{
+ const Glom::Document::type_list_layout_groups groups =
+ document.get_data_layout_groups("details", layout_table_name);
+
+ for(Glom::Document::type_list_layout_groups::const_iterator iter = groups.begin(); iter != groups.end(); ++iter)
+ {
+ const Glom::sharedptr<const Glom::LayoutGroup> group = *iter;
+ if(!group)
+ continue;
+
+ const Glom::LayoutGroup::type_list_const_items items = group->get_items_recursive();
+ for(Glom::LayoutGroup::type_list_const_items::const_iterator iter = items.begin(); iter != items.end(); ++iter)
+ {
+ const Glom::sharedptr<const Glom::LayoutItem> layout_item = *iter;
+ const Glom::sharedptr<const Glom::LayoutItem_Field> layout_item_field =
+ Glom::sharedptr<const Glom::LayoutItem_Field>::cast_dynamic(layout_item);
+ if(!layout_item_field)
+ continue;
+
+ if( (layout_item_field->get_table_used(layout_table_name) == table_name) &&
+ (layout_item_field->get_name() == field_name) )
+ {
+ return layout_item_field;
+ }
+ }
+ }
+
+ return Glom::sharedptr<const Glom::LayoutItem_Field>();
+}
+
+
diff --git a/tests/test_utils.h b/tests/test_utils.h
new file mode 100644
index 0000000..8284090
--- /dev/null
+++ b/tests/test_utils.h
@@ -0,0 +1,31 @@
+/* Glom
+ *
+ * Copyright (C) 2011 Murray Cumming
+ *
+ * This program 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 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program 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 this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#ifndef GLOM_TEST_UTILS_H
+#define GLOM_TEST_UTILS_H
+
+#include <libglom/document/document.h>
+#include <string>
+
+Glom::sharedptr<const Glom::LayoutItem_Field> get_field_on_layout(const Glom::Document& document, const Glib::ustring& layout_table_name, const Glib::ustring& table_name, const Glib::ustring& field_name);
+
+
+#endif //GLOM_TEST_UTILS_H
+
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]