Files
impala/tests/query_test/test_limit.py
Riza Suminto 4617c2370f IMPALA-13908: Remove reference to ImpalaBeeswaxException
This patch replace ImpalaBeeswaxException reference to
IMPALA_CONNECTION_EXCEPTION as much as possible.

Fix some easy flake8 issues caught thorugh this command:
git show HEAD --name-only | grep '^tests.*py' \
  | xargs -I {} impala-flake8 {} \
  | grep -e U100 -e E111 -e E301 -e E302 -e E303 -e F...

Testing:
- Pass exhaustive tests.

Change-Id: I676a9954404613a1cc35ebbc9ffa73e8132f436a
Reviewed-on: http://gerrit.cloudera.org:8080/22701
Reviewed-by: Jason Fehr <jfehr@cloudera.com>
Tested-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com>
2025-03-30 00:15:43 +00:00

86 lines
3.6 KiB
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.
# Validates limit on scan nodes
from __future__ import absolute_import, division, print_function
from tests.common.impala_connection import IMPALA_CONNECTION_EXCEPTION
from tests.common.impala_test_suite import ImpalaTestSuite
from tests.common.test_vector import ImpalaTestDimension
class TestLimit(ImpalaTestSuite):
LIMIT_VALUES = [1, 2, 3, 4, 5, 10, 100, 5000]
LIMIT_VALUES_CORE = [1, 5, 10, 5000]
QUERIES = ["select * from lineitem limit %d"]
# TODO: we should be able to run count(*) in setup rather than hardcoding the values
# but I have no idea how to do this with this framework.
TOTAL_ROWS = 6001215
@classmethod
def get_workload(self):
return 'tpch'
@classmethod
def add_test_dimensions(cls):
super(TestLimit, cls).add_test_dimensions()
# Add two more dimensions
if cls.exploration_strategy() == 'core':
cls.ImpalaTestMatrix.add_dimension(
ImpalaTestDimension('limit_value', *TestLimit.LIMIT_VALUES_CORE))
else:
cls.ImpalaTestMatrix.add_dimension(
ImpalaTestDimension('limit_value', *TestLimit.LIMIT_VALUES))
cls.ImpalaTestMatrix.add_dimension(ImpalaTestDimension('query', *TestLimit.QUERIES))
# Don't run with large limits and tiny batch sizes. This generates excessive
# network traffic and makes the machine run very slowly.
cls.ImpalaTestMatrix.add_constraint(lambda v:\
v.get_value('limit_value') < 100 or v.get_value('exec_option')['batch_size'] == 0)
# TPCH is not generated in hbase format.
# TODO: Add test coverage for hbase.
cls.ImpalaTestMatrix.add_constraint(lambda v:\
v.get_value('table_format').file_format != "hbase")
def test_limit(self, vector):
# We can't validate the rows that are returned since that is non-deterministic.
# This is why this is a python test rather than a .test.
limit = vector.get_value('limit_value')
expected_num_rows = min(limit, TestLimit.TOTAL_ROWS)
query_string = vector.get_value('query') % limit
result = self.execute_query(query_string, vector.get_value('exec_option'),
table_format=vector.get_value('table_format'))
assert(len(result.data) == expected_num_rows)
class TestLimitBase(ImpalaTestSuite):
def exec_query_validate(self, query, exec_options, should_succeed, expected_rows,
expected_error):
"""Executes a query and validates the results"""
try:
result = self.execute_query(query, exec_options)
assert should_succeed, 'Query was expected to fail'
assert len(result.data) == expected_rows,\
'Wrong number of rows returned %d' % len(result.data)
except IMPALA_CONNECTION_EXCEPTION as e:
assert not should_succeed, 'Query was not expected to fail: %s' % e
if (expected_error not in str(e)):
print(str(e))
assert expected_error in str(e)