summaryrefslogtreecommitdiffstats
path: root/debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c
diff options
context:
space:
mode:
Diffstat (limited to 'debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c')
-rw-r--r--debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c209
1 files changed, 209 insertions, 0 deletions
diff --git a/debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c b/debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c
new file mode 100644
index 00000000..2383803c
--- /dev/null
+++ b/debian/transcode/transcode-1.1.7/testsuite/test-framealloc.c
@@ -0,0 +1,209 @@
+/*
+ * test-framealloc.c -- testsuite for frame allocation functions.
+ * everyone feel free to add more tests and improve
+ * existing ones.
+ * (C) 2006-2010 - Francesco Romani <fromani -at- gmail -dot- com>
+ *
+ * This file is part of transcode, a video stream processing tool.
+ *
+ * transcode 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.
+ *
+ * transcode 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 this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "config.h"
+#include "libtc/libtc.h"
+#include "libtc/tcframes.h"
+#include "src/tc_defaults.h"
+#include "src/framebuffer.h"
+
+#ifndef PACKAGE
+#define PACKAGE __FILE__
+#endif
+
+static int format[] = { CODEC_RGB, CODEC_YUV422, CODEC_YUV }; /* old breed */
+static const char *strfmt[] = { "rgb24", "yuv422p", "yuv420p" };
+
+static int test_alloc_vid(int w, int h, int fmtid, int part)
+{
+ int ret = 0;
+ int fmt = format[fmtid];
+ vframe_list_t *vptr = tc_new_video_frame(w, h, fmt, part);
+
+ if (vptr != NULL && vptr->video_size >= (w * h * 3 / 2)) {
+ ret = 1;
+ }
+ tc_del_video_frame(vptr);
+
+ if (ret) {
+ tc_info("testing frame (simple): width=%i height=%i format=%s partial=%s -> OK",
+ w, h, strfmt[fmtid], (part) ?"yes" :"no");
+ } else {
+ tc_warn("testing frame (simple): width=%i height=%i format=%s partial=%s -> FAILED",
+ w, h, strfmt[fmtid], (part) ?"yes" :"no");
+ }
+ return ret;
+}
+
+static int test_alloc_aud(double rate, double fps, int chans, int bits)
+{
+ int ret = 0;
+ aframe_list_t *aptr = tc_new_audio_frame(rate/fps, chans, bits);
+
+ if (aptr != NULL) {
+ int as = ((rate/fps) * chans * bits/8);
+ if (aptr->audio_size >= as - 2) {
+ ret = 1;
+ }
+ }
+ tc_del_audio_frame(aptr);
+
+ if (ret) {
+ tc_info("testing frame (simple): samples=%.0f/%.3f channels=%i bits=%i -> OK",
+ rate, fps, chans, bits);
+ } else {
+ tc_warn("testing frame (simple): samples=%.0f/%.3f channels=%i bits=%i -> FAILED",
+ rate, fps, chans, bits);
+ }
+ return ret;
+}
+
+
+static int test_alloc_memset_vid(int w, int h, int fmtid, int part)
+{
+ int ret = 0;
+ int fmt = format[fmtid];
+ vframe_list_t *vptr = tc_new_video_frame(w, h, fmt, part);
+
+ if (vptr != NULL && vptr->video_size >= (w * h * 3 / 2)) {
+ memset(vptr->video_buf, 'A', vptr->video_size);
+ if (!part) {
+ memset(vptr->video_buf2, 'B', vptr->video_size);
+ }
+ ret = 1;
+ }
+ tc_del_video_frame(vptr);
+
+ if (ret) {
+ tc_info("testing frame (memset): width=%i height=%i format=%s partial=%s -> OK",
+ w, h, strfmt[fmtid], (part) ?"yes" :"no");
+ } else {
+ tc_warn("testing frame (memset): width=%i height=%i format=%s partial=%s -> FAILED",
+ w, h, strfmt[fmtid], (part) ?"yes" :"no");
+ }
+ return ret;
+}
+
+static int test_alloc_memset_aud(double rate, double fps, int chans, int bits)
+{
+ int ret = 0;
+ aframe_list_t *aptr = tc_new_audio_frame(rate/fps, chans, bits);
+
+ if (aptr != NULL) {
+ int as = ((rate/fps) * chans * bits/8);
+ if (aptr->audio_size >= as - 2) {
+ memset(aptr->audio_buf, 'A', aptr->audio_size);
+ ret = 1;
+ }
+ }
+ tc_del_audio_frame(aptr);
+
+ if (ret) {
+ tc_info("testing frame (memset): samples=%.0f/%.3f channels=%i bits=%i -> OK",
+ rate, fps, chans, bits);
+ } else {
+ tc_warn("testing frame (memset): samples=%.0f/%.3f channels=%i bits=%i -> FAILED",
+ rate, fps, chans, bits);
+ }
+ return ret;
+}
+
+
+#define LEN(a) (sizeof(a)/sizeof((a)[0]))
+
+int main(void)
+{
+ int width[] = { 128, 320, 576, 640, 960, 1024, 1280, 2048 };
+ int height[] = { 96, 240, 240, 480, 560, 768, 800, 1536 };
+ int w, h, f;
+
+ double fps[] = { 24000.0/1001.0, 24000.0/1000.0, 25000.0/1000.0,
+ 30000.0/1001.0, 30000.0/1000.0, 50000.0/1000.0 };
+ double rate[] = { 16000.0, 22500.0, 24000.0, 32000.0, 44100.0, 48000.0 };
+ int channels[] = { 1, 2 };
+ int bits[] = { 8, 16 };
+ int F, r, c, b;
+
+ int runned = 0, succesfull = 0;
+
+ for (f = 0; f < LEN(format); f++) {
+ for (w = 0; w < LEN(width); w++) {
+ for (h = 0; h < LEN(height); h++) {
+ succesfull += test_alloc_vid(width[w], height[h], f, 0);
+ succesfull += test_alloc_vid(width[w], height[h], f, 1);
+ runned += 2;
+ }
+ }
+ }
+
+ for (F = 0; F < LEN(fps); F++) {
+ for (r = 0; r < LEN(rate); r++) {
+ for (c = 0; c < LEN(channels); c++) {
+ for (b = 0; b < LEN(bits); b++) {
+ succesfull += test_alloc_aud(rate[r], fps[F], channels[c], bits[b]);
+ runned++;
+ }
+ }
+ }
+ }
+
+ for (f = 0; f < LEN(format); f++) {
+ for (w = 0; w < LEN(width); w++) {
+ for (h = 0; h < LEN(height); h++) {
+ succesfull += test_alloc_memset_vid(width[w], height[h], f, 0);
+ succesfull += test_alloc_memset_vid(width[w], height[h], f, 1);
+ runned += 2;
+ }
+ }
+ }
+
+ for (F = 0; F < LEN(fps); F++) {
+ for (r = 0; r < LEN(rate); r++) {
+ for (c = 0; c < LEN(channels); c++) {
+ for (b = 0; b < LEN(bits); b++) {
+ succesfull += test_alloc_memset_aud(rate[r], fps[F], channels[c], bits[b]);
+ runned++;
+ }
+ }
+ }
+ }
+
+ tc_info("test summary: %i tests runned, %i succesfully",
+ runned, succesfull);
+ return 0;
+}
+
+/*************************************************************************/
+
+/*
+ * Local variables:
+ * c-file-style: "stroustrup"
+ * c-file-offsets: ((case-label . *) (statement-case-intro . *))
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * vim: expandtab shiftwidth=4:
+ */