L'équipe Player de 6play.fr au Paris Video Tech

Logo Paris Video Tech

Présentation du Paris Video Tech

Mercredi 1er février avait lieu la troisième édition du Paris Video Tech, un meetup orienté autour de tous les sujets techniques de la vidéo : players HTML5, formats, encodage, distribution, publicité, …

L’équipe Player de M6 Web (Frédéric Vieudrin, Nicolas Afresne, Malik Baba Aïssa et Vincent Valot) présentait le nouveau player HTML5 de 6play.fr : un player MSE multi-formats, développé entièrement en React, le framework JS qu’on ne présente plus et qui fait le succès du nouveau 6play.fr depuis 2015.

La rencontre se déroulait dans les locaux de France Télévision à Paris et proposait trois talks :

Logo Team Tube

6play : un player MSE en React

Présentation de 6play.fr

Dans la première partie, nous avons présenté le contexte technique de 6play.fr, autour de React, ainsi que les chiffres clés du site.

Après un rappel de l’historique des players du site de Replay des chaînes du Groupe M6, nous avons présenté les enjeux de la refonte de notre précédent player et évoqué nos contraintes.

Slide Historique Techno Player

Architecture du player en React / Redux

Logo React Logo Redux

En octobre 2015 sortait le nouveau 6play.fr, une Single Page App développée en React-Redux et Isomorphique. Le succès de cette refonte nous a poussé à étudier le refonte du player 6play sur la même stack technique, historiquement en Video.js.

En complément de l’approche composant proposée par React, Redux nous a apporté la solution à la gestion de l’état du player dans le temps. En effet, son fonctionnement par événements et actions était parfaitement adapté aux événements de la balise <video>.

Media Engines

Inspiré du système multi-techs de Video.js, nous avons développé notre propre système de Bridge pilotant les différents SDK Video du marché : hls.js, dash.js, Adobe Primetime Browser TVSDK, et HTML5.

Tous les Bridges communiquent ainsi de la même manière avec notre player React au travers des MediaEvents HTML5.

Intégration continue, tests, outils et méthodes de travail

Les tests automatisés font partie intégrante des développements chez M6Web. Tester unitairement nous permet de valider nos classes et méthodes, tester fonctionnellement assure le bon fonctionnement du player sur plusieurs navigateurs et évite les régressions.

Nous utilisons les Webhooks de Github pour executer nos tests, déployer un environnement de recette dédié et nous notifier du statut de la Pull Request dans Slack.

Les slides de notre présentation

Revoir l’événement en replay