summaryrefslogtreecommitdiff
path: root/tests/pipe_tests.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/pipe_tests.c')
-rw-r--r--tests/pipe_tests.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/pipe_tests.c b/tests/pipe_tests.c
index 0dd15ba..d61b680 100644
--- a/tests/pipe_tests.c
+++ b/tests/pipe_tests.c
@@ -8,6 +8,12 @@
#define TEST_FD1 1
#define TEST_FD2 2
+#define MENU_VALID "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" \
+ "<wvmenu><title>Test menu</title></wvmenu>"
+#define INVALID_XML ">> this & is not XML >>"
+#define MENU_INVALID_ROOT "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" \
+ "<invalid></invalid>"
+
typedef struct CountingPipe {
PipeComponent p;
size_t bytes;
@@ -244,3 +250,44 @@ void testpipe_delete2(PipeComponent *component) {
delete2_called = TRUE;
free(self);
}
+
+void test_pipe_menu_validator_valid_menu() {
+ PipeMenuValidator *pipe = pipe_menu_validator_create();
+ g_assert(pipe);
+
+ pipe_component_append((PipeComponent *)pipe, MENU_VALID,
+ strlen(MENU_VALID));
+ pipe_component_finished((PipeComponent *)pipe, WEBVISTATE_FINISHED_OK);
+ RequestState state = pipe_component_get_state((PipeComponent *)pipe);
+ g_assert(state == WEBVISTATE_FINISHED_OK);
+
+ pipe_delete_full((PipeComponent *)pipe);
+}
+
+void test_pipe_menu_validator_invalid_xml() {
+ PipeMenuValidator *pipe = pipe_menu_validator_create();
+ g_assert(pipe);
+
+ pipe_component_append((PipeComponent *)pipe, INVALID_XML,
+ strlen(INVALID_XML));
+ pipe_component_finished((PipeComponent *)pipe, WEBVISTATE_FINISHED_OK);
+ RequestState state = pipe_component_get_state((PipeComponent *)pipe);
+ g_assert((state != WEBVISTATE_NOT_FINISHED) &&
+ (state != WEBVISTATE_FINISHED_OK));
+
+ pipe_delete_full((PipeComponent *)pipe);
+}
+
+void test_pipe_menu_validator_invalid_root() {
+ PipeMenuValidator *pipe = pipe_menu_validator_create();
+ g_assert(pipe);
+
+ pipe_component_append((PipeComponent *)pipe, MENU_INVALID_ROOT,
+ strlen(MENU_INVALID_ROOT));
+ pipe_component_finished((PipeComponent *)pipe, WEBVISTATE_FINISHED_OK);
+ RequestState state = pipe_component_get_state((PipeComponent *)pipe);
+ g_assert((state != WEBVISTATE_NOT_FINISHED) &&
+ (state != WEBVISTATE_FINISHED_OK));
+
+ pipe_delete_full((PipeComponent *)pipe);
+}