mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 00:28:21 +00:00
gst/gstutils.c: Fix memleak (#351502).
Original commit message from CVS: * gst/gstutils.c: (gst_util_set_value_from_string): Fix memleak (#351502). * tests/check/gst/gstutils.c: (GST_START_TEST), (gst_utils_suite): Add unit test for most of gst_util_set_value_from_string() (not that one would want to encourage use of this function).
This commit is contained in:
parent
8e2f05d8ce
commit
a8714f5195
3 changed files with 139 additions and 1 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
2006-08-15 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* gst/gstutils.c: (gst_util_set_value_from_string):
|
||||||
|
Fix memleak (#351502).
|
||||||
|
|
||||||
|
* tests/check/gst/gstutils.c: (GST_START_TEST), (gst_utils_suite):
|
||||||
|
Add unit test for most of gst_util_set_value_from_string()
|
||||||
|
(not that one would want to encourage use of this function).
|
||||||
|
|
||||||
2006-08-15 Tim-Philipp Müller <tim at centricular dot net>
|
2006-08-15 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* libs/gst/check/gstcheck.h:
|
* libs/gst/check/gstcheck.h:
|
||||||
|
|
|
@ -99,7 +99,7 @@ gst_util_set_value_from_string (GValue * value, const gchar * value_str)
|
||||||
|
|
||||||
switch (G_VALUE_TYPE (value)) {
|
switch (G_VALUE_TYPE (value)) {
|
||||||
case G_TYPE_STRING:
|
case G_TYPE_STRING:
|
||||||
g_value_set_string (value, g_strdup (value_str));
|
g_value_set_string (value, value_str);
|
||||||
break;
|
break;
|
||||||
case G_TYPE_ENUM:
|
case G_TYPE_ENUM:
|
||||||
case G_TYPE_INT:{
|
case G_TYPE_INT:{
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) <2005> Thomas Vander Stichele <thomas at apestaart dot org>
|
* Copyright (C) <2005> Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
* Copyright (C) <2006> Tim-Philipp Müller <tim centricular net>
|
||||||
*
|
*
|
||||||
* gstutils.c: Unit test for functions in gstutils
|
* gstutils.c: Unit test for functions in gstutils
|
||||||
*
|
*
|
||||||
|
@ -462,6 +463,133 @@ GST_START_TEST (test_element_unlink)
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
|
||||||
|
GST_START_TEST (test_set_value_from_string)
|
||||||
|
{
|
||||||
|
GValue val = { 0, };
|
||||||
|
|
||||||
|
/* g_return_if_fail */
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (NULL, "xyz"));
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_STRING);
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (&val, NULL));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => string */
|
||||||
|
g_value_init (&val, G_TYPE_STRING);
|
||||||
|
gst_util_set_value_from_string (&val, "Y00");
|
||||||
|
fail_unless (g_value_get_string (&val) != NULL);
|
||||||
|
fail_unless_equals_string (g_value_get_string (&val), "Y00");
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => int */
|
||||||
|
g_value_init (&val, G_TYPE_INT);
|
||||||
|
gst_util_set_value_from_string (&val, "987654321");
|
||||||
|
fail_unless (g_value_get_int (&val) == 987654321);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_INT);
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (&val, "xyz"));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => uint */
|
||||||
|
g_value_init (&val, G_TYPE_UINT);
|
||||||
|
gst_util_set_value_from_string (&val, "987654321");
|
||||||
|
fail_unless (g_value_get_uint (&val) == 987654321);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* CHECKME: is this really desired behaviour? (tpm) */
|
||||||
|
g_value_init (&val, G_TYPE_UINT);
|
||||||
|
gst_util_set_value_from_string (&val, "-999");
|
||||||
|
fail_unless (g_value_get_uint (&val) == ((guint) 0 - (guint) 999));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_UINT);
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (&val, "xyz"));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => long */
|
||||||
|
g_value_init (&val, G_TYPE_LONG);
|
||||||
|
gst_util_set_value_from_string (&val, "987654321");
|
||||||
|
fail_unless (g_value_get_long (&val) == 987654321);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_LONG);
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (&val, "xyz"));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => ulong */
|
||||||
|
g_value_init (&val, G_TYPE_ULONG);
|
||||||
|
gst_util_set_value_from_string (&val, "987654321");
|
||||||
|
fail_unless (g_value_get_ulong (&val) == 987654321);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* CHECKME: is this really desired behaviour? (tpm) */
|
||||||
|
g_value_init (&val, G_TYPE_ULONG);
|
||||||
|
gst_util_set_value_from_string (&val, "-999");
|
||||||
|
fail_unless (g_value_get_ulong (&val) == ((gulong) 0 - (gulong) 999));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_ULONG);
|
||||||
|
ASSERT_CRITICAL (gst_util_set_value_from_string (&val, "xyz"));
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => boolean */
|
||||||
|
g_value_init (&val, G_TYPE_BOOLEAN);
|
||||||
|
gst_util_set_value_from_string (&val, "true");
|
||||||
|
fail_unless_equals_int (g_value_get_boolean (&val), TRUE);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_BOOLEAN);
|
||||||
|
gst_util_set_value_from_string (&val, "TRUE");
|
||||||
|
fail_unless_equals_int (g_value_get_boolean (&val), TRUE);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_BOOLEAN);
|
||||||
|
gst_util_set_value_from_string (&val, "false");
|
||||||
|
fail_unless_equals_int (g_value_get_boolean (&val), FALSE);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_BOOLEAN);
|
||||||
|
gst_util_set_value_from_string (&val, "FALSE");
|
||||||
|
fail_unless_equals_int (g_value_get_boolean (&val), FALSE);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_BOOLEAN);
|
||||||
|
gst_util_set_value_from_string (&val, "bleh");
|
||||||
|
fail_unless_equals_int (g_value_get_boolean (&val), FALSE);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* string => float (yay, localisation issues involved) */
|
||||||
|
g_value_init (&val, G_TYPE_FLOAT);
|
||||||
|
gst_util_set_value_from_string (&val, "987.654");
|
||||||
|
fail_unless (g_value_get_float (&val) >= 987.653 &&
|
||||||
|
g_value_get_float (&val) <= 987.655);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_FLOAT);
|
||||||
|
gst_util_set_value_from_string (&val, "987,654");
|
||||||
|
fail_unless (g_value_get_float (&val) >= 987.653 &&
|
||||||
|
g_value_get_float (&val) <= 987.655);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
/* string => double (yay, localisation issues involved) */
|
||||||
|
g_value_init (&val, G_TYPE_DOUBLE);
|
||||||
|
gst_util_set_value_from_string (&val, "987.654");
|
||||||
|
fail_unless (g_value_get_double (&val) >= 987.653 &&
|
||||||
|
g_value_get_double (&val) <= 987.655);
|
||||||
|
g_value_unset (&val);
|
||||||
|
|
||||||
|
g_value_init (&val, G_TYPE_DOUBLE);
|
||||||
|
gst_util_set_value_from_string (&val, "987,654");
|
||||||
|
fail_unless (g_value_get_double (&val) >= 987.653 &&
|
||||||
|
g_value_get_double (&val) <= 987.655);
|
||||||
|
g_value_unset (&val);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_END_TEST;
|
||||||
|
|
||||||
Suite *
|
Suite *
|
||||||
gst_utils_suite (void)
|
gst_utils_suite (void)
|
||||||
{
|
{
|
||||||
|
@ -481,6 +609,7 @@ gst_utils_suite (void)
|
||||||
#endif
|
#endif
|
||||||
tcase_add_test (tc_chain, test_element_found_tags);
|
tcase_add_test (tc_chain, test_element_found_tags);
|
||||||
tcase_add_test (tc_chain, test_element_unlink);
|
tcase_add_test (tc_chain, test_element_unlink);
|
||||||
|
tcase_add_test (tc_chain, test_set_value_from_string);
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue