Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Tetragramm
GitHub Repository: Tetragramm/opencv
Path: blob/master/modules/videoio/test/test_container_avi.cpp
16354 views
1
// This file is part of OpenCV project.
2
// It is subject to the license terms in the LICENSE file found in the top-level directory
3
// of this distribution and at http://opencv.org/license.html.
4
5
#include "test_precomp.hpp"
6
#include "opencv2/videoio/container_avi.private.hpp"
7
#include <cstdio>
8
9
using namespace cv;
10
11
namespace opencv_test
12
{
13
14
TEST(videoio_avi, good_MJPG) {
15
String filename = BunnyParameters::getFilename(".mjpg.avi");
16
AVIReadContainer in;
17
in.initStream(filename);
18
frame_list frames;
19
ASSERT_TRUE(in.parseRiff(frames));
20
EXPECT_EQ(frames.size(), static_cast<unsigned>(BunnyParameters::getCount()));
21
EXPECT_EQ(in.getWidth(), static_cast<unsigned>(BunnyParameters::getWidth()));
22
EXPECT_EQ(in.getHeight(), static_cast<unsigned>(BunnyParameters::getHeight()));
23
EXPECT_EQ(in.getFps(), static_cast<unsigned>(BunnyParameters::getFps()));
24
}
25
26
TEST(videoio_avi, bad_MJPG) {
27
String filename = BunnyParameters::getFilename(".avi");
28
AVIReadContainer in;
29
in.initStream(filename);
30
frame_list frames;
31
EXPECT_FALSE(in.parseRiff(frames));
32
EXPECT_EQ(frames.size(), static_cast<unsigned>(0));
33
}
34
35
TEST(videoio_avi, basic)
36
{
37
const String filename = cv::tempfile("test.avi");
38
const double fps = 100;
39
const Size sz(800, 600);
40
const size_t count = 10;
41
const uchar data[count] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0xA};
42
const Codecs codec = MJPEG;
43
{
44
AVIWriteContainer out;
45
ASSERT_TRUE(out.initContainer(filename, fps, sz, true));
46
ASSERT_TRUE(out.isOpenedStream());
47
EXPECT_EQ(out.getWidth(), sz.width);
48
EXPECT_EQ(out.getHeight(), sz.height);
49
EXPECT_EQ(out.getChannels(), 3);
50
51
out.startWriteAVI(1);
52
{
53
out.writeStreamHeader(codec); // starts LIST chunk
54
size_t chunkPointer = out.getStreamPos();
55
int avi_index = out.getAVIIndex(0, dc);
56
{
57
out.startWriteChunk(avi_index);
58
out.putStreamBytes(data, count);
59
size_t tempChunkPointer = out.getStreamPos();
60
size_t moviPointer = out.getMoviPointer();
61
out.pushFrameOffset(chunkPointer - moviPointer);
62
out.pushFrameSize(tempChunkPointer - chunkPointer - 8);
63
out.endWriteChunk();
64
}
65
out.endWriteChunk(); // ends LIST chunk
66
}
67
out.writeIndex(0, dc);
68
out.finishWriteAVI();
69
}
70
{
71
AVIReadContainer in;
72
in.initStream(filename);
73
frame_list frames;
74
ASSERT_TRUE(in.parseRiff(frames));
75
EXPECT_EQ(in.getFps(), fps);
76
EXPECT_EQ(in.getWidth(), static_cast<unsigned>(sz.width));
77
EXPECT_EQ(in.getHeight(), static_cast<unsigned>(sz.height));
78
ASSERT_EQ(frames.size(), static_cast<unsigned>(1));
79
std::vector<char> actual = in.readFrame(frames.begin());
80
ASSERT_EQ(actual.size(), count);
81
for (size_t i = 0; i < count; ++i)
82
EXPECT_EQ(actual.at(i), data[i]) << "at index " << i;
83
}
84
remove(filename.c_str());
85
}
86
87
}
88
89