diff options
| author | Carl Hetherington <cth@carlh.net> | 2017-03-01 11:56:28 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2017-04-19 23:04:32 +0100 |
| commit | 71c8a5601a144e6c9b9373273ed09c7d3b4e7e78 (patch) | |
| tree | f2d7b9baa467a010810468ca2956226876c0e141 | |
| parent | 7a77c0cb257f4e783b844c1699b003990977de5e (diff) | |
Remove old test.
| -rw-r--r-- | test/play_test.cc | 131 |
1 files changed, 0 insertions, 131 deletions
diff --git a/test/play_test.cc b/test/play_test.cc deleted file mode 100644 index 92c49a134..000000000 --- a/test/play_test.cc +++ /dev/null @@ -1,131 +0,0 @@ -/* - Copyright (C) 2013-2014 Carl Hetherington <cth@carlh.net> - - This file is part of DCP-o-matic. - - DCP-o-matic is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. - - DCP-o-matic is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>. - -*/ - -#include <boost/test/unit_test.hpp> -#include "lib/player.h" -#include "lib/ratio.h" -#include "lib/dcp_content_type.h" -#include "lib/player_video_frame.h" -#include "test.h" -#include <iostream> - -/* This test needs stuff in Player that is only included in debug mode */ -#ifdef DCPOMATIC_DEBUG - -using std::cout; -using boost::optional; -using boost::shared_ptr; - -struct Video -{ - boost::shared_ptr<Content> content; - boost::shared_ptr<const Image> image; - Time time; -}; - -class PlayerWrapper -{ -public: - PlayerWrapper (shared_ptr<Player> p) - : _player (p) - { - _player->Video.connect (bind (&PlayerWrapper::process_video, this, _1, _3)); - } - - void process_video (shared_ptr<PlayerVideoFrame> i, Time t) - { - Video v; - v.content = _player->_last_video; - v.image = i->image (PIX_FMT_RGB24); - v.time = t; - _queue.push_front (v); - } - - optional<Video> get_video () - { - while (_queue.empty() && !_player->pass ()) {} - if (_queue.empty ()) { - return optional<Video> (); - } - - Video v = _queue.back (); - _queue.pop_back (); - return v; - } - - void seek (Time t, bool ac) - { - _player->seek (t, ac); - _queue.clear (); - } - -private: - shared_ptr<Player> _player; - std::list<Video> _queue; -}; - -BOOST_AUTO_TEST_CASE (play_test) -{ - shared_ptr<Film> film = new_test_film ("play_test"); - film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR")); - film->set_container (Ratio::from_id ("185")); - film->set_name ("play_test"); - - shared_ptr<FFmpegContent> A (new FFmpegContent (film, "test/data/red_24.mp4")); - film->examine_and_add_content (A); - wait_for_jobs (); - - BOOST_CHECK_EQUAL (A->video_length_after_3d_combine(), 16); - - shared_ptr<FFmpegContent> B (new FFmpegContent (film, "test/data/red_30.mp4")); - film->examine_and_add_content (B); - wait_for_jobs (); - - BOOST_CHECK_EQUAL (B->video_length_after_3d_combine(), 16); - - /* Film should have been set to 25fps */ - BOOST_CHECK_EQUAL (film->video_frame_rate(), 25); - - BOOST_CHECK_EQUAL (A->position(), 0); - /* A is 16 frames long at 25 fps */ - BOOST_CHECK_EQUAL (B->position(), 16 * TIME_HZ / 25); - - shared_ptr<Player> player (new Player (film)); - PlayerWrapper wrap (player); - /* Seek and audio don't get on at the moment */ - player->disable_audio (); - - for (int i = 0; i < 32; ++i) { - optional<Video> v = wrap.get_video (); - BOOST_CHECK (v); - if (i < 16) { - BOOST_CHECK (v.get().content == A); - } else { - BOOST_CHECK (v.get().content == B); - } - } - - wrap.seek (10 * TIME_HZ / 25, true); - optional<Video> v = wrap.get_video (); - BOOST_CHECK (v); - BOOST_CHECK_EQUAL (v.get().time, 10 * TIME_HZ / 25); -} - -#endif |
