mirror of
https://github.com/apache/impala.git
synced 2025-12-19 18:12:08 -05:00
bin/validate-unified-backend-test-filters.py currently does not handle the case where the call to run the unified backend test executable fails. Instead, it produces a very confusing message about invalid filters that does not mention that the execution failed. This checks the return code when running the unified backend test executable and produces a reasonable message if the return code is not 0. Change-Id: Ia84cd074be79bc9d99b0621a1ae216f3debf5833 Reviewed-on: http://gerrit.cloudera.org:8080/12895 Reviewed-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com> Tested-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com>
99 lines
4.3 KiB
Python
Executable File
99 lines
4.3 KiB
Python
Executable File
#!/usr/bin/env python
|
|
#
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance
|
|
# with the License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on an
|
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
# KIND, either express or implied. See the License for the
|
|
# specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import subprocess
|
|
import sys
|
|
from optparse import OptionParser
|
|
|
|
|
|
def get_set_of_tests(unified_binary, filters):
|
|
# Run the unified_binary with the specified filters. If filters is None, run
|
|
# without filters. Process the output to get fully qualified tests.
|
|
command = [unified_binary, "--gtest_list_tests"]
|
|
if filters is not None:
|
|
command.append("--gtest_filter={0}".format(filters))
|
|
p = subprocess.Popen(command, stdout=subprocess.PIPE)
|
|
out, err = p.communicate()
|
|
if p.returncode != 0:
|
|
print("FAILED: Unified backend test executable returned an error when trying\n"
|
|
" to list tests.")
|
|
print("Command: {0}".format(" ".join(command)))
|
|
print("Return Code: {0}".format(p.returncode))
|
|
print("stdout:\n{0}\nstderr:\n{1}".format(out, err))
|
|
sys.exit(1)
|
|
|
|
test_list = set()
|
|
cur_test_suite = None
|
|
for line in out.split("\n"):
|
|
if line.find("seed = ") != -1: continue
|
|
if len(line) == 0: continue
|
|
if line[-1] == ".":
|
|
cur_test_suite = line
|
|
else:
|
|
testcase = line.strip()
|
|
test_list.add("{0}{1}".format(cur_test_suite, testcase))
|
|
return test_list
|
|
|
|
|
|
def main():
|
|
parser = OptionParser()
|
|
parser.add_option("-f", "--filters", dest="filters",
|
|
help="Aggregation of all gtest filters")
|
|
parser.add_option("-b", "--unified_binary", dest="unified_binary",
|
|
help="Filename for the unified test binary")
|
|
options, args = parser.parse_args()
|
|
without_filter = get_set_of_tests(options.unified_binary, None)
|
|
with_filter = get_set_of_tests(options.unified_binary, options.filters)
|
|
|
|
assert with_filter.issubset(without_filter)
|
|
if without_filter != with_filter:
|
|
print("FAILED: The unified backend test executable contains tests that are\n"
|
|
" missing from the CMake test filters specified via the\n"
|
|
" ADD_UNIFIED_BE_TEST/ADD_UNIFIED_BE_LSAN_TEST macros in\n"
|
|
" CMakeLists.txt. To fix this, add a pattern in the appropriate\n"
|
|
" CMakeLists.txt to match the following tests:")
|
|
for tests in without_filter - with_filter:
|
|
print(tests)
|
|
print("Unified test executable: {0}\nFilters: {1}".format(
|
|
options.unified_binary, options.filters))
|
|
sys.exit(1)
|
|
|
|
# Check to see if there are any filters that do not match tests in the unified
|
|
# test executable. This can indicate that a test file is not included appropriately
|
|
# in the executable. It can also indicate a bogus filter.
|
|
filters_without_tests = []
|
|
for test_filter in options.filters.split(":"):
|
|
if len(test_filter) == 0: continue
|
|
tests = get_set_of_tests(options.unified_binary, test_filter)
|
|
if len(tests) == 0:
|
|
filters_without_tests.append(test_filter)
|
|
if len(filters_without_tests) > 0:
|
|
print("FAILED: Some test filters specified by\n"
|
|
" ADD_UNIFIED_BE_TEST/ADD_UNIFIED_BE_LSAN_TEST macros in\n"
|
|
" CMakeLists.txt do not match any tests in the unified backend\n"
|
|
" test executable. This can happen if there is a bogus filter or\n"
|
|
" if some tests are not being included in the test executable\n"
|
|
" (e.g. if a new test file is missing from the test library).\n"
|
|
" The invalid test filters are:")
|
|
for test_filter in filters_without_tests:
|
|
print(test_filter)
|
|
sys.exit(1)
|
|
|
|
if __name__ == "__main__": main()
|