You've already forked FFmpeg
							
							
				mirror of
				https://github.com/FFmpeg/FFmpeg.git
				synced 2025-10-30 23:18:11 +02:00 
			
		
		
		
	Run regression tests on target system.
Originally committed as revision 15915 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
		
							
								
								
									
										8
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								Makefile
									
									
									
									
									
								
							| @@ -299,14 +299,14 @@ $(CODEC_TESTS) $(LAVF_TESTS): regtest-ref | |||||||
| regtest-ref: ffmpeg$(EXESUF) tests/vsynth1/00.pgm tests/vsynth2/00.pgm tests/asynth1.sw | regtest-ref: ffmpeg$(EXESUF) tests/vsynth1/00.pgm tests/vsynth2/00.pgm tests/asynth1.sw | ||||||
|  |  | ||||||
| $(CODEC_TESTS) regtest-ref: tests/tiny_psnr$(EXESUF) | $(CODEC_TESTS) regtest-ref: tests/tiny_psnr$(EXESUF) | ||||||
| 	$(SRC_PATH)/tests/regression.sh $@ vsynth   tests/vsynth1 a | 	$(SRC_PATH)/tests/regression.sh $@ vsynth   tests/vsynth1 a "$(TARGET_EXEC)" "$(TARGET_PATH)" | ||||||
| 	$(SRC_PATH)/tests/regression.sh $@ rotozoom tests/vsynth2 a | 	$(SRC_PATH)/tests/regression.sh $@ rotozoom tests/vsynth2 a "$(TARGET_EXEC)" "$(TARGET_PATH)" | ||||||
|  |  | ||||||
| $(LAVF_TESTS): | $(LAVF_TESTS): | ||||||
| 	$(SRC_PATH)/tests/regression.sh $@ lavf tests/vsynth1 b | 	$(SRC_PATH)/tests/regression.sh $@ lavf tests/vsynth1 b "$(TARGET_EXEC)" "$(TARGET_PATH)" | ||||||
|  |  | ||||||
| seektest: codectest libavtest tests/seek_test$(EXESUF) | seektest: codectest libavtest tests/seek_test$(EXESUF) | ||||||
| 	$(SRC_PATH)/tests/seek_test.sh $(SEEK_REFFILE) | 	$(SRC_PATH)/tests/seek_test.sh $(SEEK_REFFILE) "$(TARGET_EXEC)" "$(TARGET_PATH)" | ||||||
|  |  | ||||||
| servertest: ffserver$(EXESUF) tests/vsynth1/00.pgm tests/asynth1.sw | servertest: ffserver$(EXESUF) tests/vsynth1/00.pgm tests/asynth1.sw | ||||||
| 	@echo | 	@echo | ||||||
|   | |||||||
| @@ -7,7 +7,11 @@ | |||||||
|  |  | ||||||
| set -e | set -e | ||||||
|  |  | ||||||
|  | target_exec=$5 | ||||||
|  | target_path=$6 | ||||||
|  |  | ||||||
| datadir="./tests/data" | datadir="./tests/data" | ||||||
|  | target_datadir="${target_path}/${datadir}" | ||||||
|  |  | ||||||
| test="${1#regtest-}" | test="${1#regtest-}" | ||||||
| this="$test.$2" | this="$test.$2" | ||||||
| @@ -17,18 +21,19 @@ outfile="$datadir/$4-" | |||||||
| eval do_$test=y | eval do_$test=y | ||||||
|  |  | ||||||
| # various files | # various files | ||||||
| ffmpeg="./ffmpeg_g" | ffmpeg="$target_exec ${target_path}/ffmpeg_g" | ||||||
| tiny_psnr="tests/tiny_psnr" | tiny_psnr="tests/tiny_psnr" | ||||||
| benchfile="$datadir/$this.bench" | benchfile="$datadir/$this.bench" | ||||||
| bench="$datadir/$this.bench.tmp" | bench="$datadir/$this.bench.tmp" | ||||||
| bench2="$datadir/$this.bench2.tmp" | bench2="$datadir/$this.bench2.tmp" | ||||||
| raw_src="$3/%02d.pgm" | raw_src="${target_path}/$3/%02d.pgm" | ||||||
| raw_dst="$datadir/$this.out.yuv" | raw_dst="$datadir/$this.out.yuv" | ||||||
| raw_ref="$datadir/$2.ref.yuv" | raw_ref="$datadir/$2.ref.yuv" | ||||||
| pcm_src="tests/asynth1.sw" | pcm_src="${target_path}/tests/asynth1.sw" | ||||||
| pcm_dst="$datadir/$this.out.wav" | pcm_dst="$datadir/$this.out.wav" | ||||||
| pcm_ref="$datadir/$2.ref.wav" | pcm_ref="$datadir/$2.ref.wav" | ||||||
| crcfile="$datadir/$this.crc" | crcfile="$datadir/$this.crc" | ||||||
|  | target_crcfile="$target_datadir/$this.crc" | ||||||
|  |  | ||||||
| if [ X"`echo | md5sum 2> /dev/null`" != X ]; then | if [ X"`echo | md5sum 2> /dev/null`" != X ]; then | ||||||
|     do_md5sum() { md5sum -b $1; } |     do_md5sum() { md5sum -b $1; } | ||||||
| @@ -47,6 +52,7 @@ do_ffmpeg() | |||||||
| { | { | ||||||
|     f="$1" |     f="$1" | ||||||
|     shift |     shift | ||||||
|  |     set -- $* ${target_path}/$f | ||||||
|     echo $ffmpeg $FFMPEG_OPTS $* |     echo $ffmpeg $FFMPEG_OPTS $* | ||||||
|     $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ |     $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ | ||||||
|     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:)" /tmp/ffmpeg$$ || true |     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:)" /tmp/ffmpeg$$ || true | ||||||
| @@ -67,6 +73,7 @@ do_ffmpeg_nomd5() | |||||||
| { | { | ||||||
|     f="$1" |     f="$1" | ||||||
|     shift |     shift | ||||||
|  |     set -- $* ${target_path}/$f | ||||||
|     echo $ffmpeg $FFMPEG_OPTS $* |     echo $ffmpeg $FFMPEG_OPTS $* | ||||||
|     $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ |     $ffmpeg $FFMPEG_OPTS -benchmark $* > $bench 2> /tmp/ffmpeg$$ | ||||||
|     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:)" /tmp/ffmpeg$$ || true |     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:)" /tmp/ffmpeg$$ || true | ||||||
| @@ -86,8 +93,8 @@ do_ffmpeg_crc() | |||||||
| { | { | ||||||
|     f="$1" |     f="$1" | ||||||
|     shift |     shift | ||||||
|     echo $ffmpeg $FFMPEG_OPTS $* -f crc "$crcfile" |     echo $ffmpeg $FFMPEG_OPTS $* -f crc "$target_crcfile" | ||||||
|     $ffmpeg $FFMPEG_OPTS $* -f crc "$crcfile" > /tmp/ffmpeg$$ 2>&1 |     $ffmpeg $FFMPEG_OPTS $* -f crc "$target_crcfile" > /tmp/ffmpeg$$ 2>&1 | ||||||
|     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:|ffmpeg version|  configuration|  built)" /tmp/ffmpeg$$ || true |     egrep -v "^(Stream|Press|Input|Output|frame|  Stream|  Duration|video:|ffmpeg version|  configuration|  built)" /tmp/ffmpeg$$ || true | ||||||
|     rm -f /tmp/ffmpeg$$ |     rm -f /tmp/ffmpeg$$ | ||||||
|     echo "$f `cat $crcfile`" >> $logfile |     echo "$f `cat $crcfile`" >> $logfile | ||||||
| @@ -108,55 +115,55 @@ do_ffmpeg_nocheck() | |||||||
|  |  | ||||||
| do_video_decoding() | do_video_decoding() | ||||||
| { | { | ||||||
|     do_ffmpeg $raw_dst $1 -i $file -f rawvideo $2 $raw_dst |     do_ffmpeg $raw_dst $1 -i $target_path/$file -f rawvideo $2 | ||||||
|     rm -f $raw_dst |     rm -f $raw_dst | ||||||
| } | } | ||||||
|  |  | ||||||
| do_video_encoding() | do_video_encoding() | ||||||
| { | { | ||||||
|     file=${outfile}$1 |     file=${outfile}$1 | ||||||
|     do_ffmpeg $file $2 -f image2 -vcodec pgmyuv -i $raw_src $3 $file |     do_ffmpeg $file $2 -f image2 -vcodec pgmyuv -i $raw_src $3 | ||||||
| } | } | ||||||
|  |  | ||||||
| do_audio_encoding() | do_audio_encoding() | ||||||
| { | { | ||||||
|     file=${outfile}$1 |     file=${outfile}$1 | ||||||
|     do_ffmpeg $file -ab 128k -ac 2 -f s16le -i $pcm_src $3 $file |     do_ffmpeg $file -ab 128k -ac 2 -f s16le -i $pcm_src $3 | ||||||
| } | } | ||||||
|  |  | ||||||
| do_audio_decoding() | do_audio_decoding() | ||||||
| { | { | ||||||
|     do_ffmpeg $pcm_dst -i $file -sample_fmt s16 -f wav $pcm_dst |     do_ffmpeg $pcm_dst -i $target_path/$file -sample_fmt s16 -f wav | ||||||
| } | } | ||||||
|  |  | ||||||
| do_libav() | do_libav() | ||||||
| { | { | ||||||
|     file=${outfile}libav.$1 |     file=${outfile}libav.$1 | ||||||
|     do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f s16le -i $pcm_src $2 $file |     do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f s16le -i $pcm_src $2 | ||||||
|     do_ffmpeg_crc $file -i $file $3 |     do_ffmpeg_crc $file -i $target_path/$file $3 | ||||||
| } | } | ||||||
|  |  | ||||||
| do_streamed_images() | do_streamed_images() | ||||||
| { | { | ||||||
|     file=${outfile}${1}pipe.$1 |     file=${outfile}${1}pipe.$1 | ||||||
|     do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f image2pipe $file |     do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f image2pipe | ||||||
|     do_ffmpeg_crc $file -f image2pipe -i $file |     do_ffmpeg_crc $file -f image2pipe -i $target_path/$file | ||||||
| } | } | ||||||
|  |  | ||||||
| do_image_formats() | do_image_formats() | ||||||
| { | { | ||||||
|     file=${outfile}libav%02d.$1 |     file=${outfile}libav%02d.$1 | ||||||
|     $ffmpeg -t 0.5 -y -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src $2 $3 -flags +bitexact -sws_flags +accurate_rnd+bitexact $file |     $ffmpeg -t 0.5 -y -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src $2 $3 -flags +bitexact -sws_flags +accurate_rnd+bitexact $target_path/$file | ||||||
|     do_md5sum ${outfile}libav02.$1 >> $logfile |     do_md5sum ${outfile}libav02.$1 >> $logfile | ||||||
|     do_ffmpeg_crc $file $3 -i $file |     do_ffmpeg_crc $file $3 -i $target_path/$file | ||||||
|     wc -c ${outfile}libav02.$1 >> $logfile |     wc -c ${outfile}libav02.$1 >> $logfile | ||||||
| } | } | ||||||
|  |  | ||||||
| do_audio_only() | do_audio_only() | ||||||
| { | { | ||||||
|     file=${outfile}libav.$1 |     file=${outfile}libav.$1 | ||||||
|     do_ffmpeg $file -t 1 -qscale 10 -f s16le -i $pcm_src $file |     do_ffmpeg $file -t 1 -qscale 10 -f s16le -i $pcm_src | ||||||
|     do_ffmpeg_crc $file -i $file |     do_ffmpeg_crc $file -i $target_path/$file | ||||||
| } | } | ||||||
|  |  | ||||||
| rm -f "$logfile" | rm -f "$logfile" | ||||||
| @@ -164,8 +171,8 @@ rm -f "$benchfile" | |||||||
|  |  | ||||||
| # generate reference for quality check | # generate reference for quality check | ||||||
| if [ -n "$do_ref" ]; then | if [ -n "$do_ref" ]; then | ||||||
| do_ffmpeg_nocheck $raw_ref -f image2 -vcodec pgmyuv -i $raw_src -an -f rawvideo $raw_ref | do_ffmpeg_nocheck $raw_ref -f image2 -vcodec pgmyuv -i $raw_src -an -f rawvideo $target_path/$raw_ref | ||||||
| do_ffmpeg_nocheck $pcm_ref -ab 128k -ac 2 -ar 44100 -f s16le -i $pcm_src -f wav $pcm_ref | do_ffmpeg_nocheck $pcm_ref -ab 128k -ac 2 -ar 44100 -f s16le -i $pcm_src -f wav $target_path/$pcm_ref | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if [ -n "$do_mpeg" ] ; then | if [ -n "$do_mpeg" ] ; then | ||||||
| @@ -207,7 +214,7 @@ do_video_decoding | |||||||
|  |  | ||||||
| # mpeg2 encoding interlaced | # mpeg2 encoding interlaced | ||||||
| file=${outfile}mpeg2reuse.mpg | file=${outfile}mpeg2reuse.mpg | ||||||
| do_ffmpeg $file -sameq -me_threshold 256 -mb_threshold 1024 -i ${outfile}mpeg2thread.mpg -vcodec mpeg2video -f mpeg1video -bf 2 -flags +ildct+ilme -threads 4 $file | do_ffmpeg $file -sameq -me_threshold 256 -mb_threshold 1024 -i ${target_path}/${outfile}mpeg2thread.mpg -vcodec mpeg2video -f mpeg1video -bf 2 -flags +ildct+ilme -threads 4 | ||||||
| do_video_decoding | do_video_decoding | ||||||
| fi | fi | ||||||
|  |  | ||||||
| @@ -424,11 +431,11 @@ fi | |||||||
| if [ -n "$do_wma" ] ; then | if [ -n "$do_wma" ] ; then | ||||||
| # wmav1 | # wmav1 | ||||||
| do_audio_encoding wmav1.asf "-ar 44100" "-acodec wmav1" | do_audio_encoding wmav1.asf "-ar 44100" "-acodec wmav1" | ||||||
| do_ffmpeg_nomd5 $pcm_dst -i $file -f wav $pcm_dst | do_ffmpeg_nomd5 $pcm_dst -i $target_path/$file -f wav | ||||||
| $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile | $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile | ||||||
| # wmav2 | # wmav2 | ||||||
| do_audio_encoding wmav2.asf "-ar 44100" "-acodec wmav2" | do_audio_encoding wmav2.asf "-ar 44100" "-acodec wmav2" | ||||||
| do_ffmpeg_nomd5 $pcm_dst -i $file -f wav $pcm_dst | do_ffmpeg_nomd5 $pcm_dst -i $target_path/$file -f wav | ||||||
| $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile | $tiny_psnr $pcm_dst $pcm_ref 2 8192 >> $logfile | ||||||
| fi | fi | ||||||
|  |  | ||||||
| @@ -481,9 +488,9 @@ fi | |||||||
|  |  | ||||||
| if [ -n "$do_rm" ] ; then | if [ -n "$do_rm" ] ; then | ||||||
| file=${outfile}libav.rm | file=${outfile}libav.rm | ||||||
| do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f s16le -i $pcm_src $file | do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -f s16le -i $pcm_src | ||||||
| # broken | # broken | ||||||
| #do_ffmpeg_crc $file -i $file | #do_ffmpeg_crc $file -i $target_path/$file | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if [ -n "$do_mpg" ] ; then | if [ -n "$do_mpg" ] ; then | ||||||
| @@ -530,8 +537,8 @@ fi | |||||||
| # streamed images | # streamed images | ||||||
| # mjpeg | # mjpeg | ||||||
| #file=${outfile}libav.mjpeg | #file=${outfile}libav.mjpeg | ||||||
| #do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src $file | #do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src | ||||||
| #do_ffmpeg_crc $file -i $file | #do_ffmpeg_crc $file -i $target_path/$file | ||||||
|  |  | ||||||
| if [ -n "$do_pbmpipe" ] ; then | if [ -n "$do_pbmpipe" ] ; then | ||||||
| do_streamed_images pbm | do_streamed_images pbm | ||||||
| @@ -547,14 +554,14 @@ fi | |||||||
|  |  | ||||||
| if [ -n "$do_gif" ] ; then | if [ -n "$do_gif" ] ; then | ||||||
| file=${outfile}libav.gif | file=${outfile}libav.gif | ||||||
| do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -pix_fmt rgb24 $file | do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src -pix_fmt rgb24 | ||||||
| #do_ffmpeg_crc $file -i $file | #do_ffmpeg_crc $file -i $target_path/$file | ||||||
| fi | fi | ||||||
|  |  | ||||||
| if [ -n "$do_yuv4mpeg" ] ; then | if [ -n "$do_yuv4mpeg" ] ; then | ||||||
| file=${outfile}libav.y4m | file=${outfile}libav.y4m | ||||||
| do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src $file | do_ffmpeg $file -t 1 -qscale 10 -f image2 -vcodec pgmyuv -i $raw_src | ||||||
| #do_ffmpeg_crc $file -i $file | #do_ffmpeg_crc $file -i $target_path/$file | ||||||
| fi | fi | ||||||
|  |  | ||||||
| # image formats | # image formats | ||||||
| @@ -630,9 +637,9 @@ conversions="yuv420p yuv422p yuv444p yuyv422 yuv410p yuv411p yuvj420p \ | |||||||
| for pix_fmt in $conversions ; do | for pix_fmt in $conversions ; do | ||||||
|     file=${outfile}libav-${pix_fmt}.yuv |     file=${outfile}libav-${pix_fmt}.yuv | ||||||
|     do_ffmpeg_nocheck $file -r 1 -t 1 -f image2 -vcodec pgmyuv -i $raw_src \ |     do_ffmpeg_nocheck $file -r 1 -t 1 -f image2 -vcodec pgmyuv -i $raw_src \ | ||||||
|                             -f rawvideo -s 352x288 -pix_fmt $pix_fmt $raw_dst |                             -f rawvideo -s 352x288 -pix_fmt $pix_fmt $target_path/$raw_dst | ||||||
|     do_ffmpeg $file -f rawvideo -s 352x288 -pix_fmt $pix_fmt -i $raw_dst \ |     do_ffmpeg $file -f rawvideo -s 352x288 -pix_fmt $pix_fmt -i $target_path/$raw_dst \ | ||||||
|                     -f rawvideo -s 352x288 -pix_fmt yuv444p $file |                     -f rawvideo -s 352x288 -pix_fmt yuv444p | ||||||
| done | done | ||||||
| fi | fi | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,6 +3,9 @@ | |||||||
| LC_ALL=C | LC_ALL=C | ||||||
| export LC_ALL | export LC_ALL | ||||||
|  |  | ||||||
|  | target_exec=$2 | ||||||
|  | target_path=$3 | ||||||
|  |  | ||||||
| datadir="tests/data" | datadir="tests/data" | ||||||
|  |  | ||||||
| logfile="$datadir/seek.regression" | logfile="$datadir/seek.regression" | ||||||
| @@ -13,7 +16,7 @@ rm -f $logfile | |||||||
| for i in $list ; do | for i in $list ; do | ||||||
|     echo ---------------- >> $logfile |     echo ---------------- >> $logfile | ||||||
|     echo $i >> $logfile |     echo $i >> $logfile | ||||||
|     tests/seek_test $i >> $logfile |     $target_exec $target_path/tests/seek_test $target_path/$i >> $logfile | ||||||
| done | done | ||||||
|  |  | ||||||
| if diff -u -w "$reffile" "$logfile" ; then | if diff -u -w "$reffile" "$logfile" ; then | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user