From 6f058db523cf4526d04ceb92e33149335300420d Mon Sep 17 00:00:00 2001 From: Addie Morrison Date: Wed, 11 Dec 2019 11:18:03 -0600 Subject: [PATCH] Add supporting cases and data to runner --- meson.build | 6 +- runner.py | 67 ----------- tests/NOTHING | 0 tests/create-queries-from-templates | 65 ---------- tests/create-template | 10 -- .../no-nulls/99-rows_groupsize-1.parquet | Bin 0 -> 8312 bytes .../no-nulls/99-rows_groupsize-10.parquet | Bin 0 -> 28761 bytes .../no-nulls/99-rows_groupsize-99.parquet | Bin 0 -> 228603 bytes .../nulls/99-rows_groupsize-1.parquet | Bin .../nulls/99-rows_groupsize-10.parquet | Bin .../nulls/99-rows_groupsize-99.parquet | Bin .../datasets/unsupported/decimal-10-0.parquet | Bin .../datasets/unsupported/null.parquet | Bin .../datasets/unsupported/uint16.parquet | Bin .../datasets/unsupported/uint64.parquet | Bin .../datasets/unsupported/uint8.parquet | Bin tests/meson.build | 9 ++ tests/runner.py | 77 ++++++++++++ .../segfault-safety/load-valid-file/query.sql | 1 + .../load-valid-file/results.txt | 1 + tests/segfault-safety/nonexistent-file.sql | 1 + tests/segfault-safety/unspecified-file.sql | 1 + tests/templates/001-table-scan-1-rowgroup.sql | 100 ---------------- .../003-cross-join-count-1-rowgroup.sql | 2 - .../templates/004-cross-join-10-rowgroups.sql | 2 - tests/templates/005-rowid-1-rowgroup.sql | 2 - tests/templates/007-rowid-55-10-rowgroups.sql | 2 - tests/templates/008-nulls.sql | 2 - tests/templates/009-rowid-group-by.sql | 11 -- tests/templates/010-order-by-string7.sql | 100 ---------------- tests/templates/011-order-by-string8.sql | 100 ---------------- tests/templates/012-string-7-is-null.sql | 50 -------- tests/templates/013-string-7-is-not-null.sql | 51 -------- .../014-nulls-like-percent-start.sql | 2 - tests/templates/015-nulls-like-no-match.sql | 1 - .../templates/016-nulls-like-percent-end.sql | 50 -------- tests/templates/017-nulls-like-underscore.sql | 2 - tests/templates/018-string-gt-lt.sql | 3 - tests/templates/019-string-gte-lte.sql | 2 - tests/templates/020-string-eq.sql | 2 - tests/templates/021-rowid-and-field-eq.sql | 2 - tests/templates/022-rowid-and-field-ne.sql | 1 - tests/templates/023-int8-eq.sql | 2 - tests/templates/024-int8-lt.sql | 2 - tests/templates/025-int8-lte.sql | 3 - tests/templates/026-int8-gt.sql | 2 - tests/templates/027-int8-gte.sql | 3 - .../028-int8-rowid-eq-and-field-ne.sql | 1 - tests/templates/029-int64-gte.sql | 3 - tests/templates/030-int64-gt.sql | 2 - tests/templates/031-int64-eq.sql | 2 - tests/templates/032-int64-lt.sql | 2 - tests/templates/033-int64-lte.sql | 3 - .../034-int64-rowid-eq-and-field-ne.sql | 1 - .../035-int64-rowid-eq-and-field-ne2.sql | 2 - tests/templates/036-double-eq.sql | 2 - tests/templates/037-double-gt.sql | 2 - tests/templates/038-double-gte.sql | 3 - tests/templates/039-double-lt.sql | 2 - tests/templates/040-double-lte.sql | 2 - .../041-double-rowid-and-field-ne.sql | 1 - .../042-double-rowid-and-field-ne2.sql | 2 - tests/templates/043-binary-eq.sql | 2 - tests/templates/044-binary-rowid-and-ne.sql | 1 - tests/templates/045-binary-lt.sql | 2 - tests/templates/046-binary-lte.sql | 3 - tests/templates/047-binary-gt.sql | 2 - tests/templates/048-binary-gte.sql | 3 - tests/templates/049-unusable-constraint.sql | 2 - tests/templates/050-rowid-gt-none.sql | 2 - tests/templates/051-rowid-gte-none.sql | 2 - tests/templates/052-rowid-lt-none.sql | 2 - tests/templates/053-rowid-lte-none.sql | 2 - tests/templates/054-rowid-lte-one.sql | 2 - tests/templates/055-rowid-lt-one.sql | 2 - tests/templates/056-rowid-ne-some.sql | 2 - tests/templates/057-rowid-is-null.sql | 2 - tests/templates/058-rowid-is-not-null.sql | 2 - tests/templates/059-rowid-eq-string.sql | 2 - tests/templates/060-rowid-double.sql | 2 - tests/templates/061-string-eq-int.sql | 2 - tests/templates/062-string-eq-double.sql | 1 - tests/templates/063-int8-eq-double.sql | 2 - tests/templates/064-int8-eq-str.sql | 2 - tests/templates/065-int8-eq-str2.sql | 2 - tests/templates/066-int8-eq-bogus-str.sql | 1 - tests/templates/067-int8-lt-str.sql | 2 - tests/templates/068-int8-lt-double.sql | 2 - tests/templates/069-int8-lte-str.sql | 3 - tests/templates/070-int8-lte-double.sql | 3 - tests/templates/071-int8-gt-str.sql | 2 - tests/templates/072-int8-gt-double.sql | 2 - tests/templates/073-int8-gte-str.sql | 3 - tests/templates/074-int8-gte-double.sql | 3 - tests/templates/075-int8-ne-str.sql | 1 - tests/templates/076-int8-ne-double.sql | 1 - tests/templates/077-int64-gte-str.sql | 3 - tests/templates/078-int64-gte-double.sql | 3 - tests/templates/079-int65-gt-str.sql | 2 - tests/templates/080-int65-gt-double.sql | 2 - tests/templates/081-int64-eq-str.sql | 2 - tests/templates/082-int64-eq-double.sql | 2 - tests/templates/083-int64-lt-str.sql | 2 - tests/templates/084-int64-lt-double.sql | 2 - tests/templates/085-int64-lte-str.sql | 3 - tests/templates/086-int64-lte-double.sql | 3 - tests/templates/087-int64-ne-str.sql | 1 - tests/templates/088-int64-ne-double.sql | 1 - tests/templates/089-int64-ne-some-str.sql | 2 - tests/templates/090-int64-ne-some-double.sql | 2 - tests/templates/091-double-eq-str.sql | 2 - tests/templates/092-double-eq-int.sql | 2 - tests/templates/093-double-gt-str.sql | 2 - tests/templates/094-double-gt-int.sql | 2 - tests/templates/095-double-gte-str.sql | 3 - tests/templates/096-double-gte-int.sql | 2 - tests/templates/097-double-lt-str.sql | 2 - tests/templates/098-double-lt-int.sql | 2 - tests/templates/099-double-lte-str.sql | 2 - tests/templates/100-double-lte-int.sql | 2 - .../101-double-rowid-and-field-ne-str.sql | 1 - .../102-double-rowid-and-field-ne-int.sql | 1 - ...03-double-rowid-and-field-ne2-some-str.sql | 2 - ...04-double-rowid-and-field-ne2-some-int.sql | 2 - tests/templates/105-rowid-gte-0.sql | 2 - tests/templates/106-rowid-gt-0.sql | 2 - tests/templates/109-bool-where-eq-0.sql | 2 - tests/templates/110-bool-where-eq-1.sql | 2 - tests/templates/111-bool-where-bool.sql | 2 - tests/templates/112-bool-where-not-bool.sql | 2 - tests/templates/113-bool-where-gt-0.sql | 2 - tests/templates/114-bool-where-gte-0.sql | 2 - tests/templates/115-bool-where-gt-1.sql | 2 - tests/templates/116-bool-where-lt-0.sql | 2 - tests/templates/117-bool-where-lt-1.sql | 2 - tests/templates/118-bool-where-lte-1.sql | 2 - tests/templates/119-ts-eq-july-20.sql | 2 - tests/templates/120-ts-lt-july-20.sql | 2 - tests/templates/121-ts-lte-july-20.sql | 2 - tests/templates/122-ts-gt-july-20.sql | 2 - tests/templates/123-ts-gte-july-20.sql | 2 - tests/templates/124-ts-ne-july-20.sql | 2 - tests/templates/125-fixed-bytearray-eq.sql | 2 - tests/templates/126-fixed-bytearray-lt.sql | 2 - tests/templates/127-fixed-bytearray-lte.sql | 2 - tests/templates/128-fixed-bytearray-gt.sql | 2 - tests/templates/129-fixed-bytearray-gte.sql | 2 - tests/templates/130-fixed-bytearray-ne.sql | 2 - tests/templates/131-var-bytearray-eq.sql | 2 - tests/templates/132-var-bytearray-lt.sql | 2 - tests/templates/133-var-bytearray-lte.sql | 2 - tests/templates/134-var-bytearray-gt.sql | 2 - tests/templates/135-var-bytearray-gte.sql | 2 - tests/templates/136-var-bytearray-ne.sql | 2 - tests/templates/137-var-bytearray-lte.sql | 2 - tests/templates/138-string-lte.sql | 2 - tests/templates/139-random-testcase.sql | 37 ------ tests/templates/140-random-testcase.sql | 56 --------- tests/templates/141-random-testcase.sql | 6 - tests/templates/142-rowid-is-null.sql | 1 - tests/templates/143-float-eq.sql | 2 - tests/templates/144-float-eq2.sql | 1 - tests/templates/145-float-eq3.sql | 2 - tests/templates/146-float-ne.sql | 2 - tests/templates/147-float-is-null.sql | 2 - tests/templates/148-float-is-not-null.sql | 2 - tests/templates/149-float-gte.sql | 2 - tests/templates/150-float-gt.sql | 1 - tests/templates/151-float-gt-2.sql | 2 - tests/templates/152-float-lt.sql | 2 - tests/templates/153-float-lt.sql | 2 - tests/templates/154-float-lte.sql | 2 - tests/templates/155-float-skip.sql | 2 - tests/templates/156-glob.sql | 2 - tests/templates/157-glob-star.sql | 7 -- tests/templates/158-glob-star-eight.sql | 2 - tests/templates/159-glob-star-zero.sql | 10 -- tests/templates/160-glob-star.sql | 2 - tests/templates/161-glob-star-stuff.sql | 2 - tests/templates/162-like-long.sql | 1 - tests/templates/163-blob-is-not.sql | 2 - tests/templates/164-blob-is-not.sql | 1 - tests/templates/165-not-null.sql | 2 - tests/templates/166-not-not-null.sql | 2 - tests/templates/167-double-is-not-null.sql | 2 - tests/templates/168-double-is-not-99.sql | 2 - tests/test-all | 22 ---- tests/test-bad-create-table | 31 ----- tests/test-failmalloc | 49 -------- tests/test-non-existent | 33 ----- tests/test-queries | 71 ----------- tests/test-random | 113 ------------------ tests/test-supported | 42 ------- tests/test-unsupported | 37 ------ 194 files changed, 93 insertions(+), 1423 deletions(-) delete mode 100644 runner.py create mode 100644 tests/NOTHING delete mode 100755 tests/create-queries-from-templates delete mode 100755 tests/create-template create mode 100644 tests/datasets/no-nulls/99-rows_groupsize-1.parquet create mode 100644 tests/datasets/no-nulls/99-rows_groupsize-10.parquet create mode 100644 tests/datasets/no-nulls/99-rows_groupsize-99.parquet rename parquet-generator/99-rows-nulls-1.parquet => tests/datasets/nulls/99-rows_groupsize-1.parquet (100%) rename parquet-generator/99-rows-nulls-10.parquet => tests/datasets/nulls/99-rows_groupsize-10.parquet (100%) rename parquet-generator/99-rows-nulls-99.parquet => tests/datasets/nulls/99-rows_groupsize-99.parquet (100%) rename parquet-generator/unsupported-decimal-10-0-.parquet => tests/datasets/unsupported/decimal-10-0.parquet (100%) rename parquet-generator/unsupported-null.parquet => tests/datasets/unsupported/null.parquet (100%) rename parquet-generator/unsupported-uint16.parquet => tests/datasets/unsupported/uint16.parquet (100%) rename parquet-generator/unsupported-uint64.parquet => tests/datasets/unsupported/uint64.parquet (100%) rename parquet-generator/unsupported-uint8.parquet => tests/datasets/unsupported/uint8.parquet (100%) create mode 100644 tests/meson.build create mode 100644 tests/runner.py create mode 100644 tests/segfault-safety/load-valid-file/query.sql create mode 100644 tests/segfault-safety/load-valid-file/results.txt create mode 100644 tests/segfault-safety/nonexistent-file.sql create mode 100644 tests/segfault-safety/unspecified-file.sql delete mode 100644 tests/templates/001-table-scan-1-rowgroup.sql delete mode 100644 tests/templates/003-cross-join-count-1-rowgroup.sql delete mode 100644 tests/templates/004-cross-join-10-rowgroups.sql delete mode 100644 tests/templates/005-rowid-1-rowgroup.sql delete mode 100644 tests/templates/007-rowid-55-10-rowgroups.sql delete mode 100644 tests/templates/008-nulls.sql delete mode 100644 tests/templates/009-rowid-group-by.sql delete mode 100644 tests/templates/010-order-by-string7.sql delete mode 100644 tests/templates/011-order-by-string8.sql delete mode 100644 tests/templates/012-string-7-is-null.sql delete mode 100644 tests/templates/013-string-7-is-not-null.sql delete mode 100644 tests/templates/014-nulls-like-percent-start.sql delete mode 100644 tests/templates/015-nulls-like-no-match.sql delete mode 100644 tests/templates/016-nulls-like-percent-end.sql delete mode 100644 tests/templates/017-nulls-like-underscore.sql delete mode 100644 tests/templates/018-string-gt-lt.sql delete mode 100644 tests/templates/019-string-gte-lte.sql delete mode 100644 tests/templates/020-string-eq.sql delete mode 100644 tests/templates/021-rowid-and-field-eq.sql delete mode 100644 tests/templates/022-rowid-and-field-ne.sql delete mode 100644 tests/templates/023-int8-eq.sql delete mode 100644 tests/templates/024-int8-lt.sql delete mode 100644 tests/templates/025-int8-lte.sql delete mode 100644 tests/templates/026-int8-gt.sql delete mode 100644 tests/templates/027-int8-gte.sql delete mode 100644 tests/templates/028-int8-rowid-eq-and-field-ne.sql delete mode 100644 tests/templates/029-int64-gte.sql delete mode 100644 tests/templates/030-int64-gt.sql delete mode 100644 tests/templates/031-int64-eq.sql delete mode 100644 tests/templates/032-int64-lt.sql delete mode 100644 tests/templates/033-int64-lte.sql delete mode 100644 tests/templates/034-int64-rowid-eq-and-field-ne.sql delete mode 100644 tests/templates/035-int64-rowid-eq-and-field-ne2.sql delete mode 100644 tests/templates/036-double-eq.sql delete mode 100644 tests/templates/037-double-gt.sql delete mode 100644 tests/templates/038-double-gte.sql delete mode 100644 tests/templates/039-double-lt.sql delete mode 100644 tests/templates/040-double-lte.sql delete mode 100644 tests/templates/041-double-rowid-and-field-ne.sql delete mode 100644 tests/templates/042-double-rowid-and-field-ne2.sql delete mode 100644 tests/templates/043-binary-eq.sql delete mode 100644 tests/templates/044-binary-rowid-and-ne.sql delete mode 100644 tests/templates/045-binary-lt.sql delete mode 100644 tests/templates/046-binary-lte.sql delete mode 100644 tests/templates/047-binary-gt.sql delete mode 100644 tests/templates/048-binary-gte.sql delete mode 100644 tests/templates/049-unusable-constraint.sql delete mode 100644 tests/templates/050-rowid-gt-none.sql delete mode 100644 tests/templates/051-rowid-gte-none.sql delete mode 100644 tests/templates/052-rowid-lt-none.sql delete mode 100644 tests/templates/053-rowid-lte-none.sql delete mode 100644 tests/templates/054-rowid-lte-one.sql delete mode 100644 tests/templates/055-rowid-lt-one.sql delete mode 100644 tests/templates/056-rowid-ne-some.sql delete mode 100644 tests/templates/057-rowid-is-null.sql delete mode 100644 tests/templates/058-rowid-is-not-null.sql delete mode 100644 tests/templates/059-rowid-eq-string.sql delete mode 100644 tests/templates/060-rowid-double.sql delete mode 100644 tests/templates/061-string-eq-int.sql delete mode 100644 tests/templates/062-string-eq-double.sql delete mode 100644 tests/templates/063-int8-eq-double.sql delete mode 100644 tests/templates/064-int8-eq-str.sql delete mode 100644 tests/templates/065-int8-eq-str2.sql delete mode 100644 tests/templates/066-int8-eq-bogus-str.sql delete mode 100644 tests/templates/067-int8-lt-str.sql delete mode 100644 tests/templates/068-int8-lt-double.sql delete mode 100644 tests/templates/069-int8-lte-str.sql delete mode 100644 tests/templates/070-int8-lte-double.sql delete mode 100644 tests/templates/071-int8-gt-str.sql delete mode 100644 tests/templates/072-int8-gt-double.sql delete mode 100644 tests/templates/073-int8-gte-str.sql delete mode 100644 tests/templates/074-int8-gte-double.sql delete mode 100644 tests/templates/075-int8-ne-str.sql delete mode 100644 tests/templates/076-int8-ne-double.sql delete mode 100644 tests/templates/077-int64-gte-str.sql delete mode 100644 tests/templates/078-int64-gte-double.sql delete mode 100644 tests/templates/079-int65-gt-str.sql delete mode 100644 tests/templates/080-int65-gt-double.sql delete mode 100644 tests/templates/081-int64-eq-str.sql delete mode 100644 tests/templates/082-int64-eq-double.sql delete mode 100644 tests/templates/083-int64-lt-str.sql delete mode 100644 tests/templates/084-int64-lt-double.sql delete mode 100644 tests/templates/085-int64-lte-str.sql delete mode 100644 tests/templates/086-int64-lte-double.sql delete mode 100644 tests/templates/087-int64-ne-str.sql delete mode 100644 tests/templates/088-int64-ne-double.sql delete mode 100644 tests/templates/089-int64-ne-some-str.sql delete mode 100644 tests/templates/090-int64-ne-some-double.sql delete mode 100644 tests/templates/091-double-eq-str.sql delete mode 100644 tests/templates/092-double-eq-int.sql delete mode 100644 tests/templates/093-double-gt-str.sql delete mode 100644 tests/templates/094-double-gt-int.sql delete mode 100644 tests/templates/095-double-gte-str.sql delete mode 100644 tests/templates/096-double-gte-int.sql delete mode 100644 tests/templates/097-double-lt-str.sql delete mode 100644 tests/templates/098-double-lt-int.sql delete mode 100644 tests/templates/099-double-lte-str.sql delete mode 100644 tests/templates/100-double-lte-int.sql delete mode 100644 tests/templates/101-double-rowid-and-field-ne-str.sql delete mode 100644 tests/templates/102-double-rowid-and-field-ne-int.sql delete mode 100644 tests/templates/103-double-rowid-and-field-ne2-some-str.sql delete mode 100644 tests/templates/104-double-rowid-and-field-ne2-some-int.sql delete mode 100644 tests/templates/105-rowid-gte-0.sql delete mode 100644 tests/templates/106-rowid-gt-0.sql delete mode 100644 tests/templates/109-bool-where-eq-0.sql delete mode 100644 tests/templates/110-bool-where-eq-1.sql delete mode 100644 tests/templates/111-bool-where-bool.sql delete mode 100644 tests/templates/112-bool-where-not-bool.sql delete mode 100644 tests/templates/113-bool-where-gt-0.sql delete mode 100644 tests/templates/114-bool-where-gte-0.sql delete mode 100644 tests/templates/115-bool-where-gt-1.sql delete mode 100644 tests/templates/116-bool-where-lt-0.sql delete mode 100644 tests/templates/117-bool-where-lt-1.sql delete mode 100644 tests/templates/118-bool-where-lte-1.sql delete mode 100644 tests/templates/119-ts-eq-july-20.sql delete mode 100644 tests/templates/120-ts-lt-july-20.sql delete mode 100644 tests/templates/121-ts-lte-july-20.sql delete mode 100644 tests/templates/122-ts-gt-july-20.sql delete mode 100644 tests/templates/123-ts-gte-july-20.sql delete mode 100644 tests/templates/124-ts-ne-july-20.sql delete mode 100644 tests/templates/125-fixed-bytearray-eq.sql delete mode 100644 tests/templates/126-fixed-bytearray-lt.sql delete mode 100644 tests/templates/127-fixed-bytearray-lte.sql delete mode 100644 tests/templates/128-fixed-bytearray-gt.sql delete mode 100644 tests/templates/129-fixed-bytearray-gte.sql delete mode 100644 tests/templates/130-fixed-bytearray-ne.sql delete mode 100644 tests/templates/131-var-bytearray-eq.sql delete mode 100644 tests/templates/132-var-bytearray-lt.sql delete mode 100644 tests/templates/133-var-bytearray-lte.sql delete mode 100644 tests/templates/134-var-bytearray-gt.sql delete mode 100644 tests/templates/135-var-bytearray-gte.sql delete mode 100644 tests/templates/136-var-bytearray-ne.sql delete mode 100644 tests/templates/137-var-bytearray-lte.sql delete mode 100644 tests/templates/138-string-lte.sql delete mode 100644 tests/templates/139-random-testcase.sql delete mode 100644 tests/templates/140-random-testcase.sql delete mode 100644 tests/templates/141-random-testcase.sql delete mode 100644 tests/templates/142-rowid-is-null.sql delete mode 100644 tests/templates/143-float-eq.sql delete mode 100644 tests/templates/144-float-eq2.sql delete mode 100644 tests/templates/145-float-eq3.sql delete mode 100644 tests/templates/146-float-ne.sql delete mode 100644 tests/templates/147-float-is-null.sql delete mode 100644 tests/templates/148-float-is-not-null.sql delete mode 100644 tests/templates/149-float-gte.sql delete mode 100644 tests/templates/150-float-gt.sql delete mode 100644 tests/templates/151-float-gt-2.sql delete mode 100644 tests/templates/152-float-lt.sql delete mode 100644 tests/templates/153-float-lt.sql delete mode 100644 tests/templates/154-float-lte.sql delete mode 100644 tests/templates/155-float-skip.sql delete mode 100644 tests/templates/156-glob.sql delete mode 100644 tests/templates/157-glob-star.sql delete mode 100644 tests/templates/158-glob-star-eight.sql delete mode 100644 tests/templates/159-glob-star-zero.sql delete mode 100644 tests/templates/160-glob-star.sql delete mode 100644 tests/templates/161-glob-star-stuff.sql delete mode 100644 tests/templates/162-like-long.sql delete mode 100644 tests/templates/163-blob-is-not.sql delete mode 100644 tests/templates/164-blob-is-not.sql delete mode 100644 tests/templates/165-not-null.sql delete mode 100644 tests/templates/166-not-not-null.sql delete mode 100644 tests/templates/167-double-is-not-null.sql delete mode 100644 tests/templates/168-double-is-not-99.sql delete mode 100755 tests/test-all delete mode 100755 tests/test-bad-create-table delete mode 100755 tests/test-failmalloc delete mode 100755 tests/test-non-existent delete mode 100755 tests/test-queries delete mode 100755 tests/test-random delete mode 100755 tests/test-supported delete mode 100755 tests/test-unsupported diff --git a/meson.build b/meson.build index e630c01..56c47d9 100644 --- a/meson.build +++ b/meson.build @@ -11,7 +11,7 @@ shared_library('parquet', sources: sources ) -test('Load the extension', find_program('tests/test-smoke')) -test('Try loading an unsupported file', find_program('tests/test-bad-create-table')) -test('Try loading a non-existent file', find_program('tests/test-non-existent')) +subdir('tests') +#test('Try loading a non-existent file', find_program('tests/test-non-existent')) +#test('Try loading an unsupported file', find_program('tests/test-bad-create-table')) diff --git a/runner.py b/runner.py deleted file mode 100644 index 21e93f6..0000000 --- a/runner.py +++ /dev/null @@ -1,67 +0,0 @@ -#!/usr/bin/python3 -import argparse -import os -import subprocess - -DESCRIPTION = '''sqlite-parquet-vtable test runner -Run a query against several data files with varying encodings, -and verify that the output matches an expected value -''' - -COMMON_QUERY_LINES = [ - '.echo off', - '.load ./libparquet', -] - - -def read(filename): - '''Take a filename, read it into a variable -- critically, closing it after we're done''' - with open(filename) as file: - return file.read() - - -def dispatch(query_file, results_file, expected_exit_code, datasets): - '''Run a query against assorted formats of the datasets, verifying the result each time''' - query = read(query_file) - expected_results = read(results_file) - for dataset in datasets: - for file in os.listdir(dataset): - if not file.endswith('.parquet'): - print(f'Ignoring {file} -- does not end in .parquet') - continue - vtable_statement = f'CREATE VIRTUAL TABLE dataset USING parquet(\'{file}\');' - # Append test-specified query to common lines, insert \n between lines - full_query = '\n'.join(COMMON_QUERY_LINES+[vtable_statement, query]) - proc = subprocess.run( - 'sqlite3', - stdout=subprocess.PIPE, - input=full_query, - encoding='UTF-8', - check=False - ) - assert proc.returncode == expected_exit_code - assert proc.stdout == expected_results - - -if __name__ == '__main__': - PARSER = argparse.ArgumentParser(description=DESCRIPTION) - PARSER.add_argument('query', metavar='query', help='the .sql file containing the query') - PARSER.add_argument('results', help='the file containing .output format expected results') - PARSER.add_argument('exit_code', help='the exit code you expect to recieve') - PARSER.add_argument('dataset', nargs='+', help='a dataset to run the query against') - - ARGS = PARSER.parse_args() - - # Verify that each query and result file exist - assert os.path.isfile(ARGS.query) - assert os.path.isfile(ARGS.results) - # Verify that each dataset argument is a folder (ideally with .parquet files inside) - for dataset_dir in ARGS.dataset: - assert os.path.isdir(dataset_dir) - - dispatch( - query_file=ARGS.query, - results_file=ARGS.results, - expected_exit_code=ARGS.exit_code, - datasets=ARGS.dataset - ) diff --git a/tests/NOTHING b/tests/NOTHING new file mode 100644 index 0000000..e69de29 diff --git a/tests/create-queries-from-templates b/tests/create-queries-from-templates deleted file mode 100755 index 124ea45..0000000 --- a/tests/create-queries-from-templates +++ /dev/null @@ -1,65 +0,0 @@ -#!/usr/bin/python3 - -import os.path -from os import makedirs -from glob import glob -import re -import itertools - -NULL_TOKENS = ['nulls', 'nulls1', 'nulls2', 'nulls3'] -NO_NULL_TOKENS = ['no_nulls', 'no_nulls1', 'no_nulls2', 'no_nulls3'] - -TOKEN_SET = NULL_TOKENS + NO_NULL_TOKENS - -def extract_tokens(line): - line = re.sub('[^a-zA-Z0-9_]', ' ', line).split(' ') - return list(set([token for token in line if token in TOKEN_SET])) - -def main(template_dir, query_dir): - try: - makedirs(query_dir) - except: - pass - - for f in glob(os.path.join(query_dir, '*')): - os.remove(f) - - for f in glob(os.path.join(template_dir, '*.sql')): - basename = os.path.basename(f) - - with open(f, 'r') as fptr: - content = fptr.readlines() - - # Sort tokens longest first so string replace will replace no_nullsX before nullsX - # (irrelevant ATM, but maybe useful later) - tokens = sorted(extract_tokens(content[0]), key=lambda x: -len(x)) - if not tokens: - raise ValueError('{} had no tokens'.format(content[0])) - - # For simplicity, we don't support mixing nulls and no_nulls - if not all(len(token) == len(tokens[0]) for token in tokens): - raise ValueError('cannot mix nulls and no_nulls: {}'.format(content[0])) - - - template = content[0] - for token in tokens: - template = template.replace(token, token.upper()) - - replacements = NULL_TOKENS - if tokens[0].startswith('no'): - replacements = NO_NULL_TOKENS - - for variant, choices in enumerate(itertools.combinations_with_replacement(replacements, len(tokens))): - query = template - for idx, token in enumerate(tokens): - query = query.replace(token.upper(), choices[idx]) - fname = basename.replace('.sql', '-{}.sql'.format(variant)) - - with open(os.path.join(query_dir, fname), 'w') as fptr: - content[0] = query - fptr.write(''.join(content)) - -if __name__ == '__main__': - template_dir = os.path.abspath(os.path.join(__file__, '..', 'templates')) - query_dir = os.path.abspath(os.path.join(__file__, '..', 'queries')) - main(template_dir, query_dir) diff --git a/tests/create-template b/tests/create-template deleted file mode 100755 index 40b49cb..0000000 --- a/tests/create-template +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/bash - -set -euo pipefail - -query=${1:?must provide query} - -echo "$query" -psql parquet postgres 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 Fe+U1zX$b%T literal 0 HcmV?d00001 diff --git a/tests/datasets/no-nulls/99-rows_groupsize-10.parquet b/tests/datasets/no-nulls/99-rows_groupsize-10.parquet new file mode 100644 index 0000000000000000000000000000000000000000..403dac581c4b50cf4cc8f012e18a67622ac7e0de GIT binary patch literal 28761 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 QxBHL1K9I3V_)i7@AKfd~2><{9 literal 0 HcmV?d00001 diff --git a/tests/datasets/no-nulls/99-rows_groupsize-99.parquet b/tests/datasets/no-nulls/99-rows_groupsize-99.parquet new file mode 100644 index 0000000000000000000000000000000000000000..9853d2b008cabaef4d46c8960dc3203561874751 GIT binary patch literal 228603 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 literal 0 HcmV?d00001 diff --git a/parquet-generator/99-rows-nulls-1.parquet b/tests/datasets/nulls/99-rows_groupsize-1.parquet similarity index 100% rename from parquet-generator/99-rows-nulls-1.parquet rename to tests/datasets/nulls/99-rows_groupsize-1.parquet diff --git a/parquet-generator/99-rows-nulls-10.parquet b/tests/datasets/nulls/99-rows_groupsize-10.parquet similarity index 100% rename from parquet-generator/99-rows-nulls-10.parquet rename to tests/datasets/nulls/99-rows_groupsize-10.parquet diff --git a/parquet-generator/99-rows-nulls-99.parquet b/tests/datasets/nulls/99-rows_groupsize-99.parquet similarity index 100% rename from parquet-generator/99-rows-nulls-99.parquet rename to tests/datasets/nulls/99-rows_groupsize-99.parquet diff --git a/parquet-generator/unsupported-decimal-10-0-.parquet b/tests/datasets/unsupported/decimal-10-0.parquet similarity index 100% rename from parquet-generator/unsupported-decimal-10-0-.parquet rename to tests/datasets/unsupported/decimal-10-0.parquet diff --git a/parquet-generator/unsupported-null.parquet b/tests/datasets/unsupported/null.parquet similarity index 100% rename from parquet-generator/unsupported-null.parquet rename to tests/datasets/unsupported/null.parquet diff --git a/parquet-generator/unsupported-uint16.parquet b/tests/datasets/unsupported/uint16.parquet similarity index 100% rename from parquet-generator/unsupported-uint16.parquet rename to tests/datasets/unsupported/uint16.parquet diff --git a/parquet-generator/unsupported-uint64.parquet b/tests/datasets/unsupported/uint64.parquet similarity index 100% rename from parquet-generator/unsupported-uint64.parquet rename to tests/datasets/unsupported/uint64.parquet diff --git a/parquet-generator/unsupported-uint8.parquet b/tests/datasets/unsupported/uint8.parquet similarity index 100% rename from parquet-generator/unsupported-uint8.parquet rename to tests/datasets/unsupported/uint8.parquet diff --git a/tests/meson.build b/tests/meson.build new file mode 100644 index 0000000..0a26f7a --- /dev/null +++ b/tests/meson.build @@ -0,0 +1,9 @@ + +# For more test args see https://mesonbuild.com/Unit-tests.html#other-test-options +runner = find_program('runner.py') + +test('Load the extension', runner, args: files('NOTHING', 'NOTHING')+['0']) +test('Try loading a non-existent file', runner, args: files('./segfault-safety/nonexistent-file.sql', 'NOTHING')+['1']) +test('Try loading an unspecified file', runner, args: files('./segfault-safety/unspecified-file.sql', 'NOTHING')+['1']) +test('Try loading an unsupported file', runner, args: files('NOTHING', 'NOTHING')+['1','unsupported']) +test('Load all supported test files', runner, args: files('./segfault-safety/load-valid-file/query.sql', './segfault-safety/load-valid-file/results.txt')+['0','no-nulls','nulls']) diff --git a/tests/runner.py b/tests/runner.py new file mode 100644 index 0000000..710cdbe --- /dev/null +++ b/tests/runner.py @@ -0,0 +1,77 @@ +#!/usr/bin/python3 +import argparse +import os +import subprocess + +DESCRIPTION = '''sqlite-parquet-vtable test runner +Run a query against several data files with varying encodings, +and verify that the output matches an expected value +''' + +COMMON_QUERY_LINES = [ + '.echo off', + '.load ./libparquet', +] + +TEST_ROOT = os.path.dirname(os.path.abspath(__file__)) + +def read(filename): + '''Take a filename, read it into a variable -- critically, closing it after we're done''' + with open(filename) as file: + return file.read() + +def run_and_verify(query, expected_results, expected_exit_code): + '''Run a given query, compare the results and error code''' + proc = subprocess.run( + 'sqlite3', + stdout=subprocess.PIPE, + input=query, + encoding='UTF-8', + check=False + ) + assert proc.returncode == expected_exit_code, f'Expected exit code {expected_exit_code}, found {proc.returncode}' + assert proc.stdout == expected_results, f'Expected stdout to be {expected_results}, it was actually {proc.stdout}' + +def dispatch(query_file, results_file, expected_exit_code, datasets): + '''Run a query against assorted formats of the datasets, verifying the result each time''' + query = read(query_file) + expected_results = read(results_file) + # Some of the error test cases don't need multiple datasets + if len(datasets) == 0: + run_and_verify(query, expected_results, expected_exit_code) + + # For most tests, run against all members of a dataset + for dataset in datasets: + for file in os.listdir(TEST_ROOT+'/datasets/'+dataset): + filepath = TEST_ROOT+'/datasets/'+dataset+'/'+file + if not filepath.endswith('.parquet'): + print(f'Ignoring {file} -- does not end in .parquet') + continue + vtable_statement = f'CREATE VIRTUAL TABLE dataset USING parquet(\'{filepath}\');' + # Append test-specified query to common lines, insert \n between lines + full_query = '\n'.join(COMMON_QUERY_LINES+[vtable_statement, query]) + run_and_verify(full_query, expected_results, expected_exit_code) + + +if __name__ == '__main__': + PARSER = argparse.ArgumentParser(description=DESCRIPTION) + PARSER.add_argument('query', help='the .sql file containing the query to run') + PARSER.add_argument('results', help='the file containing the expected result of the query') + PARSER.add_argument('exit_code', help='the exit code you expect to recieve') + PARSER.add_argument('dataset', nargs='*', help='a dataset to run the query against') + + ARGS = PARSER.parse_args() + + # Verify that each query and result file exist + assert os.path.isfile(ARGS.query), f'Expected to find query file at {ARGS.query}' + assert os.path.isfile(ARGS.results), f'Expected to find results file at {ARGS.results}' + # Verify that each dataset argument is a folder (ideally with .parquet files inside) + for dataset_dir in ARGS.dataset: + assert os.path.isdir(TEST_ROOT+'/datasets/'+dataset_dir), f'Expected dataset to be a directory' + + dispatch( + query_file=ARGS.query, + results_file=ARGS.results, + expected_exit_code=int(ARGS.exit_code), + datasets=ARGS.dataset + ) diff --git a/tests/segfault-safety/load-valid-file/query.sql b/tests/segfault-safety/load-valid-file/query.sql new file mode 100644 index 0000000..5e65b01 --- /dev/null +++ b/tests/segfault-safety/load-valid-file/query.sql @@ -0,0 +1 @@ +SELECT * FROM dataset LIMIT 1; diff --git a/tests/segfault-safety/load-valid-file/results.txt b/tests/segfault-safety/load-valid-file/results.txt new file mode 100644 index 0000000..4248e51 --- /dev/null +++ b/tests/segfault-safety/load-valid-file/results.txt @@ -0,0 +1 @@ +1|50|5000|50000000|50000000000|490665600000|99.0|0|000|||1.0 diff --git a/tests/segfault-safety/nonexistent-file.sql b/tests/segfault-safety/nonexistent-file.sql new file mode 100644 index 0000000..ee6d105 --- /dev/null +++ b/tests/segfault-safety/nonexistent-file.sql @@ -0,0 +1 @@ +CREATE VIRTUAL TABLE test USING parquet('$doesnotexist.parquet'); diff --git a/tests/segfault-safety/unspecified-file.sql b/tests/segfault-safety/unspecified-file.sql new file mode 100644 index 0000000..cded8d7 --- /dev/null +++ b/tests/segfault-safety/unspecified-file.sql @@ -0,0 +1 @@ +CREATE VIRTUAL TABLE test USING parquet; diff --git a/tests/templates/001-table-scan-1-rowgroup.sql b/tests/templates/001-table-scan-1-rowgroup.sql deleted file mode 100644 index 7dc3c6d..0000000 --- a/tests/templates/001-table-scan-1-rowgroup.sql +++ /dev/null @@ -1,100 +0,0 @@ -SELECT rowid, bool_0, int8_1, int16_2, int32_3, int64_4, datetime(ts_5 / 1000, 'unixepoch'), printf('%.2f', double_6) AS double_6, string_7, string_8, quote(binary_9), quote(binary_10) FROM no_nulls1 -1|1|50|5000|50000000|50000000000|1985-07-20 00:00:00|99.00|0|000|X'00'|X'00' -2|0|49|4900|49000000|49000000000|1985-07-21 00:00:00|49.50|1|001|X'0101'|X'01' -3|1|48|4800|48000000|48000000000|1985-07-22 00:00:00|33.00|2|002|X'020202'|X'02' -4|0|47|4700|47000000|47000000000|1985-07-23 00:00:00|24.75|3|003|X'03030303'|X'03' -5|1|46|4600|46000000|46000000000|1985-07-24 00:00:00|19.80|4|004|X'0404040404'|X'04' -6|0|45|4500|45000000|45000000000|1985-07-25 00:00:00|16.50|5|005|X'05'|X'05' -7|1|44|4400|44000000|44000000000|1985-07-26 00:00:00|14.14|6|006|X'0606'|X'06' -8|0|43|4300|43000000|43000000000|1985-07-27 00:00:00|12.38|7|007|X'070707'|X'07' -9|1|42|4200|42000000|42000000000|1985-07-28 00:00:00|11.00|8|008|X'08080808'|X'08' -10|0|41|4100|41000000|41000000000|1985-07-29 00:00:00|9.90|9|009|X'0909090909'|X'09' -11|1|40|4000|40000000|40000000000|1985-07-30 00:00:00|9.00|10|010|X'0A'|X'0A' -12|0|39|3900|39000000|39000000000|1985-07-31 00:00:00|8.25|11|011|X'0B0B'|X'0B' -13|1|38|3800|38000000|38000000000|1985-08-01 00:00:00|7.62|12|012|X'0C0C0C'|X'0C' -14|0|37|3700|37000000|37000000000|1985-08-02 00:00:00|7.07|13|013|X'0D0D0D0D'|X'0D' -15|1|36|3600|36000000|36000000000|1985-08-03 00:00:00|6.60|14|014|X'0E0E0E0E0E'|X'0E' -16|0|35|3500|35000000|35000000000|1985-08-04 00:00:00|6.19|15|015|X'0F'|X'0F' -17|1|34|3400|34000000|34000000000|1985-08-05 00:00:00|5.82|16|016|X'1010'|X'10' -18|0|33|3300|33000000|33000000000|1985-08-06 00:00:00|5.50|17|017|X'111111'|X'11' -19|1|32|3200|32000000|32000000000|1985-08-07 00:00:00|5.21|18|018|X'12121212'|X'12' -20|0|31|3100|31000000|31000000000|1985-08-08 00:00:00|4.95|19|019|X'1313131313'|X'13' -21|1|30|3000|30000000|30000000000|1985-08-09 00:00:00|4.71|20|020|X'14'|X'14' -22|0|29|2900|29000000|29000000000|1985-08-10 00:00:00|4.50|21|021|X'1515'|X'15' -23|1|28|2800|28000000|28000000000|1985-08-11 00:00:00|4.30|22|022|X'161616'|X'16' -24|0|27|2700|27000000|27000000000|1985-08-12 00:00:00|4.13|23|023|X'17171717'|X'17' -25|1|26|2600|26000000|26000000000|1985-08-13 00:00:00|3.96|24|024|X'1818181818'|X'18' -26|0|25|2500|25000000|25000000000|1985-08-14 00:00:00|3.81|25|025|X'19'|X'19' -27|1|24|2400|24000000|24000000000|1985-08-15 00:00:00|3.67|26|026|X'1A1A'|X'1A' -28|0|23|2300|23000000|23000000000|1985-08-16 00:00:00|3.54|27|027|X'1B1B1B'|X'1B' -29|1|22|2200|22000000|22000000000|1985-08-17 00:00:00|3.41|28|028|X'1C1C1C1C'|X'1C' -30|0|21|2100|21000000|21000000000|1985-08-18 00:00:00|3.30|29|029|X'1D1D1D1D1D'|X'1D' -31|1|20|2000|20000000|20000000000|1985-08-19 00:00:00|3.19|30|030|X'1E'|X'1E' -32|0|19|1900|19000000|19000000000|1985-08-20 00:00:00|3.09|31|031|X'1F1F'|X'1F' -33|1|18|1800|18000000|18000000000|1985-08-21 00:00:00|3.00|32|032|X'202020'|X'20' -34|0|17|1700|17000000|17000000000|1985-08-22 00:00:00|2.91|33|033|X'21212121'|X'21' -35|1|16|1600|16000000|16000000000|1985-08-23 00:00:00|2.83|34|034|X'2222222222'|X'22' -36|0|15|1500|15000000|15000000000|1985-08-24 00:00:00|2.75|35|035|X'23'|X'23' -37|1|14|1400|14000000|14000000000|1985-08-25 00:00:00|2.68|36|036|X'2424'|X'24' -38|0|13|1300|13000000|13000000000|1985-08-26 00:00:00|2.61|37|037|X'252525'|X'25' -39|1|12|1200|12000000|12000000000|1985-08-27 00:00:00|2.54|38|038|X'26262626'|X'26' -40|0|11|1100|11000000|11000000000|1985-08-28 00:00:00|2.48|39|039|X'2727272727'|X'27' -41|1|10|1000|10000000|10000000000|1985-08-29 00:00:00|2.41|40|040|X'28'|X'28' -42|0|9|900|9000000|9000000000|1985-08-30 00:00:00|2.36|41|041|X'2929'|X'29' -43|1|8|800|8000000|8000000000|1985-08-31 00:00:00|2.30|42|042|X'2A2A2A'|X'2A' -44|0|7|700|7000000|7000000000|1985-09-01 00:00:00|2.25|43|043|X'2B2B2B2B'|X'2B' -45|1|6|600|6000000|6000000000|1985-09-02 00:00:00|2.20|44|044|X'2C2C2C2C2C'|X'2C' -46|0|5|500|5000000|5000000000|1985-09-03 00:00:00|2.15|45|045|X'2D'|X'2D' -47|1|4|400|4000000|4000000000|1985-09-04 00:00:00|2.11|46|046|X'2E2E'|X'2E' -48|0|3|300|3000000|3000000000|1985-09-05 00:00:00|2.06|47|047|X'2F2F2F'|X'2F' -49|1|2|200|2000000|2000000000|1985-09-06 00:00:00|2.02|48|048|X'30303030'|X'30' -50|0|1|100|1000000|1000000000|1985-09-07 00:00:00|1.98|49|049|X'3131313131'|X'31' -51|1|0|0|0|0|1985-09-08 00:00:00|1.94|50|050|X'32'|X'32' -52|0|-1|-100|-1000000|-1000000000|1985-09-09 00:00:00|1.90|51|051|X'3333'|X'33' -53|1|-2|-200|-2000000|-2000000000|1985-09-10 00:00:00|1.87|52|052|X'343434'|X'34' -54|0|-3|-300|-3000000|-3000000000|1985-09-11 00:00:00|1.83|53|053|X'35353535'|X'35' -55|1|-4|-400|-4000000|-4000000000|1985-09-12 00:00:00|1.80|54|054|X'3636363636'|X'36' -56|0|-5|-500|-5000000|-5000000000|1985-09-13 00:00:00|1.77|55|055|X'37'|X'37' -57|1|-6|-600|-6000000|-6000000000|1985-09-14 00:00:00|1.74|56|056|X'3838'|X'38' -58|0|-7|-700|-7000000|-7000000000|1985-09-15 00:00:00|1.71|57|057|X'393939'|X'39' -59|1|-8|-800|-8000000|-8000000000|1985-09-16 00:00:00|1.68|58|058|X'3A3A3A3A'|X'3A' -60|0|-9|-900|-9000000|-9000000000|1985-09-17 00:00:00|1.65|59|059|X'3B3B3B3B3B'|X'3B' -61|1|-10|-1000|-10000000|-10000000000|1985-09-18 00:00:00|1.62|60|060|X'3C'|X'3C' -62|0|-11|-1100|-11000000|-11000000000|1985-09-19 00:00:00|1.60|61|061|X'3D3D'|X'3D' -63|1|-12|-1200|-12000000|-12000000000|1985-09-20 00:00:00|1.57|62|062|X'3E3E3E'|X'3E' -64|0|-13|-1300|-13000000|-13000000000|1985-09-21 00:00:00|1.55|63|063|X'3F3F3F3F'|X'3F' -65|1|-14|-1400|-14000000|-14000000000|1985-09-22 00:00:00|1.52|64|064|X'4040404040'|X'40' -66|0|-15|-1500|-15000000|-15000000000|1985-09-23 00:00:00|1.50|65|065|X'41'|X'41' -67|1|-16|-1600|-16000000|-16000000000|1985-09-24 00:00:00|1.48|66|066|X'4242'|X'42' -68|0|-17|-1700|-17000000|-17000000000|1985-09-25 00:00:00|1.46|67|067|X'434343'|X'43' -69|1|-18|-1800|-18000000|-18000000000|1985-09-26 00:00:00|1.43|68|068|X'44444444'|X'44' -70|0|-19|-1900|-19000000|-19000000000|1985-09-27 00:00:00|1.41|69|069|X'4545454545'|X'45' -71|1|-20|-2000|-20000000|-20000000000|1985-09-28 00:00:00|1.39|70|070|X'46'|X'46' -72|0|-21|-2100|-21000000|-21000000000|1985-09-29 00:00:00|1.38|71|071|X'4747'|X'47' -73|1|-22|-2200|-22000000|-22000000000|1985-09-30 00:00:00|1.36|72|072|X'484848'|X'48' -74|0|-23|-2300|-23000000|-23000000000|1985-10-01 00:00:00|1.34|73|073|X'49494949'|X'49' -75|1|-24|-2400|-24000000|-24000000000|1985-10-02 00:00:00|1.32|74|074|X'4A4A4A4A4A'|X'4A' -76|0|-25|-2500|-25000000|-25000000000|1985-10-03 00:00:00|1.30|75|075|X'4B'|X'4B' -77|1|-26|-2600|-26000000|-26000000000|1985-10-04 00:00:00|1.29|76|076|X'4C4C'|X'4C' -78|0|-27|-2700|-27000000|-27000000000|1985-10-05 00:00:00|1.27|77|077|X'4D4D4D'|X'4D' -79|1|-28|-2800|-28000000|-28000000000|1985-10-06 00:00:00|1.25|78|078|X'4E4E4E4E'|X'4E' -80|0|-29|-2900|-29000000|-29000000000|1985-10-07 00:00:00|1.24|79|079|X'4F4F4F4F4F'|X'4F' -81|1|-30|-3000|-30000000|-30000000000|1985-10-08 00:00:00|1.22|80|080|X'50'|X'50' -82|0|-31|-3100|-31000000|-31000000000|1985-10-09 00:00:00|1.21|81|081|X'5151'|X'51' -83|1|-32|-3200|-32000000|-32000000000|1985-10-10 00:00:00|1.19|82|082|X'525252'|X'52' -84|0|-33|-3300|-33000000|-33000000000|1985-10-11 00:00:00|1.18|83|083|X'53535353'|X'53' -85|1|-34|-3400|-34000000|-34000000000|1985-10-12 00:00:00|1.16|84|084|X'5454545454'|X'54' -86|0|-35|-3500|-35000000|-35000000000|1985-10-13 00:00:00|1.15|85|085|X'55'|X'55' -87|1|-36|-3600|-36000000|-36000000000|1985-10-14 00:00:00|1.14|86|086|X'5656'|X'56' -88|0|-37|-3700|-37000000|-37000000000|1985-10-15 00:00:00|1.13|87|087|X'575757'|X'57' -89|1|-38|-3800|-38000000|-38000000000|1985-10-16 00:00:00|1.11|88|088|X'58585858'|X'58' -90|0|-39|-3900|-39000000|-39000000000|1985-10-17 00:00:00|1.10|89|089|X'5959595959'|X'59' -91|1|-40|-4000|-40000000|-40000000000|1985-10-18 00:00:00|1.09|90|090|X'5A'|X'5A' -92|0|-41|-4100|-41000000|-41000000000|1985-10-19 00:00:00|1.08|91|091|X'5B5B'|X'5B' -93|1|-42|-4200|-42000000|-42000000000|1985-10-20 00:00:00|1.06|92|092|X'5C5C5C'|X'5C' -94|0|-43|-4300|-43000000|-43000000000|1985-10-21 00:00:00|1.05|93|093|X'5D5D5D5D'|X'5D' -95|1|-44|-4400|-44000000|-44000000000|1985-10-22 00:00:00|1.04|94|094|X'5E5E5E5E5E'|X'5E' -96|0|-45|-4500|-45000000|-45000000000|1985-10-23 00:00:00|1.03|95|095|X'5F'|X'5F' -97|1|-46|-4600|-46000000|-46000000000|1985-10-24 00:00:00|1.02|96|096|X'6060'|X'60' -98|0|-47|-4700|-47000000|-47000000000|1985-10-25 00:00:00|1.01|97|097|X'616161'|X'61' -99|1|-48|-4800|-48000000|-48000000000|1985-10-26 00:00:00|1.00|98|098|X'62626262'|X'62' diff --git a/tests/templates/003-cross-join-count-1-rowgroup.sql b/tests/templates/003-cross-join-count-1-rowgroup.sql deleted file mode 100644 index 18cdd23..0000000 --- a/tests/templates/003-cross-join-count-1-rowgroup.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from (select * from no_nulls1 t1, no_nulls1 t2); -9801 diff --git a/tests/templates/004-cross-join-10-rowgroups.sql b/tests/templates/004-cross-join-10-rowgroups.sql deleted file mode 100644 index 92a8c73..0000000 --- a/tests/templates/004-cross-join-10-rowgroups.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from (select * from no_nulls1 t1, no_nulls2 t2); -9801 diff --git a/tests/templates/005-rowid-1-rowgroup.sql b/tests/templates/005-rowid-1-rowgroup.sql deleted file mode 100644 index 5a136cb..0000000 --- a/tests/templates/005-rowid-1-rowgroup.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from no_nulls1 where rowid = 51; -0 diff --git a/tests/templates/007-rowid-55-10-rowgroups.sql b/tests/templates/007-rowid-55-10-rowgroups.sql deleted file mode 100644 index 624d521..0000000 --- a/tests/templates/007-rowid-55-10-rowgroups.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from no_nulls1 where rowid = 56; --5 diff --git a/tests/templates/008-nulls.sql b/tests/templates/008-nulls.sql deleted file mode 100644 index 1f4c57d..0000000 --- a/tests/templates/008-nulls.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT SUM(CASE WHEN bool_0 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN int8_1 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN int16_2 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN int32_3 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN int64_4 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN ts_5 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN double_6 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN string_7 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN string_8 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN binary_9 IS NULL THEN 1 ELSE 0 END), SUM(CASE WHEN binary_10 IS NULL THEN 1 ELSE 0 END) from nulls1; -50|49|50|49|50|49|50|49|50|49|50 diff --git a/tests/templates/009-rowid-group-by.sql b/tests/templates/009-rowid-group-by.sql deleted file mode 100644 index d607139..0000000 --- a/tests/templates/009-rowid-group-by.sql +++ /dev/null @@ -1,11 +0,0 @@ -select rowid % 10, count(*) from nulls1 group by 1 order by 1 -0|9 -1|10 -2|10 -3|10 -4|10 -5|10 -6|10 -7|10 -8|10 -9|10 diff --git a/tests/templates/010-order-by-string7.sql b/tests/templates/010-order-by-string7.sql deleted file mode 100644 index e3d3efd..0000000 --- a/tests/templates/010-order-by-string7.sql +++ /dev/null @@ -1,100 +0,0 @@ -select string_7 from no_nulls1 order by string_7 -0 -1 -10 -11 -12 -13 -14 -15 -16 -17 -18 -19 -2 -20 -21 -22 -23 -24 -25 -26 -27 -28 -29 -3 -30 -31 -32 -33 -34 -35 -36 -37 -38 -39 -4 -40 -41 -42 -43 -44 -45 -46 -47 -48 -49 -5 -50 -51 -52 -53 -54 -55 -56 -57 -58 -59 -6 -60 -61 -62 -63 -64 -65 -66 -67 -68 -69 -7 -70 -71 -72 -73 -74 -75 -76 -77 -78 -79 -8 -80 -81 -82 -83 -84 -85 -86 -87 -88 -89 -9 -90 -91 -92 -93 -94 -95 -96 -97 -98 diff --git a/tests/templates/011-order-by-string8.sql b/tests/templates/011-order-by-string8.sql deleted file mode 100644 index d2ff653..0000000 --- a/tests/templates/011-order-by-string8.sql +++ /dev/null @@ -1,100 +0,0 @@ -select string_8 from no_nulls1 order by string_8 -000 -001 -002 -003 -004 -005 -006 -007 -008 -009 -010 -011 -012 -013 -014 -015 -016 -017 -018 -019 -020 -021 -022 -023 -024 -025 -026 -027 -028 -029 -030 -031 -032 -033 -034 -035 -036 -037 -038 -039 -040 -041 -042 -043 -044 -045 -046 -047 -048 -049 -050 -051 -052 -053 -054 -055 -056 -057 -058 -059 -060 -061 -062 -063 -064 -065 -066 -067 -068 -069 -070 -071 -072 -073 -074 -075 -076 -077 -078 -079 -080 -081 -082 -083 -084 -085 -086 -087 -088 -089 -090 -091 -092 -093 -094 -095 -096 -097 -098 diff --git a/tests/templates/012-string-7-is-null.sql b/tests/templates/012-string-7-is-null.sql deleted file mode 100644 index e79bacc..0000000 --- a/tests/templates/012-string-7-is-null.sql +++ /dev/null @@ -1,50 +0,0 @@ -select rowid, bool_0, quote(binary_10) from nulls1 where string_7 is null -11||NULL -12||NULL -13||NULL -14||NULL -15||NULL -16||NULL -17||NULL -18||NULL -19||NULL -20||NULL -22|0|X'15' -24|0|X'17' -26|0|X'19' -28|0|X'1B' -30|0|X'1D' -32|0|X'1F' -34|0|X'21' -36|0|X'23' -38|0|X'25' -40|0|X'27' -42|0|X'29' -44|0|X'2B' -46|0|X'2D' -48|0|X'2F' -50|0|X'31' -52|0|X'33' -54|0|X'35' -56|0|X'37' -58|0|X'39' -60|0|X'3B' -62|0|X'3D' -64|0|X'3F' -66|0|X'41' -68|0|X'43' -70|0|X'45' -72|0|X'47' -74|0|X'49' -76|0|X'4B' -78|0|X'4D' -80|0|X'4F' -82|0|X'51' -84|0|X'53' -86|0|X'55' -88|0|X'57' -90|0|X'59' -92|0|X'5B' -94|0|X'5D' -96|0|X'5F' -98|0|X'61' diff --git a/tests/templates/013-string-7-is-not-null.sql b/tests/templates/013-string-7-is-not-null.sql deleted file mode 100644 index 2722426..0000000 --- a/tests/templates/013-string-7-is-not-null.sql +++ /dev/null @@ -1,51 +0,0 @@ -select rowid, bool_0, quote(binary_10) from nulls1 where string_7 is not null -1|1|X'00' -2|0|X'01' -3|1|X'02' -4|0|X'03' -5|1|X'04' -6|0|X'05' -7|1|X'06' -8|0|X'07' -9|1|X'08' -10|0|X'09' -21||NULL -23||NULL -25||NULL -27||NULL -29||NULL -31||NULL -33||NULL -35||NULL -37||NULL -39||NULL -41||NULL -43||NULL -45||NULL -47||NULL -49||NULL -51||NULL -53||NULL -55||NULL -57||NULL -59||NULL -61||NULL -63||NULL -65||NULL -67||NULL -69||NULL -71||NULL -73||NULL -75||NULL -77||NULL -79||NULL -81||NULL -83||NULL -85||NULL -87||NULL -89||NULL -91||NULL -93||NULL -95||NULL -97||NULL -99||NULL diff --git a/tests/templates/014-nulls-like-percent-start.sql b/tests/templates/014-nulls-like-percent-start.sql deleted file mode 100644 index 35c4517..0000000 --- a/tests/templates/014-nulls-like-percent-start.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_7, string_8 from nulls1 where string_8 like '%0' -0|000 diff --git a/tests/templates/015-nulls-like-no-match.sql b/tests/templates/015-nulls-like-no-match.sql deleted file mode 100644 index 0ec13dc..0000000 --- a/tests/templates/015-nulls-like-no-match.sql +++ /dev/null @@ -1 +0,0 @@ -select string_7, string_8 from nulls1 where string_8 like '0' diff --git a/tests/templates/016-nulls-like-percent-end.sql b/tests/templates/016-nulls-like-percent-end.sql deleted file mode 100644 index f12a894..0000000 --- a/tests/templates/016-nulls-like-percent-end.sql +++ /dev/null @@ -1,50 +0,0 @@ -select string_7, string_8 from nulls1 where string_8 like '0%' -0|000 -1|001 -2|002 -3|003 -4|004 -5|005 -6|006 -7|007 -8|008 -9|009 -|021 -|023 -|025 -|027 -|029 -|031 -|033 -|035 -|037 -|039 -|041 -|043 -|045 -|047 -|049 -|051 -|053 -|055 -|057 -|059 -|061 -|063 -|065 -|067 -|069 -|071 -|073 -|075 -|077 -|079 -|081 -|083 -|085 -|087 -|089 -|091 -|093 -|095 -|097 diff --git a/tests/templates/017-nulls-like-underscore.sql b/tests/templates/017-nulls-like-underscore.sql deleted file mode 100644 index 680203b..0000000 --- a/tests/templates/017-nulls-like-underscore.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_7, string_8 from nulls1 where string_8 like '0_0' -0|000 diff --git a/tests/templates/018-string-gt-lt.sql b/tests/templates/018-string-gt-lt.sql deleted file mode 100644 index 8775ee0..0000000 --- a/tests/templates/018-string-gt-lt.sql +++ /dev/null @@ -1,3 +0,0 @@ -select string_8 from nulls1 where string_8 > '010' and string_8 < '024' -021 -023 diff --git a/tests/templates/019-string-gte-lte.sql b/tests/templates/019-string-gte-lte.sql deleted file mode 100644 index 128a2fc..0000000 --- a/tests/templates/019-string-gte-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_8 from nulls1 where string_8 >= '021' and string_8 <= '021' -021 diff --git a/tests/templates/020-string-eq.sql b/tests/templates/020-string-eq.sql deleted file mode 100644 index 6c7d9f4..0000000 --- a/tests/templates/020-string-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_8 from nulls1 where string_8 = '021' -021 diff --git a/tests/templates/021-rowid-and-field-eq.sql b/tests/templates/021-rowid-and-field-eq.sql deleted file mode 100644 index 904f929..0000000 --- a/tests/templates/021-rowid-and-field-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_8 from nulls1 where rowid = 22 and string_8 = '021' -021 diff --git a/tests/templates/022-rowid-and-field-ne.sql b/tests/templates/022-rowid-and-field-ne.sql deleted file mode 100644 index 3afbd13..0000000 --- a/tests/templates/022-rowid-and-field-ne.sql +++ /dev/null @@ -1 +0,0 @@ -select string_8 from nulls1 where rowid = 22 and string_8 <> '021' diff --git a/tests/templates/023-int8-eq.sql b/tests/templates/023-int8-eq.sql deleted file mode 100644 index 95213ae..0000000 --- a/tests/templates/023-int8-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 = 30 -30 diff --git a/tests/templates/024-int8-lt.sql b/tests/templates/024-int8-lt.sql deleted file mode 100644 index 64cf4ec..0000000 --- a/tests/templates/024-int8-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 < -46 --48 diff --git a/tests/templates/025-int8-lte.sql b/tests/templates/025-int8-lte.sql deleted file mode 100644 index 4647fcb..0000000 --- a/tests/templates/025-int8-lte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 <= -46 --46 --48 diff --git a/tests/templates/026-int8-gt.sql b/tests/templates/026-int8-gt.sql deleted file mode 100644 index 2dd1398..0000000 --- a/tests/templates/026-int8-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 > 49 -50 diff --git a/tests/templates/027-int8-gte.sql b/tests/templates/027-int8-gte.sql deleted file mode 100644 index bf19539..0000000 --- a/tests/templates/027-int8-gte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 >= 49 -50 -49 diff --git a/tests/templates/028-int8-rowid-eq-and-field-ne.sql b/tests/templates/028-int8-rowid-eq-and-field-ne.sql deleted file mode 100644 index cceeca7..0000000 --- a/tests/templates/028-int8-rowid-eq-and-field-ne.sql +++ /dev/null @@ -1 +0,0 @@ -select int8_1 from nulls1 where rowid = 66 and int8_1 <> -16 diff --git a/tests/templates/029-int64-gte.sql b/tests/templates/029-int64-gte.sql deleted file mode 100644 index 8215392..0000000 --- a/tests/templates/029-int64-gte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 >= 49000000000 -50000000000 -49000000000 diff --git a/tests/templates/030-int64-gt.sql b/tests/templates/030-int64-gt.sql deleted file mode 100644 index 274f56a..0000000 --- a/tests/templates/030-int64-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 > 49000000000 -50000000000 diff --git a/tests/templates/031-int64-eq.sql b/tests/templates/031-int64-eq.sql deleted file mode 100644 index 88df198..0000000 --- a/tests/templates/031-int64-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 = 49000000000 -49000000000 diff --git a/tests/templates/032-int64-lt.sql b/tests/templates/032-int64-lt.sql deleted file mode 100644 index 7fa5e4e..0000000 --- a/tests/templates/032-int64-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 < -46000000000 --47000000000 diff --git a/tests/templates/033-int64-lte.sql b/tests/templates/033-int64-lte.sql deleted file mode 100644 index 0d305c2..0000000 --- a/tests/templates/033-int64-lte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 <= -45000000000 --45000000000 --47000000000 diff --git a/tests/templates/034-int64-rowid-eq-and-field-ne.sql b/tests/templates/034-int64-rowid-eq-and-field-ne.sql deleted file mode 100644 index e5c1c36..0000000 --- a/tests/templates/034-int64-rowid-eq-and-field-ne.sql +++ /dev/null @@ -1 +0,0 @@ -select int64_4 from nulls1 where rowid = 57 and int64_4 <> -7000000000 diff --git a/tests/templates/035-int64-rowid-eq-and-field-ne2.sql b/tests/templates/035-int64-rowid-eq-and-field-ne2.sql deleted file mode 100644 index 1c86f0a..0000000 --- a/tests/templates/035-int64-rowid-eq-and-field-ne2.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where rowid = 58 and int64_4 <> -8000000000 --7000000000 diff --git a/tests/templates/036-double-eq.sql b/tests/templates/036-double-eq.sql deleted file mode 100644 index 3439e49..0000000 --- a/tests/templates/036-double-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 = 99.0 -99.00 diff --git a/tests/templates/037-double-gt.sql b/tests/templates/037-double-gt.sql deleted file mode 100644 index 0636e5f..0000000 --- a/tests/templates/037-double-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 > 98.0 -99.00 diff --git a/tests/templates/038-double-gte.sql b/tests/templates/038-double-gte.sql deleted file mode 100644 index 8e7536f..0000000 --- a/tests/templates/038-double-gte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 >= 49.5 -99.00 -49.50 diff --git a/tests/templates/039-double-lt.sql b/tests/templates/039-double-lt.sql deleted file mode 100644 index 716e6d7..0000000 --- a/tests/templates/039-double-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 < 99.0 order by double_6 desc limit 1 -49.50 diff --git a/tests/templates/040-double-lte.sql b/tests/templates/040-double-lte.sql deleted file mode 100644 index a071b2c..0000000 --- a/tests/templates/040-double-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 <= 99.0 order by double_6 desc limit 1 -99.00 diff --git a/tests/templates/041-double-rowid-and-field-ne.sql b/tests/templates/041-double-rowid-and-field-ne.sql deleted file mode 100644 index ef9404e..0000000 --- a/tests/templates/041-double-rowid-and-field-ne.sql +++ /dev/null @@ -1 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 0 and double_6 <> 99.0 diff --git a/tests/templates/042-double-rowid-and-field-ne2.sql b/tests/templates/042-double-rowid-and-field-ne2.sql deleted file mode 100644 index d1c778b..0000000 --- a/tests/templates/042-double-rowid-and-field-ne2.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 1 and double_6 <> 100.0 -99.00 diff --git a/tests/templates/043-binary-eq.sql b/tests/templates/043-binary-eq.sql deleted file mode 100644 index e719042..0000000 --- a/tests/templates/043-binary-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select rowid from nulls1 where binary_10 = x'01'; -2 diff --git a/tests/templates/044-binary-rowid-and-ne.sql b/tests/templates/044-binary-rowid-and-ne.sql deleted file mode 100644 index 0a5d11d..0000000 --- a/tests/templates/044-binary-rowid-and-ne.sql +++ /dev/null @@ -1 +0,0 @@ -select rowid from nulls1 where rowid = 2 and binary_10 <> x'01'; diff --git a/tests/templates/045-binary-lt.sql b/tests/templates/045-binary-lt.sql deleted file mode 100644 index d640862..0000000 --- a/tests/templates/045-binary-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select rowid from nulls1 where binary_10 < x'01'; -1 diff --git a/tests/templates/046-binary-lte.sql b/tests/templates/046-binary-lte.sql deleted file mode 100644 index 8b07fe9..0000000 --- a/tests/templates/046-binary-lte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select rowid from nulls1 where binary_10 <= x'01' order by 1; -1 -2 diff --git a/tests/templates/047-binary-gt.sql b/tests/templates/047-binary-gt.sql deleted file mode 100644 index bd10f01..0000000 --- a/tests/templates/047-binary-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select rowid from nulls1 where binary_10 > x'60'; -98 diff --git a/tests/templates/048-binary-gte.sql b/tests/templates/048-binary-gte.sql deleted file mode 100644 index d8c3030..0000000 --- a/tests/templates/048-binary-gte.sql +++ /dev/null @@ -1,3 +0,0 @@ -select rowid from nulls1 where binary_10 >= x'5F' order by 1; -96 -98 diff --git a/tests/templates/049-unusable-constraint.sql b/tests/templates/049-unusable-constraint.sql deleted file mode 100644 index 8023fc8..0000000 --- a/tests/templates/049-unusable-constraint.sql +++ /dev/null @@ -1,2 +0,0 @@ -select nn1.int8_1 from no_nulls1 nn1 join no_nulls2 nn2 using (int8_1) where nn1.int8_1 = 0; -0 diff --git a/tests/templates/050-rowid-gt-none.sql b/tests/templates/050-rowid-gt-none.sql deleted file mode 100644 index 6ebb920..0000000 --- a/tests/templates/050-rowid-gt-none.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid > 100 -0 diff --git a/tests/templates/051-rowid-gte-none.sql b/tests/templates/051-rowid-gte-none.sql deleted file mode 100644 index 00b2eef..0000000 --- a/tests/templates/051-rowid-gte-none.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid >= 100 -0 diff --git a/tests/templates/052-rowid-lt-none.sql b/tests/templates/052-rowid-lt-none.sql deleted file mode 100644 index 0c28165..0000000 --- a/tests/templates/052-rowid-lt-none.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid < 0 -0 diff --git a/tests/templates/053-rowid-lte-none.sql b/tests/templates/053-rowid-lte-none.sql deleted file mode 100644 index 2545b46..0000000 --- a/tests/templates/053-rowid-lte-none.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid < -1 -0 diff --git a/tests/templates/054-rowid-lte-one.sql b/tests/templates/054-rowid-lte-one.sql deleted file mode 100644 index d5651df..0000000 --- a/tests/templates/054-rowid-lte-one.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid <= 1 -1 diff --git a/tests/templates/055-rowid-lt-one.sql b/tests/templates/055-rowid-lt-one.sql deleted file mode 100644 index bff3003..0000000 --- a/tests/templates/055-rowid-lt-one.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid < 2 -1 diff --git a/tests/templates/056-rowid-ne-some.sql b/tests/templates/056-rowid-ne-some.sql deleted file mode 100644 index fecfaad..0000000 --- a/tests/templates/056-rowid-ne-some.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid <> 1 -98 diff --git a/tests/templates/057-rowid-is-null.sql b/tests/templates/057-rowid-is-null.sql deleted file mode 100644 index 19d15af..0000000 --- a/tests/templates/057-rowid-is-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid is null -0 diff --git a/tests/templates/058-rowid-is-not-null.sql b/tests/templates/058-rowid-is-not-null.sql deleted file mode 100644 index ad1478c..0000000 --- a/tests/templates/058-rowid-is-not-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid is not null -99 diff --git a/tests/templates/059-rowid-eq-string.sql b/tests/templates/059-rowid-eq-string.sql deleted file mode 100644 index ffe4244..0000000 --- a/tests/templates/059-rowid-eq-string.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid = '1' -1 diff --git a/tests/templates/060-rowid-double.sql b/tests/templates/060-rowid-double.sql deleted file mode 100644 index 7778eda..0000000 --- a/tests/templates/060-rowid-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from no_nulls1 where rowid = 51.0; -0 diff --git a/tests/templates/061-string-eq-int.sql b/tests/templates/061-string-eq-int.sql deleted file mode 100644 index e9bc52e..0000000 --- a/tests/templates/061-string-eq-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_7 from nulls1 where string_7 = 22; -22 diff --git a/tests/templates/062-string-eq-double.sql b/tests/templates/062-string-eq-double.sql deleted file mode 100644 index 6ea46c4..0000000 --- a/tests/templates/062-string-eq-double.sql +++ /dev/null @@ -1 +0,0 @@ -select string_7 from nulls1 where string_7 = 22.0; diff --git a/tests/templates/063-int8-eq-double.sql b/tests/templates/063-int8-eq-double.sql deleted file mode 100644 index 76c9223..0000000 --- a/tests/templates/063-int8-eq-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 = 30.0; -30 diff --git a/tests/templates/064-int8-eq-str.sql b/tests/templates/064-int8-eq-str.sql deleted file mode 100644 index 53cc566..0000000 --- a/tests/templates/064-int8-eq-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 = '30.0'; -30 diff --git a/tests/templates/065-int8-eq-str2.sql b/tests/templates/065-int8-eq-str2.sql deleted file mode 100644 index 54fd20a..0000000 --- a/tests/templates/065-int8-eq-str2.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 = '30'; -30 diff --git a/tests/templates/066-int8-eq-bogus-str.sql b/tests/templates/066-int8-eq-bogus-str.sql deleted file mode 100644 index f427a87..0000000 --- a/tests/templates/066-int8-eq-bogus-str.sql +++ /dev/null @@ -1 +0,0 @@ -select int8_1 from nulls1 where int8_1 = '30f'; diff --git a/tests/templates/067-int8-lt-str.sql b/tests/templates/067-int8-lt-str.sql deleted file mode 100644 index 1cddf5d..0000000 --- a/tests/templates/067-int8-lt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 < '-46' --48 diff --git a/tests/templates/068-int8-lt-double.sql b/tests/templates/068-int8-lt-double.sql deleted file mode 100644 index d3e90d4..0000000 --- a/tests/templates/068-int8-lt-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 < -46.0 --48 diff --git a/tests/templates/069-int8-lte-str.sql b/tests/templates/069-int8-lte-str.sql deleted file mode 100644 index 2a2e041..0000000 --- a/tests/templates/069-int8-lte-str.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 <= '-46' --46 --48 diff --git a/tests/templates/070-int8-lte-double.sql b/tests/templates/070-int8-lte-double.sql deleted file mode 100644 index d6375b8..0000000 --- a/tests/templates/070-int8-lte-double.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 <= -46.0 --46 --48 diff --git a/tests/templates/071-int8-gt-str.sql b/tests/templates/071-int8-gt-str.sql deleted file mode 100644 index fa71236..0000000 --- a/tests/templates/071-int8-gt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 > '49' -50 diff --git a/tests/templates/072-int8-gt-double.sql b/tests/templates/072-int8-gt-double.sql deleted file mode 100644 index 8cbc669..0000000 --- a/tests/templates/072-int8-gt-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int8_1 from nulls1 where int8_1 > 49.0 -50 diff --git a/tests/templates/073-int8-gte-str.sql b/tests/templates/073-int8-gte-str.sql deleted file mode 100644 index 14c83be..0000000 --- a/tests/templates/073-int8-gte-str.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 >= '49' -50 -49 diff --git a/tests/templates/074-int8-gte-double.sql b/tests/templates/074-int8-gte-double.sql deleted file mode 100644 index f61e158..0000000 --- a/tests/templates/074-int8-gte-double.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int8_1 from nulls1 where int8_1 >= 49.0 -50 -49 diff --git a/tests/templates/075-int8-ne-str.sql b/tests/templates/075-int8-ne-str.sql deleted file mode 100644 index 25742a7..0000000 --- a/tests/templates/075-int8-ne-str.sql +++ /dev/null @@ -1 +0,0 @@ -select int8_1 from nulls1 where rowid = 66 and int8_1 <> '-16' diff --git a/tests/templates/076-int8-ne-double.sql b/tests/templates/076-int8-ne-double.sql deleted file mode 100644 index 958b4ed..0000000 --- a/tests/templates/076-int8-ne-double.sql +++ /dev/null @@ -1 +0,0 @@ -select int8_1 from nulls1 where rowid = 66 and int8_1 <> -16.0 diff --git a/tests/templates/077-int64-gte-str.sql b/tests/templates/077-int64-gte-str.sql deleted file mode 100644 index ce32e12..0000000 --- a/tests/templates/077-int64-gte-str.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 >= '49000000000' -50000000000 -49000000000 diff --git a/tests/templates/078-int64-gte-double.sql b/tests/templates/078-int64-gte-double.sql deleted file mode 100644 index 684a87c..0000000 --- a/tests/templates/078-int64-gte-double.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 >= 49000000000.0 -50000000000 -49000000000 diff --git a/tests/templates/079-int65-gt-str.sql b/tests/templates/079-int65-gt-str.sql deleted file mode 100644 index 3f73f86..0000000 --- a/tests/templates/079-int65-gt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 > '49000000000' -50000000000 diff --git a/tests/templates/080-int65-gt-double.sql b/tests/templates/080-int65-gt-double.sql deleted file mode 100644 index fbd4489..0000000 --- a/tests/templates/080-int65-gt-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 > 49000000000.0 -50000000000 diff --git a/tests/templates/081-int64-eq-str.sql b/tests/templates/081-int64-eq-str.sql deleted file mode 100644 index fec63b6..0000000 --- a/tests/templates/081-int64-eq-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 = '49000000000' -49000000000 diff --git a/tests/templates/082-int64-eq-double.sql b/tests/templates/082-int64-eq-double.sql deleted file mode 100644 index f938657..0000000 --- a/tests/templates/082-int64-eq-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 = 49000000000.0 -49000000000 diff --git a/tests/templates/083-int64-lt-str.sql b/tests/templates/083-int64-lt-str.sql deleted file mode 100644 index 306fa80..0000000 --- a/tests/templates/083-int64-lt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 < '-46000000000' --47000000000 diff --git a/tests/templates/084-int64-lt-double.sql b/tests/templates/084-int64-lt-double.sql deleted file mode 100644 index d905218..0000000 --- a/tests/templates/084-int64-lt-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where int64_4 < -46000000000.0 --47000000000 diff --git a/tests/templates/085-int64-lte-str.sql b/tests/templates/085-int64-lte-str.sql deleted file mode 100644 index eef3607..0000000 --- a/tests/templates/085-int64-lte-str.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 <= '-45000000000' --45000000000 --47000000000 diff --git a/tests/templates/086-int64-lte-double.sql b/tests/templates/086-int64-lte-double.sql deleted file mode 100644 index dfc225b..0000000 --- a/tests/templates/086-int64-lte-double.sql +++ /dev/null @@ -1,3 +0,0 @@ -select int64_4 from nulls1 where int64_4 <= -45000000000.0 --45000000000 --47000000000 diff --git a/tests/templates/087-int64-ne-str.sql b/tests/templates/087-int64-ne-str.sql deleted file mode 100644 index 41a8718..0000000 --- a/tests/templates/087-int64-ne-str.sql +++ /dev/null @@ -1 +0,0 @@ -select int64_4 from nulls1 where rowid = 57 and int64_4 <> '-7000000000' diff --git a/tests/templates/088-int64-ne-double.sql b/tests/templates/088-int64-ne-double.sql deleted file mode 100644 index 40555f5..0000000 --- a/tests/templates/088-int64-ne-double.sql +++ /dev/null @@ -1 +0,0 @@ -select int64_4 from nulls1 where rowid = 57 and int64_4 <> -7000000000.0 diff --git a/tests/templates/089-int64-ne-some-str.sql b/tests/templates/089-int64-ne-some-str.sql deleted file mode 100644 index 020ea4b..0000000 --- a/tests/templates/089-int64-ne-some-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where rowid = 58 and int64_4 <> '-8000000000' --7000000000 diff --git a/tests/templates/090-int64-ne-some-double.sql b/tests/templates/090-int64-ne-some-double.sql deleted file mode 100644 index d9b3e06..0000000 --- a/tests/templates/090-int64-ne-some-double.sql +++ /dev/null @@ -1,2 +0,0 @@ -select int64_4 from nulls1 where rowid = 58 and int64_4 <> -8000000000.0 --7000000000 diff --git a/tests/templates/091-double-eq-str.sql b/tests/templates/091-double-eq-str.sql deleted file mode 100644 index 4e9af68..0000000 --- a/tests/templates/091-double-eq-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 = '99.0' -99.00 diff --git a/tests/templates/092-double-eq-int.sql b/tests/templates/092-double-eq-int.sql deleted file mode 100644 index e5b40fa..0000000 --- a/tests/templates/092-double-eq-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 = 99 -99.00 diff --git a/tests/templates/093-double-gt-str.sql b/tests/templates/093-double-gt-str.sql deleted file mode 100644 index 91198fc..0000000 --- a/tests/templates/093-double-gt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 > '98' -99.00 diff --git a/tests/templates/094-double-gt-int.sql b/tests/templates/094-double-gt-int.sql deleted file mode 100644 index be17f03..0000000 --- a/tests/templates/094-double-gt-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 > 98 -99.00 diff --git a/tests/templates/095-double-gte-str.sql b/tests/templates/095-double-gte-str.sql deleted file mode 100644 index 0b20634..0000000 --- a/tests/templates/095-double-gte-str.sql +++ /dev/null @@ -1,3 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 >= '49.5' -99.00 -49.50 diff --git a/tests/templates/096-double-gte-int.sql b/tests/templates/096-double-gte-int.sql deleted file mode 100644 index 9ff614c..0000000 --- a/tests/templates/096-double-gte-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) as double_6 from nulls1 where double_6 >= '99' -99.00 diff --git a/tests/templates/097-double-lt-str.sql b/tests/templates/097-double-lt-str.sql deleted file mode 100644 index 895815c..0000000 --- a/tests/templates/097-double-lt-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 < '99.0' order by double_6 desc limit 1 -49.50 diff --git a/tests/templates/098-double-lt-int.sql b/tests/templates/098-double-lt-int.sql deleted file mode 100644 index 2219f18..0000000 --- a/tests/templates/098-double-lt-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 < 99 order by double_6 desc limit 1 -49.50 diff --git a/tests/templates/099-double-lte-str.sql b/tests/templates/099-double-lte-str.sql deleted file mode 100644 index 2005580..0000000 --- a/tests/templates/099-double-lte-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 <= '99.0' order by double_6 desc limit 1 -99.00 diff --git a/tests/templates/100-double-lte-int.sql b/tests/templates/100-double-lte-int.sql deleted file mode 100644 index cef9659..0000000 --- a/tests/templates/100-double-lte-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where double_6 <= 99 order by double_6 desc limit 1 -99.00 diff --git a/tests/templates/101-double-rowid-and-field-ne-str.sql b/tests/templates/101-double-rowid-and-field-ne-str.sql deleted file mode 100644 index a7c8a8b..0000000 --- a/tests/templates/101-double-rowid-and-field-ne-str.sql +++ /dev/null @@ -1 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 0 and double_6 <> '99.0' diff --git a/tests/templates/102-double-rowid-and-field-ne-int.sql b/tests/templates/102-double-rowid-and-field-ne-int.sql deleted file mode 100644 index 91d8048..0000000 --- a/tests/templates/102-double-rowid-and-field-ne-int.sql +++ /dev/null @@ -1 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 0 and double_6 <> 99 diff --git a/tests/templates/103-double-rowid-and-field-ne2-some-str.sql b/tests/templates/103-double-rowid-and-field-ne2-some-str.sql deleted file mode 100644 index 2cbd9a8..0000000 --- a/tests/templates/103-double-rowid-and-field-ne2-some-str.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 1 and double_6 <> '100' -99.00 diff --git a/tests/templates/104-double-rowid-and-field-ne2-some-int.sql b/tests/templates/104-double-rowid-and-field-ne2-some-int.sql deleted file mode 100644 index bc49adc..0000000 --- a/tests/templates/104-double-rowid-and-field-ne2-some-int.sql +++ /dev/null @@ -1,2 +0,0 @@ -select printf('%.2f', double_6) from nulls1 where rowid = 1 and double_6 <> 100 -99.00 diff --git a/tests/templates/105-rowid-gte-0.sql b/tests/templates/105-rowid-gte-0.sql deleted file mode 100644 index 941d653..0000000 --- a/tests/templates/105-rowid-gte-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid >= 0 -99 diff --git a/tests/templates/106-rowid-gt-0.sql b/tests/templates/106-rowid-gt-0.sql deleted file mode 100644 index fa00ce7..0000000 --- a/tests/templates/106-rowid-gt-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where rowid > 1 -98 diff --git a/tests/templates/109-bool-where-eq-0.sql b/tests/templates/109-bool-where-eq-0.sql deleted file mode 100644 index c359765..0000000 --- a/tests/templates/109-bool-where-eq-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 = 0 -44 diff --git a/tests/templates/110-bool-where-eq-1.sql b/tests/templates/110-bool-where-eq-1.sql deleted file mode 100644 index 4596109..0000000 --- a/tests/templates/110-bool-where-eq-1.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 = 1 -5 diff --git a/tests/templates/111-bool-where-bool.sql b/tests/templates/111-bool-where-bool.sql deleted file mode 100644 index 22a9370..0000000 --- a/tests/templates/111-bool-where-bool.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 -5 diff --git a/tests/templates/112-bool-where-not-bool.sql b/tests/templates/112-bool-where-not-bool.sql deleted file mode 100644 index 73dd46c..0000000 --- a/tests/templates/112-bool-where-not-bool.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where not bool_0 -44 diff --git a/tests/templates/113-bool-where-gt-0.sql b/tests/templates/113-bool-where-gt-0.sql deleted file mode 100644 index 3c60dc5..0000000 --- a/tests/templates/113-bool-where-gt-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 > 0 -5 diff --git a/tests/templates/114-bool-where-gte-0.sql b/tests/templates/114-bool-where-gte-0.sql deleted file mode 100644 index 479b815..0000000 --- a/tests/templates/114-bool-where-gte-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 >= 0 -49 diff --git a/tests/templates/115-bool-where-gt-1.sql b/tests/templates/115-bool-where-gt-1.sql deleted file mode 100644 index 2f33d93..0000000 --- a/tests/templates/115-bool-where-gt-1.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 > 1 -0 diff --git a/tests/templates/116-bool-where-lt-0.sql b/tests/templates/116-bool-where-lt-0.sql deleted file mode 100644 index 7764906..0000000 --- a/tests/templates/116-bool-where-lt-0.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 < 0 -0 diff --git a/tests/templates/117-bool-where-lt-1.sql b/tests/templates/117-bool-where-lt-1.sql deleted file mode 100644 index 4066908..0000000 --- a/tests/templates/117-bool-where-lt-1.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 < 1 -44 diff --git a/tests/templates/118-bool-where-lte-1.sql b/tests/templates/118-bool-where-lte-1.sql deleted file mode 100644 index 0881aaf..0000000 --- a/tests/templates/118-bool-where-lte-1.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where bool_0 <= 1 -49 diff --git a/tests/templates/119-ts-eq-july-20.sql b/tests/templates/119-ts-eq-july-20.sql deleted file mode 100644 index c552939..0000000 --- a/tests/templates/119-ts-eq-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 = 490665600000 -1 diff --git a/tests/templates/120-ts-lt-july-20.sql b/tests/templates/120-ts-lt-july-20.sql deleted file mode 100644 index 2269103..0000000 --- a/tests/templates/120-ts-lt-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 < 490665600000 -0 diff --git a/tests/templates/121-ts-lte-july-20.sql b/tests/templates/121-ts-lte-july-20.sql deleted file mode 100644 index 44c3891..0000000 --- a/tests/templates/121-ts-lte-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 <= 490665600000 -1 diff --git a/tests/templates/122-ts-gt-july-20.sql b/tests/templates/122-ts-gt-july-20.sql deleted file mode 100644 index 126e0ce..0000000 --- a/tests/templates/122-ts-gt-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 > 490665600000 -49 diff --git a/tests/templates/123-ts-gte-july-20.sql b/tests/templates/123-ts-gte-july-20.sql deleted file mode 100644 index bf869e0..0000000 --- a/tests/templates/123-ts-gte-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 >= 490665600000 -50 diff --git a/tests/templates/124-ts-ne-july-20.sql b/tests/templates/124-ts-ne-july-20.sql deleted file mode 100644 index 1d4f330..0000000 --- a/tests/templates/124-ts-ne-july-20.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls1 where ts_5 <> 490665600000 -49 diff --git a/tests/templates/125-fixed-bytearray-eq.sql b/tests/templates/125-fixed-bytearray-eq.sql deleted file mode 100644 index 9c74478..0000000 --- a/tests/templates/125-fixed-bytearray-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 = X'10' -1 diff --git a/tests/templates/126-fixed-bytearray-lt.sql b/tests/templates/126-fixed-bytearray-lt.sql deleted file mode 100644 index b56c898..0000000 --- a/tests/templates/126-fixed-bytearray-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 < X'10' -16 diff --git a/tests/templates/127-fixed-bytearray-lte.sql b/tests/templates/127-fixed-bytearray-lte.sql deleted file mode 100644 index 4b94ce3..0000000 --- a/tests/templates/127-fixed-bytearray-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 <= X'10' -17 diff --git a/tests/templates/128-fixed-bytearray-gt.sql b/tests/templates/128-fixed-bytearray-gt.sql deleted file mode 100644 index 241f8d9..0000000 --- a/tests/templates/128-fixed-bytearray-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 > X'' -99 diff --git a/tests/templates/129-fixed-bytearray-gte.sql b/tests/templates/129-fixed-bytearray-gte.sql deleted file mode 100644 index b3a164c..0000000 --- a/tests/templates/129-fixed-bytearray-gte.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 >= X'01' -98 diff --git a/tests/templates/130-fixed-bytearray-ne.sql b/tests/templates/130-fixed-bytearray-ne.sql deleted file mode 100644 index 396b49b..0000000 --- a/tests/templates/130-fixed-bytearray-ne.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_10 <> X'10' -98 diff --git a/tests/templates/131-var-bytearray-eq.sql b/tests/templates/131-var-bytearray-eq.sql deleted file mode 100644 index 1971a04..0000000 --- a/tests/templates/131-var-bytearray-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 = X'020202' -1 diff --git a/tests/templates/132-var-bytearray-lt.sql b/tests/templates/132-var-bytearray-lt.sql deleted file mode 100644 index d68086a..0000000 --- a/tests/templates/132-var-bytearray-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM no_nulls1 WHERE binary_9 < X'020202' -2 diff --git a/tests/templates/133-var-bytearray-lte.sql b/tests/templates/133-var-bytearray-lte.sql deleted file mode 100644 index 8f66494..0000000 --- a/tests/templates/133-var-bytearray-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 <= X'0101' -2 diff --git a/tests/templates/134-var-bytearray-gt.sql b/tests/templates/134-var-bytearray-gt.sql deleted file mode 100644 index 6e86d53..0000000 --- a/tests/templates/134-var-bytearray-gt.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 > X'' -50 diff --git a/tests/templates/135-var-bytearray-gte.sql b/tests/templates/135-var-bytearray-gte.sql deleted file mode 100644 index 7494293..0000000 --- a/tests/templates/135-var-bytearray-gte.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 >= X'62626262' -1 diff --git a/tests/templates/136-var-bytearray-ne.sql b/tests/templates/136-var-bytearray-ne.sql deleted file mode 100644 index a1daf7d..0000000 --- a/tests/templates/136-var-bytearray-ne.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 <> X'62626262' -49 diff --git a/tests/templates/137-var-bytearray-lte.sql b/tests/templates/137-var-bytearray-lte.sql deleted file mode 100644 index 529a1ef..0000000 --- a/tests/templates/137-var-bytearray-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -SELECT COUNT(*) FROM nulls1 WHERE binary_9 <= X'01' -1 diff --git a/tests/templates/138-string-lte.sql b/tests/templates/138-string-lte.sql deleted file mode 100644 index d4c4966..0000000 --- a/tests/templates/138-string-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from no_nulls1 where string_8 <= '003' -4 diff --git a/tests/templates/139-random-testcase.sql b/tests/templates/139-random-testcase.sql deleted file mode 100644 index eb8d1e0..0000000 --- a/tests/templates/139-random-testcase.sql +++ /dev/null @@ -1,37 +0,0 @@ -select rowid from nulls1 where binary_9 >= '56' and ts_5 < 496886400000; -1 -2 -3 -4 -5 -6 -7 -8 -9 -10 -21 -23 -25 -27 -29 -31 -33 -35 -37 -39 -41 -43 -45 -47 -49 -51 -53 -55 -57 -59 -61 -63 -65 -67 -69 -71 diff --git a/tests/templates/140-random-testcase.sql b/tests/templates/140-random-testcase.sql deleted file mode 100644 index 96f35e2..0000000 --- a/tests/templates/140-random-testcase.sql +++ /dev/null @@ -1,56 +0,0 @@ -SELECT quote(int8_1) FROM nulls1 WHERE rowid <> 94 AND bool_0 IS NOT 0; -50 -48 -46 -44 -42 -NULL -NULL -NULL -NULL -NULL -NULL -NULL -NULL -NULL -NULL -30 -28 -26 -24 -22 -20 -18 -16 -14 -12 -10 -8 -6 -4 -2 -0 --2 --4 --6 --8 --10 --12 --14 --16 --18 --20 --22 --24 --26 --28 --30 --32 --34 --36 --38 --40 --42 --44 --46 --48 diff --git a/tests/templates/141-random-testcase.sql b/tests/templates/141-random-testcase.sql deleted file mode 100644 index 74e6984..0000000 --- a/tests/templates/141-random-testcase.sql +++ /dev/null @@ -1,6 +0,0 @@ -SELECT rowid FROM nulls WHERE (bool_0 IS 1) -1 -3 -5 -7 -9 diff --git a/tests/templates/142-rowid-is-null.sql b/tests/templates/142-rowid-is-null.sql deleted file mode 100644 index e93220c..0000000 --- a/tests/templates/142-rowid-is-null.sql +++ /dev/null @@ -1 +0,0 @@ -SELECT * FROM nulls WHERE rowid IS NULL diff --git a/tests/templates/143-float-eq.sql b/tests/templates/143-float-eq.sql deleted file mode 100644 index b11f4c6..0000000 --- a/tests/templates/143-float-eq.sql +++ /dev/null @@ -1,2 +0,0 @@ -select float_11 from nulls where float_11 = 1.0 -1.0 diff --git a/tests/templates/144-float-eq2.sql b/tests/templates/144-float-eq2.sql deleted file mode 100644 index 7e0bb60..0000000 --- a/tests/templates/144-float-eq2.sql +++ /dev/null @@ -1 +0,0 @@ -select float_11 from nulls where float_11 = 123.0 diff --git a/tests/templates/145-float-eq3.sql b/tests/templates/145-float-eq3.sql deleted file mode 100644 index be29d42..0000000 --- a/tests/templates/145-float-eq3.sql +++ /dev/null @@ -1,2 +0,0 @@ -select float_11 from nulls where float_11 = '1' -1.0 diff --git a/tests/templates/146-float-ne.sql b/tests/templates/146-float-ne.sql deleted file mode 100644 index c8805ae..0000000 --- a/tests/templates/146-float-ne.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 <> 1.0 -49 diff --git a/tests/templates/147-float-is-null.sql b/tests/templates/147-float-is-null.sql deleted file mode 100644 index 057f598..0000000 --- a/tests/templates/147-float-is-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 is null -49 diff --git a/tests/templates/148-float-is-not-null.sql b/tests/templates/148-float-is-not-null.sql deleted file mode 100644 index 2ff14d2..0000000 --- a/tests/templates/148-float-is-not-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 is not null -50 diff --git a/tests/templates/149-float-gte.sql b/tests/templates/149-float-gte.sql deleted file mode 100644 index 6368870..0000000 --- a/tests/templates/149-float-gte.sql +++ /dev/null @@ -1,2 +0,0 @@ -select float_11 from nulls where float_11 >= 1.0 -1.0 diff --git a/tests/templates/150-float-gt.sql b/tests/templates/150-float-gt.sql deleted file mode 100644 index 48a7644..0000000 --- a/tests/templates/150-float-gt.sql +++ /dev/null @@ -1 +0,0 @@ -select float_11 from nulls where float_11 > 1.0 diff --git a/tests/templates/151-float-gt-2.sql b/tests/templates/151-float-gt-2.sql deleted file mode 100644 index ad121b7..0000000 --- a/tests/templates/151-float-gt-2.sql +++ /dev/null @@ -1,2 +0,0 @@ -select float_11 from nulls where float_11 > 0.5 -1.0 diff --git a/tests/templates/152-float-lt.sql b/tests/templates/152-float-lt.sql deleted file mode 100644 index c59980c..0000000 --- a/tests/templates/152-float-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 < 0.0102 -1 diff --git a/tests/templates/153-float-lt.sql b/tests/templates/153-float-lt.sql deleted file mode 100644 index 1f6b900..0000000 --- a/tests/templates/153-float-lt.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 < 0.001 -0 diff --git a/tests/templates/154-float-lte.sql b/tests/templates/154-float-lte.sql deleted file mode 100644 index c5d5c42..0000000 --- a/tests/templates/154-float-lte.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where float_11 <= 0.0102 -1 diff --git a/tests/templates/155-float-skip.sql b/tests/templates/155-float-skip.sql deleted file mode 100644 index 5ff0ab5..0000000 --- a/tests/templates/155-float-skip.sql +++ /dev/null @@ -1,2 +0,0 @@ -select float_11 from nulls where rowid = 2 -0.5 diff --git a/tests/templates/156-glob.sql b/tests/templates/156-glob.sql deleted file mode 100644 index f2cba44..0000000 --- a/tests/templates/156-glob.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_7 from nulls where string_7 glob '7' -7 diff --git a/tests/templates/157-glob-star.sql b/tests/templates/157-glob-star.sql deleted file mode 100644 index 4b03d99..0000000 --- a/tests/templates/157-glob-star.sql +++ /dev/null @@ -1,7 +0,0 @@ -select string_7 from nulls where string_7 glob '7*' -7 -70 -72 -74 -76 -78 diff --git a/tests/templates/158-glob-star-eight.sql b/tests/templates/158-glob-star-eight.sql deleted file mode 100644 index 2a0e12c..0000000 --- a/tests/templates/158-glob-star-eight.sql +++ /dev/null @@ -1,2 +0,0 @@ -select string_7 from nulls where string_7 glob '7*8' -78 diff --git a/tests/templates/159-glob-star-zero.sql b/tests/templates/159-glob-star-zero.sql deleted file mode 100644 index 1378b63..0000000 --- a/tests/templates/159-glob-star-zero.sql +++ /dev/null @@ -1,10 +0,0 @@ -select string_7 from nulls where string_7 glob '*0' -0 -20 -30 -40 -50 -60 -70 -80 -90 diff --git a/tests/templates/160-glob-star.sql b/tests/templates/160-glob-star.sql deleted file mode 100644 index 0b401d1..0000000 --- a/tests/templates/160-glob-star.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where string_7 glob '*' -50 diff --git a/tests/templates/161-glob-star-stuff.sql b/tests/templates/161-glob-star-stuff.sql deleted file mode 100644 index 7f474d0..0000000 --- a/tests/templates/161-glob-star-stuff.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where string_7 glob '*123' -0 diff --git a/tests/templates/162-like-long.sql b/tests/templates/162-like-long.sql deleted file mode 100644 index fdf4446..0000000 --- a/tests/templates/162-like-long.sql +++ /dev/null @@ -1 +0,0 @@ -select string_7 from nulls where string_7 like 'asdfasdf' diff --git a/tests/templates/163-blob-is-not.sql b/tests/templates/163-blob-is-not.sql deleted file mode 100644 index 0df2c8d..0000000 --- a/tests/templates/163-blob-is-not.sql +++ /dev/null @@ -1,2 +0,0 @@ -select quote(binary_9) from nulls where rowid = 2 and binary_9 is not X'00' -X'0101' diff --git a/tests/templates/164-blob-is-not.sql b/tests/templates/164-blob-is-not.sql deleted file mode 100644 index ad4527a..0000000 --- a/tests/templates/164-blob-is-not.sql +++ /dev/null @@ -1 +0,0 @@ -select quote(binary_9) from nulls where rowid = 1 and binary_9 is not X'00' diff --git a/tests/templates/165-not-null.sql b/tests/templates/165-not-null.sql deleted file mode 100644 index 78c552e..0000000 --- a/tests/templates/165-not-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where binary_9 not null -50 diff --git a/tests/templates/166-not-not-null.sql b/tests/templates/166-not-not-null.sql deleted file mode 100644 index 413ab02..0000000 --- a/tests/templates/166-not-not-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where not binary_9 not null -49 diff --git a/tests/templates/167-double-is-not-null.sql b/tests/templates/167-double-is-not-null.sql deleted file mode 100644 index 68baa98..0000000 --- a/tests/templates/167-double-is-not-null.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where double_6 is not null -49 diff --git a/tests/templates/168-double-is-not-99.sql b/tests/templates/168-double-is-not-99.sql deleted file mode 100644 index 8d27d63..0000000 --- a/tests/templates/168-double-is-not-99.sql +++ /dev/null @@ -1,2 +0,0 @@ -select count(*) from nulls where double_6 is not 99.0 -98 diff --git a/tests/test-all b/tests/test-all deleted file mode 100755 index e702164..0000000 --- a/tests/test-all +++ /dev/null @@ -1,22 +0,0 @@ -#!/bin/bash -set -euo pipefail - -here=$(dirname "${BASH_SOURCE[0]}") - -set -x -"$here"/test-non-existent -"$here"/test-bad-create-table -"$here"/test-unsupported -"$here"/test-supported -"$here"/test-queries -"$here"/test-random - -if [ -v COVERAGE ]; then - # Do at most 10 seconds of failmalloc testing - "$here"/test-failmalloc || true - now=$(date +%s) - in_10s=$((now+10)) - while [ $(date +%s) -lt $in_10s ]; do - "$here"/test-failmalloc || true - done -fi diff --git a/tests/test-bad-create-table b/tests/test-bad-create-table deleted file mode 100755 index 9f3e5e5..0000000 --- a/tests/test-bad-create-table +++ /dev/null @@ -1,31 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# Verify that all the unsupported.*parquet files result in an error when creating the virtual table, -# but don't segfault. - -load_bad_table() { - cat < /dev/null 2> testcase-stderr.txt - # We expect the 'SELECT 123' command to NOT have been run - if grep -q 123 testcase-out.txt; then - echo "...FAILED; expected an error message. Check testcase-{out,err}.txt" >&2 - exit 1 - fi -} - -main "$@" diff --git a/tests/test-failmalloc b/tests/test-failmalloc deleted file mode 100755 index 17ca159..0000000 --- a/tests/test-failmalloc +++ /dev/null @@ -1,49 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# A harness that runs SQLite with the parquet extension in an environment where malloc randomly -# fails. "Success" is if the logs don't have any C++ exceptions that talk about std::bad_alloc -# -# The results can need a bit of interpretation; look at the log and see if it sniffs like -# the segfault came from Python or SQLite. - -ensure_failmalloc() { - if [ ! -d libfailmalloc ]; then - git clone https://github.com/cldellow/libfailmalloc.git - fi - - if [ ! -e libfailmalloc/.libs/libfailmalloc.so ]; then - cd libfailmalloc - ./configure - make - fi -} - -run_under_low_memory() { - start=$(date +%s%3N) - set +e - env LD_PRELOAD="$here"/libfailmalloc/.libs/libfailmalloc.so FAILMALLOC_PROBABILITY=0.00001 ./test-random >results.bad_alloc 2>&1 - rv=$? - now=$(date +%s%3N) - echo "Bailed after $((now-start)) ms" - set -e - if [ "$rv" -gt 127 ]; then - cat results.bad_alloc - echo "Segfaulted with exit code: $rv" - exit 1 - fi -} - -main() { - here=$(dirname "${BASH_SOURCE[0]}") - here=$(readlink -f "$here") - cd "$here" - - ensure_failmalloc - # Sometimes we'll exit due to a Python memory issue, so try a few times. - for i in {0..100}; do - run_under_low_memory - done -} - -main "$@" diff --git a/tests/test-non-existent b/tests/test-non-existent deleted file mode 100755 index 43dfab1..0000000 --- a/tests/test-non-existent +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# Verify that loading a non existent file is an error, not a segfault - -load_nonexistent() { - cat < /dev/null 2> testcase-stderr.txt - - # We expect the 'SELECT 123' command to NOT have been run - if grep -q 123 testcase-out.txt; then - echo "...FAILED; expected an error message. Check testcase-{out,err}.txt" >&2 - exit 1 - fi -} - -main "$@" diff --git a/tests/test-queries b/tests/test-queries deleted file mode 100755 index eb64a4e..0000000 --- a/tests/test-queries +++ /dev/null @@ -1,71 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# For each files in tests/queries/*, mount that parquet file, run the query, and compare -# its output. - -run_query() { - file=${1:?must provide testcase file} - query=${2:?must provide query to run} - basename=$(basename "$file") - cat < testcases.txt - - if [ ! -s testcases.txt ]; then - echo "no matching testcases found" - exit 1 - fi - - cat "$root"/parquet-generator/*.sql > "$root"/testcase-bootstrap.sql - rm -f test.db - "$root"/sqlite/sqlite3 test.db -init "$root"/testcase-bootstrap.sql < /dev/null - if [ ! -v NO_DEBUG ] && [ "$(cat testcases.txt | wc -l)" == "1" ]; then - set -x - gdb -ex run --args "$root"/sqlite/sqlite3 test.db -init testcase-cmds.txt - else - while read -r file; do - echo "Testing: $file" - query=$(head -n1 "$file" | tail -n1) - tail -n+2 "$file" > testcase-expected.txt - - run_query "$file" "$query" > testcase-cmds.txt - if ! "$root"/sqlite/sqlite3 test.db -init testcase-cmds.txt < /dev/null > testcase-stdout.txt 2> testcase-stderr.txt; then - echo "...FAILED; check testcase-{out,err}.txt" >&2 - exit 1 - fi - diff testcase-out.txt testcase-expected.txt - done < testcases.txt - fi -} - -main "$@" diff --git a/tests/test-random b/tests/test-random deleted file mode 100755 index e1dd145..0000000 --- a/tests/test-random +++ /dev/null @@ -1,113 +0,0 @@ -#!/usr/bin/python3 - -import sqlite3 -import os.path -import random - -ops = ['=', '<>', '>', '>=', '<', '<=', 'IS', 'IS NOT', 'LIKE']; - -def get_column_values(conn, table, column): - cursor = conn.execute('SELECT DISTINCT quote({}) FROM {}'.format(column, table)) - rv = [] - for row in cursor: - rv.append(row[0]) - cursor.close() - return rv - -def get_columns(conn, table): - cursor = conn.execute('SELECT * FROM {} LIMIT 1'.format(table)) - rv = ['rowid'] + [description[0] for description in cursor.description] - cursor.close() - return rv - -def generate_statement(conn, table, column_values, all_values): - names = list(column_values.keys()) - - num_fields = random.randint(1, 20) - - query = 'SELECT ' - for i in range(num_fields): - if i > 0: - query += ', ' - - query += 'quote(' + names[random.randint(0, len(names) - 1)] + ')' - query += ' FROM ' - query += table - - num_clauses = random.randint(0, 2) - for i in range(num_clauses): - if i == 0: - query += ' WHERE ' - else: - query += ' AND ' - - field = names[random.randint(0, len(names) - 1)] - op = ops[random.randint(0, len(ops) - 1)] - values = column_values[field] - if random.randint(0, 1) == 0: - values = all_values - value = values[random.randint(0, len(values) - 1)] - if random.randint(0, 5) == 0: - query += ' NOT ' - query += '(' + field + ' ' + op + ' ' + str(value) + ')' - - if random.randint(0, 3) == 0: - how_many = random.randint(0, 15) - query += ' LIMIT {}'.format(how_many) - - if random.randint(0, 3) == 0: - how_many = random.randint(0, 30) - query += ' OFFSET {}'.format(how_many) - - return query - -def test_statement(conn, table, column_values, all_values): - query = generate_statement(conn, table, column_values, all_values) - - gold = [row for row in conn.execute(query)] - print('{} rows: {}'.format(len(gold), query)) - for parquet in ['nulls1', 'nulls2', 'nulls3']: - new_query = query.replace('nulls', parquet) - rv = [row for row in conn.execute(new_query)] - if gold != rv: - with open('testcase-cmds.txt', 'w') as f: - f.write('.load build/linux/libparquet\n.testcase query\n.bail on\n{};\n.output\n'.format(new_query)) - with open('testcase-expected.txt', 'w') as f: - for row in gold: - f.write('{}\n'.format(row)) - with open('testcase-out.txt', 'w') as f: - for row in rv: - f.write('{}\n'.format(row)) - - raise ValueError('ruhroh') - - - -def test_table(conn, table): - # Don't include the floating point columns in random tests - sqlite itself stores doubles, so - # it can't act as an oracle for the FP stuff. - column_names = [x for x in get_columns(conn, table) if not x.startswith('float_')] - print('Table {}: {}'.format(table, column_names)) - column_values = {} - for name in column_names: - column_values[name] = get_column_values(conn, table, name) - - #random.seed(0) - all_values = [] - for values in column_values.values(): - all_values = all_values + values - for i in range(1000): - test_statement(conn, table, column_values, all_values) - -def test_db(db_file, extension_file, tables): - conn = sqlite3.connect(db_file) - conn.enable_load_extension(True) - conn.load_extension(extension_file) - conn.enable_load_extension(False) - for table in tables: - test_table(conn, table) - -if __name__ == '__main__': - db_file = os.path.abspath(os.path.join(__file__, '..', '..', 'test.db')) - extension_file = os.path.abspath(os.path.join(__file__, '..', '..', 'build', 'linux', 'libparquet')) - test_db(db_file, extension_file, ['nulls', 'no_nulls']) diff --git a/tests/test-supported b/tests/test-supported deleted file mode 100755 index d78111b..0000000 --- a/tests/test-supported +++ /dev/null @@ -1,42 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# Verify that all the non-unsupported.*parquet files can be loaded and 'SELECT * FROM x LIMIT 1'ed -# without segfaulting. - -load_supported() { - file=${1:?must provide file to load} - basename=$(basename "$file") - cat < /dev/null 2> testcase-stderr.txt; then - echo "...FAILED; check testcase-{out,err}.txt" >&2 - exit 1 - fi - # We expect the 'SELECT 123' command to have been run - if ! grep -q 123 testcase-out.txt; then - echo "...FAILED; check testcase-{out,err}.txt" >&2 - exit 1 - fi - done < <(echo "$supported_files") -} - -main "$@" diff --git a/tests/test-unsupported b/tests/test-unsupported deleted file mode 100755 index a761646..0000000 --- a/tests/test-unsupported +++ /dev/null @@ -1,37 +0,0 @@ -#!/bin/bash -set -euo pipefail - -# Verify that all the unsupported.*parquet files result in an error when creating the virtual table, -# but don't segfault. - -load_unsupported() { - file=${1:?must provide file to load} - basename=$(basename "$file") - cat < /dev/null 2> testcase-stderr.txt - # We expect the 'SELECT 123' command to NOT have been run - if grep -q 123 testcase-out.txt; then - echo "...FAILED; expected an error message. Check testcase-{out,err}.txt" >&2 - exit 1 - fi - done < <(echo "$unsupported_files") -} - -main "$@"