minio/mint/run/core/s3select/tests.py

88 lines
3.1 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import sys
from csv import (test_csv_input_custom_quote_char,
test_csv_output_custom_quote_char)
from minio import Minio
from sql_ops import (test_sql_datatypes, test_sql_functions_agg_cond_conv,
test_sql_functions_date, test_sql_functions_string,
test_sql_operators, test_sql_operators_precedence,
test_sql_select, test_sql_select_csv_no_header,
test_sql_select_json)
2020-05-15 14:20:57 -04:00
from utils import LogOutput
def main():
"""
Functional testing for S3 select.
"""
try:
access_key = os.getenv('ACCESS_KEY', 'Q3AM3UQ867SPQQA43P2F')
secret_key = os.getenv('SECRET_KEY',
'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG')
server_endpoint = os.getenv('SERVER_ENDPOINT', 'play.min.io')
secure = os.getenv('ENABLE_HTTPS', '1') == '1'
if server_endpoint == 'play.min.io':
access_key = 'Q3AM3UQ867SPQQA43P2F'
secret_key = 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG'
secure = True
client = Minio(server_endpoint, access_key, secret_key, secure=secure)
log_output = LogOutput(client.select_object_content,
'test_csv_input_quote_char')
test_csv_input_custom_quote_char(client, log_output)
log_output = LogOutput(client.select_object_content,
'test_csv_output_quote_char')
test_csv_output_custom_quote_char(client, log_output)
log_output = LogOutput(
client.select_object_content, 'test_sql_operators')
2020-05-15 14:20:57 -04:00
test_sql_operators(client, log_output)
log_output = LogOutput(client.select_object_content,
'test_sql_operators_precedence')
2020-05-15 14:20:57 -04:00
test_sql_operators_precedence(client, log_output)
log_output = LogOutput(client.select_object_content,
'test_sql_functions_agg_cond_conv')
2020-05-15 14:20:57 -04:00
test_sql_functions_agg_cond_conv(client, log_output)
log_output = LogOutput(
client.select_object_content, 'test_sql_functions_date')
2020-05-15 14:20:57 -04:00
test_sql_functions_date(client, log_output)
log_output = LogOutput(client.select_object_content,
'test_sql_functions_string')
2020-05-15 14:20:57 -04:00
test_sql_functions_string(client, log_output)
log_output = LogOutput(
client.select_object_content, 'test_sql_datatypes')
2020-05-15 14:20:57 -04:00
test_sql_datatypes(client, log_output)
log_output = LogOutput(client.select_object_content, 'test_sql_select')
test_sql_select(client, log_output)
log_output = LogOutput(
client.select_object_content, 'test_sql_select_json')
2020-05-15 14:20:57 -04:00
test_sql_select_json(client, log_output)
log_output = LogOutput(
client.select_object_content, 'test_sql_select_csv')
2020-05-15 14:20:57 -04:00
test_sql_select_csv_no_header(client, log_output)
except Exception as err:
print(log_output.json_report(err))
sys.exit(1)
if __name__ == "__main__":
# Execute only if run as a script
main()