mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
gst/: Updated API
Original commit message from CVS: * gst/gst.defs: * gst/gst-types.defs: Updated API * gst/gstelement.override: _wrap_gst_element_get_state: made wrapper behave more like codegen-ed functions. It now only takes an int or long as optional timeout argument, and if there's no argument it will use GST_CLOCK_TIME_NONE * testsuite/test_bin.py: * testsuite/test_event.py: * testsuite/test_ghostpad.py: * testsuite/test_pipeline.py: Updated testsuites for element.get_state() modifications Added event parsing checks Commented out test_ghostpad.PipeTest.testProbedLink til I find out why "while self._handoffs < 10: pass" doesn't exit although it reaches values way over 10
This commit is contained in:
parent
a96098cba8
commit
b06c5a8a9e
8 changed files with 123 additions and 106 deletions
22
ChangeLog
22
ChangeLog
|
@ -1,3 +1,25 @@
|
||||||
|
2005-10-19 Edward Hervey <edward@fluendo.com>
|
||||||
|
|
||||||
|
* gst/gst.defs:
|
||||||
|
* gst/gst-types.defs:
|
||||||
|
Updated API
|
||||||
|
|
||||||
|
* gst/gstelement.override:
|
||||||
|
_wrap_gst_element_get_state: made wrapper behave more like codegen-ed
|
||||||
|
functions.
|
||||||
|
It now only takes an int or long as optional timeout argument, and if
|
||||||
|
there's no argument it will use GST_CLOCK_TIME_NONE
|
||||||
|
|
||||||
|
* testsuite/test_bin.py:
|
||||||
|
* testsuite/test_event.py:
|
||||||
|
* testsuite/test_ghostpad.py:
|
||||||
|
* testsuite/test_pipeline.py:
|
||||||
|
Updated testsuites for element.get_state() modifications
|
||||||
|
Added event parsing checks
|
||||||
|
Commented out test_ghostpad.PipeTest.testProbedLink til I find out why
|
||||||
|
"while self._handoffs < 10: pass" doesn't exit although it reaches
|
||||||
|
values way over 10
|
||||||
|
|
||||||
2005-10-19 Thomas Vander Stichele <thomas at apestaart dot org>
|
2005-10-19 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
* gst/gst.defs:
|
* gst/gst.defs:
|
||||||
|
|
|
@ -346,7 +346,6 @@
|
||||||
'("locked-state" "GST_ELEMENT_LOCKED_STATE")
|
'("locked-state" "GST_ELEMENT_LOCKED_STATE")
|
||||||
'("is-sink" "GST_ELEMENT_IS_SINK")
|
'("is-sink" "GST_ELEMENT_IS_SINK")
|
||||||
'("unparenting" "GST_ELEMENT_UNPARENTING")
|
'("unparenting" "GST_ELEMENT_UNPARENTING")
|
||||||
'("changing-state" "GST_ELEMENT_CHANGING_STATE")
|
|
||||||
'("flag-last" "GST_ELEMENT_FLAG_LAST")
|
'("flag-last" "GST_ELEMENT_FLAG_LAST")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
@ -637,6 +636,7 @@
|
||||||
'("tag" "GST_MESSAGE_TAG")
|
'("tag" "GST_MESSAGE_TAG")
|
||||||
'("buffering" "GST_MESSAGE_BUFFERING")
|
'("buffering" "GST_MESSAGE_BUFFERING")
|
||||||
'("state-changed" "GST_MESSAGE_STATE_CHANGED")
|
'("state-changed" "GST_MESSAGE_STATE_CHANGED")
|
||||||
|
'("state-dirty" "GST_MESSAGE_STATE_DIRTY")
|
||||||
'("step-done" "GST_MESSAGE_STEP_DONE")
|
'("step-done" "GST_MESSAGE_STEP_DONE")
|
||||||
'("clock-provide" "GST_MESSAGE_CLOCK_PROVIDE")
|
'("clock-provide" "GST_MESSAGE_CLOCK_PROVIDE")
|
||||||
'("clock-lost" "GST_MESSAGE_CLOCK_LOST")
|
'("clock-lost" "GST_MESSAGE_CLOCK_LOST")
|
||||||
|
@ -647,6 +647,7 @@
|
||||||
'("element" "GST_MESSAGE_ELEMENT")
|
'("element" "GST_MESSAGE_ELEMENT")
|
||||||
'("segment-start" "GST_MESSAGE_SEGMENT_START")
|
'("segment-start" "GST_MESSAGE_SEGMENT_START")
|
||||||
'("segment-done" "GST_MESSAGE_SEGMENT_DONE")
|
'("segment-done" "GST_MESSAGE_SEGMENT_DONE")
|
||||||
|
'("duration" "GST_MESSAGE_DURATION")
|
||||||
'("any" "GST_MESSAGE_ANY")
|
'("any" "GST_MESSAGE_ANY")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
101
gst/gst.defs
101
gst/gst.defs
|
@ -35,6 +35,22 @@
|
||||||
(return-type "none")
|
(return-type "none")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
(define-function version
|
||||||
|
(c-name "gst_version")
|
||||||
|
(return-type "none")
|
||||||
|
(parameters
|
||||||
|
'("guint*" "major")
|
||||||
|
'("guint*" "minor")
|
||||||
|
'("guint*" "micro")
|
||||||
|
'("guint*" "nano")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
(define-function version_string
|
||||||
|
(c-name "gst_version_string")
|
||||||
|
(return-type "gchar*")
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
;; From ../gstreamer/gst/gstbin.h
|
;; From ../gstreamer/gst/gstbin.h
|
||||||
|
@ -479,7 +495,7 @@
|
||||||
(define-method get_size
|
(define-method get_size
|
||||||
(of-object "GstCaps")
|
(of-object "GstCaps")
|
||||||
(c-name "gst_caps_get_size")
|
(c-name "gst_caps_get_size")
|
||||||
(return-type "int")
|
(return-type "guint")
|
||||||
)
|
)
|
||||||
|
|
||||||
(define-method get_structure
|
(define-method get_structure
|
||||||
|
@ -487,7 +503,7 @@
|
||||||
(c-name "gst_caps_get_structure")
|
(c-name "gst_caps_get_structure")
|
||||||
(return-type "GstStructure*")
|
(return-type "GstStructure*")
|
||||||
(parameters
|
(parameters
|
||||||
'("int" "index")
|
'("guint" "index")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -497,7 +513,7 @@
|
||||||
(return-type "GstCaps*")
|
(return-type "GstCaps*")
|
||||||
(caller-owns-return #t)
|
(caller-owns-return #t)
|
||||||
(parameters
|
(parameters
|
||||||
'("gint" "nth")
|
'("guint" "nth")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -1301,7 +1317,7 @@
|
||||||
(define-method get_uri_type
|
(define-method get_uri_type
|
||||||
(of-object "GstElementFactory")
|
(of-object "GstElementFactory")
|
||||||
(c-name "gst_element_factory_get_uri_type")
|
(c-name "gst_element_factory_get_uri_type")
|
||||||
(return-type "guint")
|
(return-type "gint")
|
||||||
)
|
)
|
||||||
|
|
||||||
(define-method get_uri_protocols
|
(define-method get_uri_protocols
|
||||||
|
@ -2530,49 +2546,6 @@
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
;; From ../gstreamer/gst/gstmemchunk.h
|
|
||||||
|
|
||||||
(define-function gst_mem_chunk_new
|
|
||||||
(c-name "gst_mem_chunk_new")
|
|
||||||
(is-constructor-of "GstMemChunk")
|
|
||||||
(return-type "GstMemChunk*")
|
|
||||||
(parameters
|
|
||||||
'("gchar*" "name")
|
|
||||||
'("gint" "atom_size")
|
|
||||||
'("gulong" "area_size")
|
|
||||||
'("gint" "type")
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method destroy
|
|
||||||
(of-object "GstMemChunk")
|
|
||||||
(c-name "gst_mem_chunk_destroy")
|
|
||||||
(return-type "none")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method alloc
|
|
||||||
(of-object "GstMemChunk")
|
|
||||||
(c-name "gst_mem_chunk_alloc")
|
|
||||||
(return-type "gpointer")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method alloc0
|
|
||||||
(of-object "GstMemChunk")
|
|
||||||
(c-name "gst_mem_chunk_alloc0")
|
|
||||||
(return-type "gpointer")
|
|
||||||
)
|
|
||||||
|
|
||||||
(define-method free
|
|
||||||
(of-object "GstMemChunk")
|
|
||||||
(c-name "gst_mem_chunk_free")
|
|
||||||
(return-type "none")
|
|
||||||
(parameters
|
|
||||||
'("gpointer" "mem")
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
;; From ../gstreamer/gst/gstmessage.h
|
;; From ../gstreamer/gst/gstmessage.h
|
||||||
|
|
||||||
(define-function gst_message_get_type
|
(define-function gst_message_get_type
|
||||||
|
@ -2645,6 +2618,14 @@
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
(define-function gst_message_new_state_dirty
|
||||||
|
(c-name "gst_message_new_state_dirty")
|
||||||
|
(return-type "GstMessage*")
|
||||||
|
(parameters
|
||||||
|
'("GstObject*" "src")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
(define-function gst_message_new_clock_provide
|
(define-function gst_message_new_clock_provide
|
||||||
(c-name "gst_message_new_clock_provide")
|
(c-name "gst_message_new_clock_provide")
|
||||||
(return-type "GstMessage*")
|
(return-type "GstMessage*")
|
||||||
|
@ -2713,6 +2694,16 @@
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
(define-function gst_message_new_duration
|
||||||
|
(c-name "gst_message_new_duration")
|
||||||
|
(return-type "GstMessage*")
|
||||||
|
(parameters
|
||||||
|
'("GstObject*" "src")
|
||||||
|
'("GstFormat" "format")
|
||||||
|
'("gint64" "duration")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
(define-function message_new_custom
|
(define-function message_new_custom
|
||||||
(c-name "gst_message_new_custom")
|
(c-name "gst_message_new_custom")
|
||||||
(return-type "GstMessage*")
|
(return-type "GstMessage*")
|
||||||
|
@ -2797,7 +2788,8 @@
|
||||||
(c-name "gst_message_parse_segment_start")
|
(c-name "gst_message_parse_segment_start")
|
||||||
(return-type "none")
|
(return-type "none")
|
||||||
(parameters
|
(parameters
|
||||||
'("GstClockTime*" "timestamp")
|
'("GstFormat*" "format")
|
||||||
|
'("gint64*" "position")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -2806,7 +2798,18 @@
|
||||||
(c-name "gst_message_parse_segment_done")
|
(c-name "gst_message_parse_segment_done")
|
||||||
(return-type "none")
|
(return-type "none")
|
||||||
(parameters
|
(parameters
|
||||||
'("GstClockTime*" "timestamp")
|
'("GstFormat*" "format")
|
||||||
|
'("gint64*" "position")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
(define-method parse_duration
|
||||||
|
(of-object "GstMessage")
|
||||||
|
(c-name "gst_message_parse_duration")
|
||||||
|
(return-type "none")
|
||||||
|
(parameters
|
||||||
|
'("GstFormat*" "format")
|
||||||
|
'("gint64*" "duration")
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -81,33 +81,22 @@ _wrap_gst_element_get_state(PyGObject *self, PyObject *args, PyObject *kwargs)
|
||||||
GstState state;
|
GstState state;
|
||||||
GstState pending;
|
GstState pending;
|
||||||
GstStateChangeReturn ret;
|
GstStateChangeReturn ret;
|
||||||
PyObject *timeout = NULL;
|
GstClockTime timeout = GST_CLOCK_TIME_NONE;
|
||||||
GstClockTime timeout64 = GST_CLOCK_TIME_NONE;
|
|
||||||
PyObject *tuple;
|
PyObject *tuple;
|
||||||
|
|
||||||
if (!PyArg_ParseTupleAndKeywords(args, kwargs,
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs,
|
||||||
"|O:GstElement.get_state", kwlist,
|
"|K:GstElement.get_state", kwlist,
|
||||||
&timeout)) {
|
&timeout)) {
|
||||||
PyErr_SetString(PyExc_RuntimeError, "Timeout not specified correctly");
|
PyErr_SetString(PyExc_RuntimeError, "Timeout not specified correctly");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (timeout == Py_None) {
|
|
||||||
/* infinite timeout */
|
|
||||||
timeout64 = GST_CLOCK_TIME_NONE;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (!PyLong_Check (timeout)) {
|
|
||||||
PyErr_SetString(PyExc_TypeError, "timeout not specified as a long");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
timeout64 = PyLong_AsLong (timeout);
|
|
||||||
|
|
||||||
}
|
GST_DEBUG ("timeout:%lld", timeout);
|
||||||
|
|
||||||
pyg_begin_allow_threads;
|
pyg_begin_allow_threads;
|
||||||
|
|
||||||
ret = gst_element_get_state(GST_ELEMENT (self->obj), &state, &pending,
|
ret = gst_element_get_state(GST_ELEMENT (self->obj), &state, &pending,
|
||||||
timeout64);
|
timeout);
|
||||||
|
|
||||||
pyg_end_allow_threads;
|
pyg_end_allow_threads;
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ class BinSubclassTest(TestCase):
|
||||||
self.assertEquals(bin.__gstrefcount__, 1)
|
self.assertEquals(bin.__gstrefcount__, 1)
|
||||||
|
|
||||||
# test get_state with no timeout
|
# test get_state with no timeout
|
||||||
(ret, state, pending) = bin.get_state(None)
|
(ret, state, pending) = bin.get_state()
|
||||||
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
||||||
self.assertEquals(bin.__gstrefcount__, 1)
|
self.assertEquals(bin.__gstrefcount__, 1)
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ class BinSubclassTest(TestCase):
|
||||||
self.failUnless(bin._state_changed)
|
self.failUnless(bin._state_changed)
|
||||||
|
|
||||||
# test get_state with no timeout
|
# test get_state with no timeout
|
||||||
(ret, state, pending) = bin.get_state(None)
|
(ret, state, pending) = bin.get_state()
|
||||||
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
||||||
|
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS:
|
if ret == gst.STATE_CHANGE_SUCCESS:
|
||||||
|
@ -83,14 +83,14 @@ class BinSubclassTest(TestCase):
|
||||||
self.assertEquals(pending, gst.STATE_VOID_PENDING)
|
self.assertEquals(pending, gst.STATE_VOID_PENDING)
|
||||||
|
|
||||||
# test get_state with a timeout
|
# test get_state with a timeout
|
||||||
(ret, state, pending) = bin.get_state(0.1)
|
(ret, state, pending) = bin.get_state(1)
|
||||||
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
self.failIfEqual(ret, gst.STATE_CHANGE_FAILURE)
|
||||||
|
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS:
|
if ret == gst.STATE_CHANGE_SUCCESS:
|
||||||
self.assertEquals(state, gst.STATE_PLAYING)
|
self.assertEquals(state, gst.STATE_PLAYING)
|
||||||
self.assertEquals(pending, gst.STATE_VOID_PENDING)
|
self.assertEquals(pending, gst.STATE_VOID_PENDING)
|
||||||
|
|
||||||
(ret, state, pending) = bin.get_state(timeout=0.1)
|
(ret, state, pending) = bin.get_state(timeout=gst.SECOND)
|
||||||
|
|
||||||
# back to NULL
|
# back to NULL
|
||||||
bin.set_state(gst.STATE_NULL)
|
bin.set_state(gst.STATE_NULL)
|
||||||
|
@ -146,7 +146,7 @@ class Preroll(TestCase):
|
||||||
|
|
||||||
# bin will go to paused, src pad task will start and error out
|
# bin will go to paused, src pad task will start and error out
|
||||||
self.bin.set_state(gst.STATE_PAUSED)
|
self.bin.set_state(gst.STATE_PAUSED)
|
||||||
ret = self.bin.get_state(timeout=None)
|
ret = self.bin.get_state()
|
||||||
self.assertEquals(ret[0], gst.STATE_CHANGE_SUCCESS)
|
self.assertEquals(ret[0], gst.STATE_CHANGE_SUCCESS)
|
||||||
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
||||||
self.assertEquals(ret[2], gst.STATE_VOID_PENDING)
|
self.assertEquals(ret[2], gst.STATE_VOID_PENDING)
|
||||||
|
@ -155,7 +155,7 @@ class Preroll(TestCase):
|
||||||
gst.debug('adding sink and setting to PAUSED, should cause preroll')
|
gst.debug('adding sink and setting to PAUSED, should cause preroll')
|
||||||
self.bin.add(sink)
|
self.bin.add(sink)
|
||||||
sink.set_state(gst.STATE_PAUSED)
|
sink.set_state(gst.STATE_PAUSED)
|
||||||
ret = self.bin.get_state(timeout=0.0)
|
ret = self.bin.get_state(timeout=0)
|
||||||
self.assertEquals(ret[0], gst.STATE_CHANGE_ASYNC)
|
self.assertEquals(ret[0], gst.STATE_CHANGE_ASYNC)
|
||||||
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
||||||
self.assertEquals(ret[2], gst.STATE_PAUSED)
|
self.assertEquals(ret[2], gst.STATE_PAUSED)
|
||||||
|
@ -164,13 +164,13 @@ class Preroll(TestCase):
|
||||||
src.set_state(gst.STATE_READY)
|
src.set_state(gst.STATE_READY)
|
||||||
src.link(sink)
|
src.link(sink)
|
||||||
src.set_state(gst.STATE_PAUSED)
|
src.set_state(gst.STATE_PAUSED)
|
||||||
ret = self.bin.get_state(timeout=None)
|
ret = self.bin.get_state()
|
||||||
self.assertEquals(ret[0], gst.STATE_CHANGE_SUCCESS)
|
self.assertEquals(ret[0], gst.STATE_CHANGE_SUCCESS)
|
||||||
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
self.assertEquals(ret[1], gst.STATE_PAUSED)
|
||||||
self.assertEquals(ret[2], gst.STATE_VOID_PENDING)
|
self.assertEquals(ret[2], gst.STATE_VOID_PENDING)
|
||||||
|
|
||||||
self.bin.set_state(gst.STATE_NULL)
|
self.bin.set_state(gst.STATE_NULL)
|
||||||
self.bin.get_state(timeout=None)
|
self.bin.get_state()
|
||||||
|
|
||||||
class ConstructorTest(TestCase):
|
class ConstructorTest(TestCase):
|
||||||
def testGood(self):
|
def testGood(self):
|
||||||
|
|
|
@ -53,6 +53,9 @@ class EventTest(TestCase):
|
||||||
self.sink.send_event(event)
|
self.sink.send_event(event)
|
||||||
gst.debug('sent event')
|
gst.debug('sent event')
|
||||||
|
|
||||||
|
self.assertEqual(event.parse_seek(), [1.0, gst.FORMAT_BYTES, gst.SEEK_FLAG_FLUSH,
|
||||||
|
gst.SEEK_TYPE_SET, 0, gst.SEEK_TYPE_NONE, 0])
|
||||||
|
|
||||||
def testWrongEvent(self):
|
def testWrongEvent(self):
|
||||||
buffer = gst.Buffer()
|
buffer = gst.Buffer()
|
||||||
self.assertRaises(TypeError, self.sink.send_event, buffer)
|
self.assertRaises(TypeError, self.sink.send_event, buffer)
|
||||||
|
|
|
@ -102,7 +102,7 @@ class PipeTest(TestCase):
|
||||||
|
|
||||||
self.pipeline.set_state(gst.STATE_PLAYING)
|
self.pipeline.set_state(gst.STATE_PLAYING)
|
||||||
while True:
|
while True:
|
||||||
(ret, cur, pen) = self.pipeline.get_state(timeout=None)
|
(ret, cur, pen) = self.pipeline.get_state()
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_PLAYING:
|
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_PLAYING:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
@ -111,41 +111,40 @@ class PipeTest(TestCase):
|
||||||
|
|
||||||
self.pipeline.set_state(gst.STATE_NULL)
|
self.pipeline.set_state(gst.STATE_NULL)
|
||||||
while True:
|
while True:
|
||||||
(ret, cur, pen) = self.pipeline.get_state(timeout=None)
|
(ret, cur, pen) = self.pipeline.get_state()
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_NULL:
|
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_NULL:
|
||||||
break
|
break
|
||||||
|
|
||||||
def testProbedLink(self):
|
## def testProbedLink(self):
|
||||||
self.pipeline.add(self.src)
|
## self.pipeline.add(self.src)
|
||||||
pad = self.src.get_pad("src")
|
## pad = self.src.get_pad("src")
|
||||||
|
|
||||||
self.sink.connect_handoff(self._sink_handoff_cb)
|
## self.sink.connect_handoff(self._sink_handoff_cb)
|
||||||
self._handoffs = 0
|
## self._handoffs = 0
|
||||||
|
|
||||||
# FIXME: adding a probe to the ghost pad does not work atm
|
## # FIXME: adding a probe to the ghost pad does not work atm
|
||||||
# id = pad.add_buffer_probe(self._src_buffer_probe_cb)
|
## # id = pad.add_buffer_probe(self._src_buffer_probe_cb)
|
||||||
realpad = pad.get_target()
|
## realpad = pad.get_target()
|
||||||
self._probe_id = realpad.add_buffer_probe(self._src_buffer_probe_cb)
|
## self._probe_id = realpad.add_buffer_probe(self._src_buffer_probe_cb)
|
||||||
|
|
||||||
self._probed = False
|
## self._probed = False
|
||||||
|
|
||||||
self.pipeline.set_state(gst.STATE_PLAYING)
|
## while True:
|
||||||
while True:
|
## (ret, cur, pen) = self.pipeline.get_state()
|
||||||
(ret, cur, pen) = self.pipeline.get_state(timeout=None)
|
## if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_PLAYING:
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_PLAYING:
|
## break
|
||||||
break
|
|
||||||
|
|
||||||
while not self._probed:
|
## while not self._probed:
|
||||||
pass
|
## pass
|
||||||
|
|
||||||
while self._handoffs < 10:
|
## while self._handoffs < 10:
|
||||||
pass
|
## pass
|
||||||
|
|
||||||
self.pipeline.set_state(gst.STATE_NULL)
|
## self.pipeline.set_state(gst.STATE_NULL)
|
||||||
while True:
|
## while True:
|
||||||
(ret, cur, pen) = self.pipeline.get_state(timeout=None)
|
## (ret, cur, pen) = self.pipeline.get_state()
|
||||||
if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_NULL:
|
## if ret == gst.STATE_CHANGE_SUCCESS and cur == gst.STATE_NULL:
|
||||||
break
|
## break
|
||||||
|
|
||||||
def _src_buffer_probe_cb(self, pad, buffer):
|
def _src_buffer_probe_cb(self, pad, buffer):
|
||||||
gst.debug("received probe on pad %r" % pad)
|
gst.debug("received probe on pad %r" % pad)
|
||||||
|
@ -157,7 +156,7 @@ class PipeTest(TestCase):
|
||||||
gst.debug('setting sink state')
|
gst.debug('setting sink state')
|
||||||
|
|
||||||
# FIXME: attempt one: sync to current pending state of bin
|
# FIXME: attempt one: sync to current pending state of bin
|
||||||
(res, cur, pen) = self.pipeline.get_state(timeout=0.0)
|
(res, cur, pen) = self.pipeline.get_state(timeout=0)
|
||||||
target = pen
|
target = pen
|
||||||
if target == gst.STATE_VOID_PENDING:
|
if target == gst.STATE_VOID_PENDING:
|
||||||
target = cur
|
target = cur
|
||||||
|
@ -174,7 +173,7 @@ class PipeTest(TestCase):
|
||||||
self._probe_id = None
|
self._probe_id = None
|
||||||
gst.debug('done')
|
gst.debug('done')
|
||||||
|
|
||||||
def _sink_handoff_cb(self, sink, pad, buffer):
|
def _sink_handoff_cb(self, sink, buffer, pad):
|
||||||
gst.debug('received handoff on pad %r' % pad)
|
gst.debug('received handoff on pad %r' % pad)
|
||||||
self._handoffs += 1
|
self._handoffs += 1
|
||||||
|
|
||||||
|
|
|
@ -63,15 +63,15 @@ class Pipeline(TestCase):
|
||||||
self.gcverify()
|
self.gcverify()
|
||||||
|
|
||||||
def testRun(self):
|
def testRun(self):
|
||||||
self.assertEqual(self.pipeline.get_state(None)[1], gst.STATE_NULL)
|
self.assertEqual(self.pipeline.get_state()[1], gst.STATE_NULL)
|
||||||
self.pipeline.set_state(gst.STATE_PLAYING)
|
self.pipeline.set_state(gst.STATE_PLAYING)
|
||||||
self.assertEqual(self.pipeline.get_state(None)[1], gst.STATE_PLAYING)
|
self.assertEqual(self.pipeline.get_state()[1], gst.STATE_PLAYING)
|
||||||
|
|
||||||
time.sleep(1)
|
time.sleep(1)
|
||||||
|
|
||||||
self.assertEqual(self.pipeline.get_state(None)[1], gst.STATE_PLAYING)
|
self.assertEqual(self.pipeline.get_state()[1], gst.STATE_PLAYING)
|
||||||
self.pipeline.set_state(gst.STATE_NULL)
|
self.pipeline.set_state(gst.STATE_NULL)
|
||||||
self.assertEqual(self.pipeline.get_state(None)[1], gst.STATE_NULL)
|
self.assertEqual(self.pipeline.get_state()[1], gst.STATE_NULL)
|
||||||
|
|
||||||
class Bus(TestCase):
|
class Bus(TestCase):
|
||||||
def testGet(self):
|
def testGet(self):
|
||||||
|
|
Loading…
Reference in a new issue