gstreamer/tests/check/gst/sessionpool.c

180 lines
5.9 KiB
C
Raw Normal View History

/* GStreamer
* Copyright (C) 2014 Sebastian Rasmussen <sebras@hotmail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include <gst/check/gstcheck.h>
#include <rtsp-session-pool.h>
typedef struct
{
GstRTSPSession *sessions[3];
GstRTSPFilterResult response[3];
} Responses;
static GstRTSPFilterResult
filter_func (GstRTSPSessionPool * pool, GstRTSPSession * session,
gpointer user_data)
{
Responses *responses = (Responses *) user_data;
gint i;
for (i = 0; i < 3; i++)
if (session == responses->sessions[i])
return responses->response[i];
return GST_RTSP_FILTER_KEEP;
}
GST_START_TEST (test_pool)
{
GstRTSPSessionPool *pool;
GstRTSPSession *session1, *session2, *session3;
const gchar *session1id, *session2id, *session3id;
GList *list;
guint maxsessions;
GSource *source;
guint sourceid;
pool = gst_rtsp_session_pool_new ();
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 0);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 0);
gst_rtsp_session_pool_set_max_sessions (pool, 3);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 3);
session1 = gst_rtsp_session_pool_create (pool);
fail_unless (GST_IS_RTSP_SESSION (session1));
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 1);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 3);
session1id = gst_rtsp_session_get_sessionid (session1);
session2 = gst_rtsp_session_pool_create (pool);
fail_unless (GST_IS_RTSP_SESSION (session2));
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 2);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 3);
session2id = gst_rtsp_session_get_sessionid (session2);
session3 = gst_rtsp_session_pool_create (pool);
fail_unless (GST_IS_RTSP_SESSION (session3));
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 3);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 3);
session3id = gst_rtsp_session_get_sessionid (session3);
fail_if (GST_IS_RTSP_SESSION (gst_rtsp_session_pool_create (pool)));
fail_unless (gst_rtsp_session_pool_find (pool, session1id) == session1);
fail_unless (gst_rtsp_session_pool_find (pool, session2id) == session2);
fail_unless (gst_rtsp_session_pool_find (pool, session3id) == session3);
fail_unless (gst_rtsp_session_pool_find (pool, "") == NULL);
fail_unless (gst_rtsp_session_pool_remove (pool, session2));
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 2);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 3);
gst_rtsp_session_pool_set_max_sessions (pool, 2);
fail_unless_equals_int (gst_rtsp_session_pool_get_n_sessions (pool), 2);
fail_unless_equals_int (gst_rtsp_session_pool_get_max_sessions (pool), 2);
session2 = gst_rtsp_session_pool_create (pool);
fail_if (GST_IS_RTSP_SESSION (session2));
{
list = gst_rtsp_session_pool_filter (pool, NULL, NULL);
fail_unless_equals_int (g_list_length (list), 2);
fail_unless (g_list_find (list, session1) != NULL);
fail_unless (g_list_find (list, session3) != NULL);
g_list_foreach (list, (GFunc) g_object_unref, NULL);
}
{
Responses responses = {
{session1, session2, session3},
{GST_RTSP_FILTER_KEEP, GST_RTSP_FILTER_KEEP, GST_RTSP_FILTER_KEEP},
};
list = gst_rtsp_session_pool_filter (pool, filter_func, &responses);
fail_unless (list == NULL);
}
{
Responses responses = {
{session1, session2, session3},
{GST_RTSP_FILTER_REF, GST_RTSP_FILTER_KEEP, GST_RTSP_FILTER_KEEP},
};
list = gst_rtsp_session_pool_filter (pool, filter_func, &responses);
fail_unless_equals_int (g_list_length (list), 1);
fail_unless (g_list_nth_data (list, 0) == session1);
g_list_foreach (list, (GFunc) g_object_unref, NULL);
}
{
Responses responses = {
{session1, session2, session3},
{GST_RTSP_FILTER_KEEP, GST_RTSP_FILTER_KEEP, GST_RTSP_FILTER_REMOVE},
};
list = gst_rtsp_session_pool_filter (pool, filter_func, &responses);
fail_unless_equals_int (g_list_length (list), 0);
}
fail_unless (gst_rtsp_session_pool_find (pool, session1id) == session1);
fail_unless (gst_rtsp_session_pool_find (pool, session2id) == NULL);
fail_unless (gst_rtsp_session_pool_find (pool, session3id) == NULL);
g_object_get (pool, "max-sessions", &maxsessions, NULL);
fail_unless_equals_int (maxsessions, 2);
g_object_set (pool, "max-sessions", 3, NULL);
g_object_get (pool, "max-sessions", &maxsessions, NULL);
fail_unless_equals_int (maxsessions, 3);
fail_unless_equals_int (gst_rtsp_session_pool_cleanup (pool), 0);
gst_rtsp_session_set_timeout (session1, 1);
source = gst_rtsp_session_pool_create_watch (pool);
fail_unless (source != NULL);
sourceid = g_source_attach (source, NULL);
fail_unless (sourceid != 0);
while (!g_main_context_iteration (NULL, TRUE));
g_source_unref (source);
g_object_unref (pool);
}
GST_END_TEST;
static Suite *
rtspsessionpool_suite (void)
{
Suite *s = suite_create ("rtspsessionpool");
TCase *tc = tcase_create ("general");
suite_add_tcase (s, tc);
tcase_set_timeout (tc, 15);
tcase_add_test (tc, test_pool);
return s;
}
GST_CHECK_MAIN (rtspsessionpool);