mirror of
https://github.com/xenia-project/FFmpeg.git
synced 2024-11-24 03:59:43 +00:00
fate: Add tests of the ff_make_absolute_url function
Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
33893e6abc
commit
7bc433b36d
@ -376,7 +376,8 @@ SKIPHEADERS-$(CONFIG_NETWORK) += network.h rtsp.h
|
|||||||
EXAMPLES = metadata \
|
EXAMPLES = metadata \
|
||||||
output \
|
output \
|
||||||
|
|
||||||
TESTPROGS = seek
|
TESTPROGS = seek \
|
||||||
|
url \
|
||||||
|
|
||||||
TOOLS = aviocat \
|
TOOLS = aviocat \
|
||||||
ismindex \
|
ismindex \
|
||||||
|
58
libavformat/url-test.c
Normal file
58
libavformat/url-test.c
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2012 Martin Storsjo
|
||||||
|
*
|
||||||
|
* This file is part of Libav.
|
||||||
|
*
|
||||||
|
* Libav is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Libav 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
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with Libav; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "internal.h"
|
||||||
|
|
||||||
|
#undef printf
|
||||||
|
#undef exit
|
||||||
|
|
||||||
|
static void test(const char *base, const char *rel)
|
||||||
|
{
|
||||||
|
char buf[200], buf2[200];
|
||||||
|
ff_make_absolute_url(buf, sizeof(buf), base, rel);
|
||||||
|
printf("%s\n", buf);
|
||||||
|
if (base) {
|
||||||
|
/* Test in-buffer replacement */
|
||||||
|
snprintf(buf2, sizeof(buf2), "%s", base);
|
||||||
|
ff_make_absolute_url(buf2, sizeof(buf2), buf2, rel);
|
||||||
|
if (strcmp(buf, buf2)) {
|
||||||
|
printf("In-place handling of %s + %s failed\n", base, rel);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
test(NULL, "baz");
|
||||||
|
test("/foo/bar", "baz");
|
||||||
|
test("/foo/bar", "../baz");
|
||||||
|
test("/foo/bar", "/baz");
|
||||||
|
test("http://server/foo/", "baz");
|
||||||
|
test("http://server/foo/bar", "baz");
|
||||||
|
test("http://server/foo/", "../baz");
|
||||||
|
test("http://server/foo/bar/123", "../../baz");
|
||||||
|
test("http://server/foo/bar/123", "/baz");
|
||||||
|
test("http://server/foo/bar/123", "https://other/url");
|
||||||
|
test("http://server/foo/bar?param=value/with/slashes", "/baz");
|
||||||
|
test("http://server/foo/bar?param&otherparam", "?someparam");
|
||||||
|
test("http://server/foo/bar", "//other/url");
|
||||||
|
return 0;
|
||||||
|
}
|
@ -47,6 +47,7 @@ include $(SRC_PATH)/tests/fate/h264.mak
|
|||||||
include $(SRC_PATH)/tests/fate/image.mak
|
include $(SRC_PATH)/tests/fate/image.mak
|
||||||
include $(SRC_PATH)/tests/fate/indeo.mak
|
include $(SRC_PATH)/tests/fate/indeo.mak
|
||||||
include $(SRC_PATH)/tests/fate/libavcodec.mak
|
include $(SRC_PATH)/tests/fate/libavcodec.mak
|
||||||
|
include $(SRC_PATH)/tests/fate/libavformat.mak
|
||||||
include $(SRC_PATH)/tests/fate/libavutil.mak
|
include $(SRC_PATH)/tests/fate/libavutil.mak
|
||||||
include $(SRC_PATH)/tests/fate/lossless-audio.mak
|
include $(SRC_PATH)/tests/fate/lossless-audio.mak
|
||||||
include $(SRC_PATH)/tests/fate/lossless-video.mak
|
include $(SRC_PATH)/tests/fate/lossless-video.mak
|
||||||
@ -81,6 +82,7 @@ FATE_AVCONV += $(FATE_AVCONV-yes)
|
|||||||
FATE-$(CONFIG_AVCONV) += $(FATE_AVCONV)
|
FATE-$(CONFIG_AVCONV) += $(FATE_AVCONV)
|
||||||
|
|
||||||
FATE-$(CONFIG_AVCODEC) += $(FATE_LIBAVCODEC)
|
FATE-$(CONFIG_AVCODEC) += $(FATE_LIBAVCODEC)
|
||||||
|
FATE-$(CONFIG_AVFORMAT) += $(FATE_LIBAVFORMAT)
|
||||||
|
|
||||||
FATE_SAMPLES-$(CONFIG_AVCONV) += $(FATE_SAMPLES_AVCONV)
|
FATE_SAMPLES-$(CONFIG_AVCONV) += $(FATE_SAMPLES_AVCONV)
|
||||||
FATE_SAMPLES += $(FATE_SAMPLES-yes)
|
FATE_SAMPLES += $(FATE_SAMPLES-yes)
|
||||||
|
5
tests/fate/libavformat.mak
Normal file
5
tests/fate/libavformat.mak
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FATE_LIBAVFORMAT += fate-url
|
||||||
|
fate-url: libavformat/url-test$(EXESUF)
|
||||||
|
fate-url: CMD = run libavformat/url-test
|
||||||
|
|
||||||
|
fate-libavformat: $(FATE_LIBAVFORMAT)
|
13
tests/ref/fate/url
Normal file
13
tests/ref/fate/url
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
baz
|
||||||
|
/foo/baz
|
||||||
|
/baz
|
||||||
|
/baz
|
||||||
|
http://server/foo/baz
|
||||||
|
http://server/foo/baz
|
||||||
|
http://server/baz
|
||||||
|
http://server/baz
|
||||||
|
http://server/baz
|
||||||
|
https://other/url
|
||||||
|
http://server/baz
|
||||||
|
http://server/foo/bar?someparam
|
||||||
|
http://other/url
|
Loading…
Reference in New Issue
Block a user