TestVP9Decode.cpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * Copyright (c) 2022, Gregory Bertilson <zaggy1024@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibTest/TestCase.h>
  7. #include <LibVideo/Containers/Matroska/Reader.h>
  8. #include <LibVideo/VP9/Decoder.h>
  9. static void decode_video(StringView path, size_t expected_frame_count)
  10. {
  11. auto matroska_document = MUST(Video::Matroska::Reader::parse_matroska_from_file(path));
  12. auto video_track_optional = matroska_document->track_for_track_type(Video::Matroska::TrackEntry::TrackType::Video);
  13. VERIFY(video_track_optional.has_value());
  14. auto video_track_entry = video_track_optional.value();
  15. size_t frame_count = 0;
  16. size_t cluster_index, block_index, frame_index;
  17. Video::VP9::Decoder vp9_decoder;
  18. for (cluster_index = 0; cluster_index < matroska_document->clusters().size(); cluster_index++) {
  19. auto const& cluster = matroska_document->clusters()[cluster_index];
  20. for (block_index = 0; block_index < cluster.blocks().size(); block_index++) {
  21. auto const& block = cluster.blocks()[block_index];
  22. if (block.track_number() != video_track_entry.track_number())
  23. continue;
  24. for (frame_index = 0; frame_index < block.frames().size(); frame_index++) {
  25. MUST(vp9_decoder.receive_sample(block.frames()[frame_index]));
  26. frame_count++;
  27. }
  28. }
  29. }
  30. VERIFY(frame_count == expected_frame_count);
  31. }
  32. TEST_CASE(webm_in_vp9)
  33. {
  34. decode_video("./vp9_in_webm.webm"sv, 25);
  35. }
  36. BENCHMARK_CASE(vp9_4k)
  37. {
  38. decode_video("./vp9_4k.webm"sv, 2);
  39. }