diff options
Diffstat (limited to '')
-rw-r--r-- | test/test_sql_str_func.sh | 170 |
1 files changed, 170 insertions, 0 deletions
diff --git a/test/test_sql_str_func.sh b/test/test_sql_str_func.sh new file mode 100644 index 0000000..4c58214 --- /dev/null +++ b/test/test_sql_str_func.sh @@ -0,0 +1,170 @@ +#! /bin/bash + +run_cap_test ./drive_sql "select length(gzip(1))" + +run_cap_test ./drive_sql "select gunzip(gzip(1))" + +run_cap_test ./drive_sql "select humanize_file_size()" + +run_cap_test ./drive_sql "select humanize_file_size('abc')" + +run_cap_test ./drive_sql "select humanize_file_size(1, 2)" + +run_cap_test ./drive_sql "select humanize_file_size(10 * 1000 * 1000)" + +run_cap_test ./drive_sql "select startswith('.foo', '.')" + +run_cap_test ./drive_sql "select startswith('foo', '.')" + +run_cap_test ./drive_sql "select endswith('foo', '.')" + +run_cap_test ./drive_sql "select endswith('foo.', '.')" + +run_cap_test ./drive_sql "select endswith('foo.txt', '.txt')" + +run_cap_test ./drive_sql "select endswith('a', '.txt')" + +run_cap_test ./drive_sql "select regexp('abcd', 'abcd')" + +run_cap_test ./drive_sql "select regexp('bc', 'abcd')" + +run_cap_test ./drive_sql "select regexp('[e-z]+', 'abcd')" + +run_cap_test ./drive_sql "select regexp('[e-z]+', 'ea')" + +run_cap_test ./drive_sql "select regexp_replace('test 1 2 3', '\\d+', 'N')" + +run_cap_test env TEST_COMMENT=regexp_replace_with_bs1 ./drive_sql <<'EOF' +select regexp_replace('test 1 2 3', '\s+', '{\0}') as repl +EOF + +run_cap_test env TEST_COMMENT=regexp_replace_with_bs2 ./drive_sql <<'EOF' +select regexp_replace('test 1 2 3', '\w*', '{\0}') as repl +EOF + +run_cap_test ./drive_sql "select regexp_replace('123 abc', '(\w*)', '<\3>') as repl" + +run_cap_test env TEST_COMMENT=regexp_replace_with_bs3 ./drive_sql <<'EOF' +select regexp_replace('123 abc', '(\w*)', '<\\>') as repl +EOF + +run_cap_test ./drive_sql "select regexp_replace('abc: def', '(\w*):\s*(.*)', '\1=\2') as repl" + +run_cap_test ./drive_sql "select regexp_match('abc', 'abc')" + +run_cap_test ./drive_sql "select regexp_match(null, 'abc')" + +run_cap_test ./drive_sql "select regexp_match('abc', null) as result" + +run_cap_test ./drive_sql "select typeof(result), result from (select regexp_match('(\d*)abc', 'abc') as result)" + +run_cap_test ./drive_sql "select typeof(result), result from (select regexp_match('(\d*)abc(\d*)', 'abc') as result)" + +run_cap_test ./drive_sql "select typeof(result), result from (select regexp_match('(\d+)', '123') as result)" + +run_cap_test ./drive_sql "select typeof(result), result from (select regexp_match('a(\d+\.\d+)a', 'a123.456a') as result)" + +run_cap_test ./drive_sql "select regexp_match('foo=(?<foo>\w+); (\w+)', 'foo=abc; 123') as result" + +run_cap_test ./drive_sql "select regexp_match('foo=(?<foo>\w+); (\w+\.\w+)', 'foo=abc; 123.456') as result" + +run_cap_test ${lnav_test} -nN \ + -c ";SELECT regexp_match('^(\w+)=([^;]+);', 'abc=def;ghi=jkl;')" + +run_cap_test ./drive_sql "select extract('foo=1') as result" + +run_cap_test ./drive_sql "select extract('foo=1; bar=2') as result" + +run_cap_test ./drive_sql "select extract(null) as result" + +run_cap_test ./drive_sql "select extract(1) as result" + +run_cap_test ./drive_sql "select logfmt2json('foo=1 bar=2 baz=2e1 msg=hello') as result" + +run_cap_test ./drive_sql "SELECT substr('#foo', range_start) AS value FROM regexp_capture('#foo', '(\w+)') WHERE capture_index = 1" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar', '\w+ (\w+)')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar', '\w+ \w+')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar', '\w+ (?<word>\w+)')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar', '(bar)|\w+ (?<word>\w+)')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture()" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo bar', '(')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('1 2 3 45', '(\d+)')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture('foo foo', '^foo')" + +run_cap_test ./drive_sql "SELECT * FROM regexp_capture_into_json('foo=1 bar=2; foo=3 bar=4', 'foo=(\d+) bar=(\d+)')" + +run_cap_test ./drive_sql "SELECT encode('foo', 'bar')" + +run_cap_test ./drive_sql "SELECT encode('foo', null)" + +run_cap_test ./drive_sql "SELECT encode(null, 'base64')" + +run_cap_test ./drive_sql "SELECT gunzip(decode(encode(gzip('Hello, World!'), 'base64'), 'base64'))" + +run_cap_test env TEST_COMMENT=invalid_url ./drive_sql <<'EOF' +SELECT parse_url('https://bad@[fe::') +EOF + +run_cap_test env TEST_COMMENT=unsupported_url ./drive_sql <<'EOF' +SELECT parse_url('https://example.com:100000') +EOF + +run_cap_test env TEST_COMMENT=parse_url1 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com') +EOF + +run_cap_test env TEST_COMMENT=parse_url2 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com/') +EOF + +run_cap_test env TEST_COMMENT=parse_url3 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com/search?flag') +EOF + +run_cap_test env TEST_COMMENT=parse_url4 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com/search?flag&flag2') +EOF + +run_cap_test env TEST_COMMENT=parse_url5 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com/search?flag&flag2&=def') +EOF + +run_cap_test env TEST_COMMENT=parse_url6 ./drive_sql <<'EOF' +SELECT parse_url('https://example.com/sea%26rch?flag&flag2&=def#frag1%20space') +EOF + + +run_cap_test env TEST_COMMENT=unparse_url3 ./drive_sql <<'EOF' +SELECT unparse_url(parse_url('https://example.com/search?flag')) +EOF + +run_cap_test env TEST_COMMENT=unparse_url4 ./drive_sql <<'EOF' +SELECT unparse_url(parse_url('https://example.com/search?flag&flag2')) +EOF + +run_cap_test env TEST_COMMENT=unparse_url5 ./drive_sql <<'EOF' +SELECT unparse_url(parse_url('https://example.com/search?flag&flag2&=def')) +EOF + +run_cap_test env TEST_COMMENT=unparse_url6 ./drive_sql <<'EOF' +SELECT unparse_url(parse_url('https://example.com/search?flag&flag2&=def#frag1%20space')) +EOF + +run_cap_test ${lnav_test} -n \ + -c ';SELECT log_body, extract(log_body) from vmw_log' \ + -c ':write-json-to -' \ + ${test_dir}/logfile_vmw_log.0 + +run_cap_test ${lnav_test} -n \ + -c ';SELECT anonymize(bro_id_resp_h) FROM bro_http_log' \ + ${test_dir}/logfile_bro_http.log.0 |