]> git.sesse.net Git - vlc/commitdiff
test: Add a test for media_player_next().
authorPierre d'Herbemont <pdherbemont@free.fr>
Thu, 21 May 2009 06:34:03 +0000 (23:34 -0700)
committerPierre d'Herbemont <pdherbemont@free.fr>
Thu, 21 May 2009 06:34:03 +0000 (23:34 -0700)
Doesn't work because variables callback can't be removed from their own callbacks.
Some work will be required here.

test/libvlc/media_list_player.c

index 5ae0c27b56d100ddc2eb300b01121d0a1dc2b350..fbc67bf8a21d49a0bf01cc37e65d2861051c462a 100644 (file)
 
 #include "test.h"
 
+static void media_list_add_file_path(libvlc_instance_t *vlc, libvlc_media_list_t *ml, const char * file_path)
+{
+    libvlc_media_t *md = libvlc_media_new (vlc, file_path, &ex);
+    catch ();
+
+    libvlc_media_list_add_media (ml, md, &ex);
+    catch ();
+
+    libvlc_media_release (md);
+}
+
+static void test_media_list_player_next(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 = test_default_sample;
+    
+    log ("Testing media player next()\n");
+    
+    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);
+    catch ();
+
+    libvlc_media_list_add_media (ml, md, &ex);
+    catch ();
+
+    // Add three media
+    media_list_add_file_path (vlc, ml, file);
+    media_list_add_file_path (vlc, ml, file);
+    media_list_add_file_path (vlc, ml, file);
+
+    libvlc_media_list_player_set_media_list (mlp, ml, &ex);
+    
+    libvlc_media_list_player_play_item (mlp, md, &ex);
+    catch ();
+
+    libvlc_media_release (md);
+
+    usleep(500000);
+    
+    libvlc_media_list_player_next (mlp, &ex);
+    catch ();
+
+    libvlc_media_list_player_pause (mlp, &ex);
+    catch();
+
+    usleep(500000);
+    
+    libvlc_media_list_player_next (mlp, &ex);
+    catch ();
+    
+    libvlc_media_list_player_stop (mlp, &ex);
+    catch ();
+
+    usleep(500000);
+    
+    libvlc_media_list_player_next (mlp, &ex);
+    catch ();
+        
+    libvlc_media_list_player_release (mlp);
+    catch ();
+    
+    libvlc_release (vlc);
+    catch ();
+}
+
 static void test_media_list_player_pause_stop(const char** argv, int argc)
 {
     libvlc_instance_t *vlc;
@@ -120,5 +198,8 @@ int main (void)
 
     test_media_list_player_pause_stop (test_defaults_args, test_defaults_nargs);
     test_media_list_player_play_item_at_index (test_defaults_args, test_defaults_nargs);
+    if(0) // Core hangs here, because it doesn't support callback removal from callbacks (variable)
+        test_media_list_player_next (test_defaults_args, test_defaults_nargs);
+
     return 0;
 }