#define log( ... ) printf( "testapi: " __VA_ARGS__ );
+/* test if we have exception */
+static bool have_exception (void)
+{
+ if (libvlc_exception_raised (&ex))
+ {
+ libvlc_exception_clear (&ex);
+ return true;
+ }
+ else
+ return false;
+}
+
static void catch (void)
{
if (libvlc_exception_raised (&ex))
static void test_media_list (const char ** argv, int argc);
static void test_events (const char ** argv, int argc);
static void test_media_player_play_stop(const char** argv, int argc);
+static void test_media_player_pause_stop(const char** argv, int argc);
+static void test_media_list_player_pause_stop(const char** argv, int argc);
/* Tests implementations */
static void test_core (const char ** argv, int argc)
static void test_media_list (const char ** argv, int argc)
{
libvlc_instance_t *vlc;
- libvlc_media_descriptor_t *md;
+ libvlc_media_t *md1, *md2, *md3, *md4;
libvlc_media_list_t *ml;
log ("Testing media_list\n");
ml = libvlc_media_list_new (vlc, &ex);
catch ();
- md = libvlc_media_descriptor_new (vlc, "/dev/null", &ex);
+ md1 = libvlc_media_new (vlc, "/dev/null", &ex);
+ catch ();
+ md2 = libvlc_media_new (vlc, "/dev/null", &ex);
+ catch ();
+ md3 = libvlc_media_new (vlc, "/dev/null", &ex);
catch ();
- libvlc_media_list_add_media_descriptor (ml, md, &ex);
+ libvlc_media_list_add_media (ml, md1, &ex);
catch ();
- libvlc_media_list_add_media_descriptor (ml, md, &ex);
+ libvlc_media_list_add_media (ml, md2, &ex);
catch ();
assert( libvlc_media_list_count (ml, &ex) == 2 );
catch ();
- libvlc_media_descriptor_release (md);
+ assert( libvlc_media_list_index_of_item (ml, md1, &ex) == 0 );
+ catch ();
+
+ assert( libvlc_media_list_index_of_item (ml, md2, &ex) == 1 );
+ catch ();
+
+ libvlc_media_list_remove_index (ml, 0, &ex); /* removing first item */
+ catch ();
+
+ /* test if second item was moved on first place */
+ assert( libvlc_media_list_index_of_item (ml, md2, &ex) == 0 );
+ catch ();
+
+ libvlc_media_list_add_media (ml, md1, &ex); /* add 2 items */
+ catch ();
+ libvlc_media_list_add_media (ml, md1, &ex);
+ catch ();
+
+ /* there should be 3 pieces */
+ assert( libvlc_media_list_count (ml, &ex) == 3 );
+ catch ();
+
+ libvlc_media_list_insert_media (ml, md3, 2, &ex);
+ catch ();
+
+ /* there should be 4 pieces */
+ assert( libvlc_media_list_count (ml, &ex) == 4 );
+ catch ();
+
+ /* test inserting on right place */
+ assert( libvlc_media_list_index_of_item (ml, md3, &ex) == 2 );
+ catch ();
+
+ /* test right returning descriptor*/
+ assert ( libvlc_media_list_item_at_index (ml, 0, &ex) == md2 );
+ catch ();
+
+ assert ( libvlc_media_list_item_at_index (ml, 2, &ex) == md3 );
+ catch ();
+
+ /* test if give exceptions, when it should */
+ /* have 4 items, so index 4 should give exception */
+ libvlc_media_list_remove_index (ml, 4, &ex);
+ assert (have_exception ());
+
+ libvlc_media_list_remove_index (ml, 100, &ex);
+ assert (have_exception ());
+
+ libvlc_media_list_remove_index (ml, -1, &ex);
+ assert (have_exception ());
+
+ /* getting non valid items */
+ libvlc_media_t * p_non_exist =
+ libvlc_media_list_item_at_index (ml, 4, &ex);
+ assert (have_exception ());
+
+ p_non_exist = libvlc_media_list_item_at_index (ml, 100, &ex);
+ assert (have_exception ());
+
+ p_non_exist = libvlc_media_list_item_at_index (ml, -1, &ex);
+ assert (have_exception ());
+
+ md4 = libvlc_media_new (vlc, "/dev/dsp", &ex);
+ catch ();
+
+ /* try to find non inserted item */
+ int i_non_exist = 0;
+ i_non_exist = libvlc_media_list_index_of_item (ml, md4, &ex);
+ assert ( i_non_exist == -1 );
+
+ libvlc_media_release (md1);
+ libvlc_media_release (md2);
+ libvlc_media_release (md3);
+ libvlc_media_release (md4);
libvlc_media_list_release (ml);
vlc_bool_t * callback_was_called = user_data;
libvlc_event_manager_t *em;
- em = libvlc_media_instance_event_manager (event->p_obj, &ex);
+ em = libvlc_media_player_event_manager (event->p_obj, &ex);
catch();
libvlc_event_detach (em, event->type, test_events_callback_and_detach, user_data, &ex);
static void test_events (const char ** argv, int argc)
{
libvlc_instance_t *vlc;
- libvlc_media_instance_t *mi;
+ libvlc_media_player_t *mi;
libvlc_event_manager_t *em;
vlc_bool_t callback_was_called;
libvlc_exception_t ex;
libvlc_event_type_t mi_events[] = {
- libvlc_MediaInstancePlayed,
- libvlc_MediaInstancePaused,
- libvlc_MediaInstanceReachedEnd,
- libvlc_MediaInstanceEncounteredError,
- libvlc_MediaInstanceTimeChanged,
- libvlc_MediaInstancePositionChanged,
+ libvlc_MediaPlayerPlayed,
+ libvlc_MediaPlayerPaused,
+ libvlc_MediaPlayerEndReached,
+ libvlc_MediaPlayerStopped,
+ libvlc_MediaPlayerEncounteredError,
+ libvlc_MediaPlayerTimeChanged,
+ libvlc_MediaPlayerPositionChanged,
};
int i, mi_events_len = sizeof(mi_events)/sizeof(*mi_events);
vlc = libvlc_new (argc, argv, &ex);
catch ();
- mi = libvlc_media_instance_new (vlc, &ex);
+ mi = libvlc_media_player_new (vlc, &ex);
catch ();
- em = libvlc_media_instance_event_manager (mi, &ex);
+ em = libvlc_media_player_event_manager (mi, &ex);
log ("+ Testing attaching to Media Instance\n");
catch ();
}
- libvlc_media_instance_release (mi);
+ libvlc_media_player_release (mi);
catch ();
libvlc_release (vlc);
static void test_media_player_play_stop(const char** argv, int argc)
{
+#if 0
libvlc_instance_t *vlc;
- libvlc_media_descriptor_t *md;
- libvlc_media_instance_t *mi;
+ libvlc_media_t *md;
+ libvlc_media_player_t *mi;
const char * file = "file://../bindings/java/core/src/test/resources/raffa_voice.ogg";
log ("Testing play and pause of %s\n", file);
vlc = libvlc_new (argc, argv, &ex);
catch ();
- md = libvlc_media_descriptor_new (vlc, file, &ex);
+ md = libvlc_media_new (vlc, file, &ex);
catch ();
- mi = libvlc_media_instance_new_from_media_descriptor (md, &ex);
+ mi = libvlc_media_player_new_from_media (md, &ex);
catch ();
- libvlc_media_descriptor_release (md);
+ libvlc_media_release (md);
- libvlc_media_instance_play (mi, &ex);
+ libvlc_media_player_play (mi, &ex);
catch ();
/* FIXME: Do something clever */
sleep(1);
- assert( libvlc_media_instance_get_state (mi, &ex) != libvlc_Error );
+ assert( libvlc_media_player_get_state (mi, &ex) != libvlc_Error );
+ catch ();
+
+ libvlc_media_player_stop (mi, &ex);
catch ();
- libvlc_media_instance_stop (mi, &ex);
+ libvlc_media_player_release (mi);
catch ();
+
+ libvlc_release (vlc);
+ catch ();
+#endif
+}
+
+static void test_media_player_pause_stop(const char** argv, int argc)
+{
+ libvlc_instance_t *vlc;
+ libvlc_media_t *md;
+ libvlc_media_player_t *mi;
+ const char * file = "file://../bindings/java/core/src/test/resources/raffa_voice.ogg";
+
+ log ("Testing play and pause of %s\n", file);
+
+ libvlc_exception_init (&ex);
+ vlc = libvlc_new (argc, argv, &ex);
+ catch ();
+
+ md = libvlc_media_new (vlc, file, &ex);
+ catch ();
+
+ mi = libvlc_media_player_new_from_media (md, &ex);
+ catch ();
+
+ libvlc_media_release (md);
+
+ libvlc_media_player_play (mi, &ex);
+ catch ();
+
+ /* FIXME: Do something clever */
sleep(1);
- libvlc_media_instance_release (mi);
+ assert( libvlc_media_player_get_state (mi, &ex) == libvlc_Playing );
+ catch ();
+
+ libvlc_media_player_pause (mi, &ex);
+ assert( libvlc_media_player_get_state (mi, &ex) == libvlc_Paused );
+ catch();
+
+ libvlc_media_player_stop (mi, &ex);
+ catch ();
+
+ libvlc_media_player_release (mi);
+ catch ();
+
+ libvlc_release (vlc);
+ catch ();
+}
+
+static void test_media_list_player_pause_stop(const char** argv, int argc)
+{
+ libvlc_instance_t *vlc;
+ libvlc_media_t *md;
+ libvlc_media_list_t *ml;
+ libvlc_media_list_player_t *mlp;
+
+ const char * file = "file://../bindings/java/core/src/test/resources/raffa_voice.ogg";
+
+ log ("Testing play and pause of %s using the media list.\n", file);
+
+ libvlc_exception_init (&ex);
+ vlc = libvlc_new (argc, argv, &ex);
+ catch ();
+
+ md = libvlc_media_new (vlc, file, &ex);
+ catch ();
+
+ ml = libvlc_media_list_new (vlc, &ex);
+ catch ();
+
+ mlp = libvlc_media_list_player_new (vlc, &ex);
+
+ libvlc_media_list_add_media( ml, md, &ex );
+ catch ();
+
+ libvlc_media_list_player_set_media_list( mlp, ml, &ex );
+
+ libvlc_media_list_player_play_item( mlp, md, &ex );
+ sleep(1); // play is asynchronous
+ catch ();
+
+ libvlc_media_list_player_pause (mlp, &ex);
+ catch();
+
+ libvlc_media_list_player_stop (mlp, &ex);
+ catch ();
+
+ libvlc_media_release (md);
+
+ libvlc_media_list_player_release (mlp);
catch ();
libvlc_release (vlc);
catch ();
}
+
+
int main (int argc, char *argv[])
{
const char *args[argc + 5];
test_media_player_play_stop(args, nlibvlc_args);
+ test_media_player_pause_stop(args, nlibvlc_args);
+
+ test_media_list_player_pause_stop(args, nlibvlc_args);
+
return 0;
}