3 ## Copyright (c) 2016 The WebM project authors. All Rights Reserved.
5 ## Use of this source code is governed by a BSD-style license
6 ## that can be found in the LICENSE file in the root of the source
7 ## tree. An additional intellectual property rights grant can be found
8 ## in the file PATENTS. All contributing project authors may
9 ## be found in the AUTHORS file in the root of the source tree.
11 ## This file tests the libvpx cx_set_ref example. To add new tests to this
12 ## file, do the following:
13 ## 1. Write a shell function (this is your test).
14 ## 2. Add the function to cx_set_ref_tests (on a new line).
16 . $(dirname $0)/tools_common.sh
18 # Environment check: $YUV_RAW_INPUT is required.
19 cx_set_ref_verify_environment() {
20 if [ ! -e "${YUV_RAW_INPUT}" ]; then
21 echo "Libvpx test data must exist in LIBVPX_TEST_DATA_PATH."
26 # Runs cx_set_ref and updates the reference frame before encoding frame 90.
27 # $1 is the codec name.
30 local encoder="${LIBVPX_BIN_PATH}/${codec}cx_set_ref${VPX_TEST_EXE_SUFFIX}"
31 local output_file="${VPX_TEST_OUTPUT_DIR}/${codec}cx_set_ref_${codec}.ivf"
32 local ref_frame_num=90
34 if [ ! -x "${encoder}" ]; then
35 elog "${encoder} does not exist or is not executable."
39 eval "${VPX_TEST_PREFIX}" "${encoder}" "${YUV_RAW_INPUT_WIDTH}" \
40 "${YUV_RAW_INPUT_HEIGHT}" "${YUV_RAW_INPUT}" "${output_file}" \
41 "${ref_frame_num}" ${devnull} || return 1
43 [ -e "${output_file}" ] || return 1
47 if [ "$(vp8_encode_available)" = "yes" ]; then
48 vpx_set_ref vp8 || return 1
53 if [ "$(vp9_encode_available)" = "yes" ]; then
54 vpx_set_ref vp9 || return 1
58 cx_set_ref_tests="cx_set_ref_vp8 cx_set_ref_vp9"
60 run_tests cx_set_ref_verify_environment "${cx_set_ref_tests}"