| // Licensed to the Apache Software Foundation (ASF) under one |
| // or more contributor license agreements. See the NOTICE file |
| // distributed with this work for additional information |
| // regarding copyright ownership. The ASF licenses this file |
| // to you under the Apache License, Version 2.0 (the |
| // "License"); you may not use this file except in compliance |
| // with the License. You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, |
| // software distributed under the License is distributed on an |
| // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| // KIND, either express or implied. See the License for the |
| // specific language governing permissions and limitations |
| // under the License. |
| |
| #include <cstdint> |
| #include <cstring> |
| #include <memory> |
| #include <string> |
| #include <vector> |
| |
| #include "function_test_util.h" |
| #include "util/encryption_util.h" |
| #include "vec/core/field.h" |
| #include "vec/core/types.h" |
| #include "vec/data_types/data_type_number.h" |
| #include "vec/data_types/data_type_string.h" |
| |
| namespace doris::vectorized { |
| using namespace ut_type; |
| |
| TEST(function_string_test, function_string_substr_test) { |
| std::string func_name = "substr"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("AbCdEfg"), std::int32_t(1), std::int32_t(1)}, std::string("A")}, |
| {{std::string("AbCdEfg"), std::int32_t(1), std::int32_t(5)}, std::string("AbCdE")}, |
| {{std::string("AbCdEfg"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(1), std::int32_t(100)}, |
| std::string("AbCdEfg")}, |
| {{std::string("AbCdEfg"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("AbCdEfg"), std::int32_t(5), std::int32_t(1)}, std::string("E")}, |
| {{std::string("AbCdEfg"), std::int32_t(5), std::int32_t(5)}, std::string("Efg")}, |
| {{std::string("AbCdEfg"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(5), std::int32_t(100)}, std::string("Efg")}, |
| {{std::string("AbCdEfg"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("AbCdEfg"), std::int32_t(-1), std::int32_t(1)}, std::string("g")}, |
| {{std::string("AbCdEfg"), std::int32_t(-1), std::int32_t(5)}, std::string("g")}, |
| {{std::string("AbCdEfg"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(-1), std::int32_t(100)}, std::string("g")}, |
| {{std::string("AbCdEfg"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("AbCdEfg"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("AbCdEfg"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("AbCdEfg"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("AbCdEfg"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("AbCdEfg"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("AbCdEfg"), Null(), Null()}, Null()}, |
| {{std::string("HELLO123"), std::int32_t(1), std::int32_t(1)}, std::string("H")}, |
| {{std::string("HELLO123"), std::int32_t(1), std::int32_t(5)}, std::string("HELLO")}, |
| {{std::string("HELLO123"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(1), std::int32_t(100)}, |
| std::string("HELLO123")}, |
| {{std::string("HELLO123"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("HELLO123"), std::int32_t(5), std::int32_t(1)}, std::string("O")}, |
| {{std::string("HELLO123"), std::int32_t(5), std::int32_t(5)}, std::string("O123")}, |
| {{std::string("HELLO123"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(5), std::int32_t(100)}, |
| std::string("O123")}, |
| {{std::string("HELLO123"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("HELLO123"), std::int32_t(-1), std::int32_t(1)}, std::string("3")}, |
| {{std::string("HELLO123"), std::int32_t(-1), std::int32_t(5)}, std::string("3")}, |
| {{std::string("HELLO123"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(-1), std::int32_t(100)}, std::string("3")}, |
| {{std::string("HELLO123"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("HELLO123"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("HELLO123"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("HELLO123"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("HELLO123"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("HELLO123"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("HELLO123"), Null(), Null()}, Null()}, |
| {{std::string("你好HELLO"), std::int32_t(1), std::int32_t(1)}, std::string("你")}, |
| {{std::string("你好HELLO"), std::int32_t(1), std::int32_t(5)}, |
| std::string("你好HEL")}, |
| {{std::string("你好HELLO"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(1), std::int32_t(100)}, |
| std::string("你好HELLO")}, |
| {{std::string("你好HELLO"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("你好HELLO"), std::int32_t(5), std::int32_t(1)}, std::string("L")}, |
| {{std::string("你好HELLO"), std::int32_t(5), std::int32_t(5)}, std::string("LLO")}, |
| {{std::string("你好HELLO"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(5), std::int32_t(100)}, |
| std::string("LLO")}, |
| {{std::string("你好HELLO"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("你好HELLO"), std::int32_t(-1), std::int32_t(1)}, std::string("O")}, |
| {{std::string("你好HELLO"), std::int32_t(-1), std::int32_t(5)}, std::string("O")}, |
| {{std::string("你好HELLO"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(-1), std::int32_t(100)}, std::string("O")}, |
| {{std::string("你好HELLO"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("你好HELLO"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("你好HELLO"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("你好HELLO"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("你好HELLO"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("你好HELLO"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("你好HELLO"), Null(), Null()}, Null()}, |
| {{std::string("123ABC_"), std::int32_t(1), std::int32_t(1)}, std::string("1")}, |
| {{std::string("123ABC_"), std::int32_t(1), std::int32_t(5)}, std::string("123AB")}, |
| {{std::string("123ABC_"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(1), std::int32_t(100)}, |
| std::string("123ABC_")}, |
| {{std::string("123ABC_"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("123ABC_"), std::int32_t(5), std::int32_t(1)}, std::string("B")}, |
| {{std::string("123ABC_"), std::int32_t(5), std::int32_t(5)}, std::string("BC_")}, |
| {{std::string("123ABC_"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(5), std::int32_t(100)}, std::string("BC_")}, |
| {{std::string("123ABC_"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("123ABC_"), std::int32_t(-1), std::int32_t(1)}, std::string("_")}, |
| {{std::string("123ABC_"), std::int32_t(-1), std::int32_t(5)}, std::string("_")}, |
| {{std::string("123ABC_"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(-1), std::int32_t(100)}, std::string("_")}, |
| {{std::string("123ABC_"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("123ABC_"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("123ABC_"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("123ABC_"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("123ABC_"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("123ABC_"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("123ABC_"), Null(), Null()}, Null()}, |
| {{std::string("MYtestSTR"), std::int32_t(1), std::int32_t(1)}, std::string("M")}, |
| {{std::string("MYtestSTR"), std::int32_t(1), std::int32_t(5)}, |
| std::string("MYtes")}, |
| {{std::string("MYtestSTR"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(1), std::int32_t(100)}, |
| std::string("MYtestSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("MYtestSTR"), std::int32_t(5), std::int32_t(1)}, std::string("s")}, |
| {{std::string("MYtestSTR"), std::int32_t(5), std::int32_t(5)}, |
| std::string("stSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(5), std::int32_t(100)}, |
| std::string("stSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("MYtestSTR"), std::int32_t(-1), std::int32_t(1)}, std::string("R")}, |
| {{std::string("MYtestSTR"), std::int32_t(-1), std::int32_t(5)}, std::string("R")}, |
| {{std::string("MYtestSTR"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(-1), std::int32_t(100)}, std::string("R")}, |
| {{std::string("MYtestSTR"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("MYtestSTR"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("MYtestSTR"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("MYtestSTR"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("MYtestSTR"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("MYtestSTR"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("MYtestSTR"), Null(), Null()}, Null()}, |
| {{std::string(""), std::int32_t(1), std::int32_t(1)}, std::string("")}, |
| {{std::string(""), std::int32_t(1), std::int32_t(5)}, std::string("")}, |
| {{std::string(""), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string(""), std::int32_t(1), std::int32_t(100)}, std::string("")}, |
| {{std::string(""), std::int32_t(1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(5), std::int32_t(1)}, std::string("")}, |
| {{std::string(""), std::int32_t(5), std::int32_t(5)}, std::string("")}, |
| {{std::string(""), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string(""), std::int32_t(5), std::int32_t(100)}, std::string("")}, |
| {{std::string(""), std::int32_t(5), Null()}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::int32_t(1)}, std::string("")}, |
| {{std::string(""), std::int32_t(-1), std::int32_t(5)}, std::string("")}, |
| {{std::string(""), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string(""), std::int32_t(-1), std::int32_t(100)}, std::string("")}, |
| {{std::string(""), std::int32_t(-1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string(""), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string(""), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string(""), std::int32_t(100), std::int32_t(100)}, std::string("")}, |
| {{std::string(""), std::int32_t(100), Null()}, Null()}, |
| {{std::string(""), Null(), std::int32_t(1)}, Null()}, |
| {{std::string(""), Null(), std::int32_t(5)}, Null()}, |
| {{std::string(""), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string(""), Null(), std::int32_t(100)}, Null()}, |
| {{std::string(""), Null(), Null()}, Null()}, |
| {{Null(), std::int32_t(1), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(1), std::int32_t(5)}, Null()}, |
| {{Null(), std::int32_t(1), std::int32_t(-1)}, Null()}, |
| {{Null(), std::int32_t(1), std::int32_t(100)}, Null()}, |
| {{Null(), std::int32_t(1), Null()}, Null()}, |
| {{Null(), std::int32_t(5), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(5), std::int32_t(5)}, Null()}, |
| {{Null(), std::int32_t(5), std::int32_t(-1)}, Null()}, |
| {{Null(), std::int32_t(5), std::int32_t(100)}, Null()}, |
| {{Null(), std::int32_t(5), Null()}, Null()}, |
| {{Null(), std::int32_t(-1), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(-1), std::int32_t(5)}, Null()}, |
| {{Null(), std::int32_t(-1), std::int32_t(-1)}, Null()}, |
| {{Null(), std::int32_t(-1), std::int32_t(100)}, Null()}, |
| {{Null(), std::int32_t(-1), Null()}, Null()}, |
| {{Null(), std::int32_t(100), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(100), std::int32_t(5)}, Null()}, |
| {{Null(), std::int32_t(100), std::int32_t(-1)}, Null()}, |
| {{Null(), std::int32_t(100), std::int32_t(100)}, Null()}, |
| {{Null(), std::int32_t(100), Null()}, Null()}, |
| {{Null(), Null(), std::int32_t(1)}, Null()}, |
| {{Null(), Null(), std::int32_t(5)}, Null()}, |
| {{Null(), Null(), std::int32_t(-1)}, Null()}, |
| {{Null(), Null(), std::int32_t(100)}, Null()}, |
| {{Null(), Null(), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1), std::int32_t(1)}, std::string("A")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1), std::int32_t(5)}, |
| std::string("A,b,C")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1), std::int32_t(100)}, |
| std::string("A,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(5), std::int32_t(1)}, std::string("C")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(5), std::int32_t(5)}, |
| std::string("C,D,_")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(5), std::int32_t(-1)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(5), std::int32_t(100)}, |
| std::string("C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1), std::int32_t(1)}, std::string("E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1), std::int32_t(5)}, std::string("E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1), std::int32_t(-1)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1), std::int32_t(100)}, |
| std::string("E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(100), std::int32_t(1)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(100), std::int32_t(5)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(100), std::int32_t(-1)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(100), std::int32_t(100)}, |
| std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("A,b,C,D,_E"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("A,b,C,D,_E"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("A,b,C,D,_E"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("A,b,C,D,_E"), Null(), Null()}, Null()}, |
| {{std::string("1234321312312"), std::int32_t(1), std::int32_t(1)}, |
| std::string("1")}, |
| {{std::string("1234321312312"), std::int32_t(1), std::int32_t(5)}, |
| std::string("12343")}, |
| {{std::string("1234321312312"), std::int32_t(1), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(1), std::int32_t(100)}, |
| std::string("1234321312312")}, |
| {{std::string("1234321312312"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("1234321312312"), std::int32_t(5), std::int32_t(1)}, |
| std::string("3")}, |
| {{std::string("1234321312312"), std::int32_t(5), std::int32_t(5)}, |
| std::string("32131")}, |
| {{std::string("1234321312312"), std::int32_t(5), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(5), std::int32_t(100)}, |
| std::string("321312312")}, |
| {{std::string("1234321312312"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("1234321312312"), std::int32_t(-1), std::int32_t(1)}, |
| std::string("2")}, |
| {{std::string("1234321312312"), std::int32_t(-1), std::int32_t(5)}, |
| std::string("2")}, |
| {{std::string("1234321312312"), std::int32_t(-1), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(-1), std::int32_t(100)}, |
| std::string("2")}, |
| {{std::string("1234321312312"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("1234321312312"), std::int32_t(100), std::int32_t(1)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(100), std::int32_t(5)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(100), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(100), std::int32_t(100)}, |
| std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("1234321312312"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("1234321312312"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("1234321312312"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("1234321312312"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("1234321312312"), Null(), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(1), std::int32_t(1)}, |
| std::string("h")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(1), std::int32_t(5)}, |
| std::string("heh1h")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(1), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(1), std::int32_t(100)}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(5), std::int32_t(1)}, |
| std::string("h")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(5), std::int32_t(5)}, |
| std::string("h2_!u")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(5), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(5), std::int32_t(100)}, |
| std::string("h2_!u@_u@i$o%ll_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(5), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(-1), std::int32_t(1)}, |
| std::string("_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(-1), std::int32_t(5)}, |
| std::string("_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(-1), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(-1), std::int32_t(100)}, |
| std::string("_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(100), std::int32_t(1)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(100), std::int32_t(5)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(100), std::int32_t(-1)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(100), std::int32_t(100)}, |
| std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::int32_t(100), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null(), std::int32_t(5)}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null(), Null()}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("ABC"), std::int32_t(123)}, std::string("")}, |
| {{std::string("ABC"), std::int32_t(321)}, std::string("")}, |
| {{std::string("ABC"), std::int32_t(1)}, std::string("ABC")}, |
| {{std::string("ABC"), std::int32_t(-1)}, std::string("C")}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{std::string("ABC"), std::int32_t(100)}, std::string("")}, |
| {{std::string("ABC"), std::int32_t(-100)}, std::string("")}, |
| {{std::string("ABB"), std::int32_t(123)}, std::string("")}, |
| {{std::string("ABB"), std::int32_t(321)}, std::string("")}, |
| {{std::string("ABB"), std::int32_t(1)}, std::string("ABB")}, |
| {{std::string("ABB"), std::int32_t(-1)}, std::string("B")}, |
| {{std::string("ABB"), Null()}, Null()}, |
| {{std::string("ABB"), std::int32_t(100)}, std::string("")}, |
| {{std::string("ABB"), std::int32_t(-100)}, std::string("")}, |
| {{std::string("HEHE"), std::int32_t(123)}, std::string("")}, |
| {{std::string("HEHE"), std::int32_t(321)}, std::string("")}, |
| {{std::string("HEHE"), std::int32_t(1)}, std::string("HEHE")}, |
| {{std::string("HEHE"), std::int32_t(-1)}, std::string("E")}, |
| {{std::string("HEHE"), Null()}, Null()}, |
| {{std::string("HEHE"), std::int32_t(100)}, std::string("")}, |
| {{std::string("HEHE"), std::int32_t(-100)}, std::string("")}, |
| {{Null(), std::int32_t(123)}, Null()}, |
| {{Null(), std::int32_t(321)}, Null()}, |
| {{Null(), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(-1)}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::int32_t(100)}, Null()}, |
| {{Null(), std::int32_t(-100)}, Null()}, |
| |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_strright_test) { |
| std::string func_name = "strright"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("asd"), 1}, std::string("d")}, |
| {{std::string("hello word"), -2}, std::string("ello word")}, |
| {{std::string("hello word"), 20}, std::string("hello word")}, |
| {{std::string("HELLO,!^%"), 2}, std::string("^%")}, |
| {{std::string(""), 3}, std::string("")}, |
| {{Null(), 3}, Null()}, |
| {{std::string("12345"), 10}, std::string("12345")}, |
| {{std::string("12345"), -10}, std::string("")}, |
| {{std::string(""), Null()}, Null()}, |
| {{Null(), -100}, Null()}, |
| {{std::string("12345"), 12345}, std::string("12345")}, |
| {{std::string(""), 1}, std::string()}, |
| {{std::string("a b c d _ %"), -3}, std::string("b c d _ %")}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string("hah hah"), -1}, std::string("hah hah")}, |
| {{std::string("🤣"), -1}, std::string("🤣")}, |
| {{std::string("🤣😃😄"), -2}, std::string("😃😄")}, |
| {{std::string("🐼abc🐼"), 100}, std::string("🐼abc🐼")}, |
| {{std::string("你好世界"), 5}, std::string("你好世界")}, |
| {{std::string("12345"), 6}, std::string("12345")}, |
| {{std::string("12345"), 12345}, std::string("12345")}, |
| {{std::string("-12345"), -1}, std::string("-12345")}, |
| {{std::string("-12345"), -12345}, std::string()}, |
| {{Null(), -12345}, Null()}, |
| {{std::string("😡"), Null()}, Null()}, |
| {{std::string("🤣"), 0}, std::string()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_strleft_test) { |
| std::string func_name = "strleft"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("asd"), 1}, std::string("a")}, |
| {{std::string("hel lo "), 5}, std::string("hel ")}, |
| {{std::string("hello word"), 20}, std::string("hello word")}, |
| {{std::string("HELLO,!^%"), 7}, std::string("HELLO,!")}, |
| {{std::string(""), 2}, std::string("")}, |
| {{std::string(""), -2}, std::string("")}, |
| {{std::string(""), 0}, std::string("")}, |
| {{std::string("123"), 0}, std::string("")}, |
| {{Null(), 3}, Null()}, |
| {{std::string("12321"), 3}, std::string("123")}, |
| {{std::string("123"), 0}, std::string()}, |
| {{std::string("123"), -1}, std::string()}, |
| {{std::string("123"), Null()}, Null()}, |
| {{Null(), 0}, Null()}, |
| {{std::string("🫢"), 0}, std::string()}, |
| {{std::string("123"), 4}, std::string("123")}, |
| {{std::string("哈哈hh🤣"), 1}, std::string("哈")}, |
| {{std::string("哈哈hh🤣"), 100}, std::string("哈哈hh🤣")}, |
| {{std::string("mnzxv"), -1}, std::string()}, |
| {{std::string("123"), Null()}, Null()}, |
| {{std::string(1e6, 'a'), Null()}, Null()}, |
| {{std::string(""), -100}, std::string()}, |
| {{std::string("abcdef"), 4}, std::string("abcd")}, |
| {{std::string("NULL"), 3}, std::string("NUL")}, |
| {{std::string("NuLl"), 4}, std::string("NuLl")}, |
| {{Null(), 123}, Null()}, |
| {{std::string("Includes numbers 123456."), 10}, std::string("Includes n")}, |
| {{std::string("CapsAndLowercase"), 6}, std::string("CapsAn")}, |
| {{std::string("1234567890"), 3}, std::string("123")}, |
| {{std::string("Punctuation, too!"), 13}, std::string("Punctuation, ")}, |
| {{std::string("Short"), 10}, std::string("Short")}, |
| {{std::string("No more than needed"), 18}, std::string("No more than neede")}, |
| {{std::string("1234567890"), -5}, std::string("")}, |
| {{std::string("Contains space at end "), 21}, std::string("Contains space at end")}, |
| {{std::string("Chinese字符"), 7}, std::string("Chinese")}, |
| {{std::string("日本語"), 2}, std::string("日本")}, |
| {{std::string("Emoji 😊😂🤣"), 5}, std::string("Emoji")}, |
| {{std::string("SpecialCharacters#@!"), 11}, std::string("SpecialChar")}, |
| {{std::string("Numbers123456"), 7}, std::string("Numbers")}, |
| {{std::string("1234567890"), 0}, std::string("")}, |
| {{std::string("Empty"), Null()}, Null()}, |
| {{Null(), 5}, Null()}, |
| {{std::string("Leading and trailing "), 7}, std::string("Leading")}, |
| {{Null(), -10}, Null()}, |
| {{std::string("One Unicode 🔥"), 12}, std::string("One Unicode ")}, |
| {{std::string("🌟💫✨"), 2}, std::string("🌟💫")}, |
| {{std::string("New"), 1}, std::string("N")}, |
| {{std::string("New"), Null()}, Null()}, |
| {{Null(), 1}, Null()}, |
| {{std::string("Two words"), 9}, std::string("Two words")}, |
| {{std::string("Boundary case"), 13}, std::string("Boundary case")}, |
| {{std::string("Boundary case"), 14}, std::string("Boundary case")}, |
| {{std::string("Multi\nLine\nString"), 5}, std::string("Multi")}, |
| {{std::string(" SingleQuote'"), 12}, std::string(" SingleQuote")}, |
| {{std::string("\"DoubleQuote"), 12}, std::string("\"DoubleQuote")}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_lower_test) { |
| std::string func_name = "lower"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("abcdefg")}, |
| {{std::string("HELLO123")}, std::string("hello123")}, |
| {{std::string("你好HELLO")}, std::string("你好hello")}, |
| {{std::string("ÀÇ")}, std::string("àç")}, |
| {{std::string("ÀÇAC123")}, std::string("àçac123")}, |
| {{std::string("İstanbul")}, std::string("i̇stanbul")}, |
| {{std::string("KIZILAY")}, std::string("kizilay")}, |
| {{std::string("GROSSE")}, std::string("grosse")}, |
| {{std::string("Å")}, std::string("å")}, |
| {{std::string("ΣΟΦΟΣ")}, std::string("σοφος")}, |
| {{std::string("123ABC_")}, std::string("123abc_")}, |
| {{std::string("MYtestSTR")}, std::string("myteststr")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| //bug{{std::string("ΔΟΚΙΜΑΣΤΙΚΌ ΚΕΊΜΕΝΟ")}, std::string("δοκιμαστικό κείμενο")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| check_function_all_arg_comb<DataTypeString, true>(std::string("lcase"), input_types, |
| data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_upper_test) { |
| std::string func_name = "upper"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("ABCDEFG")}, |
| {{std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("MYtestSTR")}, std::string("MYTESTSTR")}, |
| {{std::string("àç")}, std::string("ÀÇ")}, |
| {{std::string("straße")}, std::string("STRASSE")}, |
| {{std::string("àçac123")}, std::string("ÀÇAC123")}, |
| {{std::string("ffi")}, std::string("FFI")}, |
| {{std::string("Dž")}, std::string("DŽ")}, |
| {{std::string("Ångström")}, std::string("ÅNGSTRÖM")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("abcdefghijklmnopqrstuvwxyz")}, |
| std::string("ABCDEFGHIJKLMNOPQRSTUVWXYZ")}, |
| {{std::string("`~!@#$%^&*()_-+=|\\{}[]:\";'<>?,./")}, |
| std::string("`~!@#$%^&*()_-+=|\\{}[]:\";'<>?,./")}, |
| {{std::string("MixedCASEabcdefghijklmnopqrstuvwxyz")}, |
| std::string("MIXEDCASEABCDEFGHIJKLMNOPQRSTUVWXYZ")}, |
| {{std::string("1234567890")}, std::string("1234567890")}, |
| {{std::string("!@#$%^&*( ) _+-={}[]|\\:;\"'<>?,./")}, |
| std::string("!@#$%^&*( ) _+-={}[]|\\:;\"'<>?,./")}, |
| {{std::string("Text with spaces")}, std::string("TEXT WITH SPACES")}, |
| //bug{{std::string("текст на русском")}, std::string("ТЕКСТ НА РУССКОМ")}, |
| {{std::string("文字列のテスト")}, std::string("文字列のテスト")}, |
| {{std::string("測試字符串")}, std::string("測試字符串")}, |
| {{std::string("테스트 문자열")}, std::string("테스트 문자열")}, |
| {{std::string("أحرف مختلفة")}, std::string("أحرف مختلفة")}, |
| //bug{{std::string("Δοκιµαστικό κείµενο")}, std::string("ΔΟΚΙΜΑΣΤΙΚΌ ΚΕΊΜΕΝΟ")}, |
| {{std::string("โพสต์ทดสอบ")}, std::string("โพสต์ทดสอบ")}, |
| {{std::string("יידיש טעקסט")}, std::string("יידיש טעקסט")}, |
| //bug{{std::string("Exámplè wïth âccents")}, std::string("EXÁMPLÈ WÏTH ÂCCENTS")}, |
| {{std::string("ⓔⓧⓐⓜⓟⓛⓔ ⓦⓘⓣⓗ ⓒⓘⓡⓒⓛⓔ ⓛⓔⓣⓣⓔⓡⓢ")}, |
| std::string("ⒺⓍⒶⓂⓅⓁⒺ ⓌⒾⓉⒽ ⒸⒾⓇⒸⓁⒺ ⓁⒺⓉⓉⒺⓇⓈ")}, |
| {{std::string("🅴🆇🅰🅼🅿🅻🅴 🆆🅸🆃🅷 🆂🆀🆄🅰🆁🅴 🅻🅴🆃🆃🅴🆁🆂")}, |
| std::string("🅴🆇🅰🅼🅿🅻🅴 🆆🅸🆃🅷 🆂🆀🆄🅰🆁🅴 🅻🅴🆃🆃🅴🆁🆂")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| check_function_all_arg_comb<DataTypeString, true>(std::string("ucase"), input_types, |
| data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_trim_test) { |
| std::string func_name = "trim"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string(" paddedStringNoEscape ")}, std::string("paddedStringNoEscape")}, |
| {{std::string("singleWord")}, std::string("singleWord")}, |
| {{std::string(" leadingSpaceStringNoEscape")}, |
| std::string("leadingSpaceStringNoEscape")}, |
| {{std::string("trailingSpaceStringNoEscape ")}, |
| std::string("trailingSpaceStringNoEscape")}, |
| {{std::string(" spaced out string ")}, std::string("spaced out string")}, |
| {{std::string("123 spaced number 321 ")}, |
| std::string("123 spaced number 321")}, |
| {{std::string(" mixed123NUMBERSandSymbols!!! ")}, |
| std::string("mixed123NUMBERSandSymbols!!!")}, |
| {{std::string(" ")}, std::string("")}, |
| {{std::string("123")}, std::string("123")}, |
| {{std::string("symbolic string #$*&^% ")}, std::string("symbolic string #$*&^%")}, |
| {{std::string(" Another Test Case")}, std::string("Another Test Case")}, |
| // 多语言字符串 |
| {{std::string(" 极客时间 ")}, std::string("极客时间")}, |
| {{std::string(" テストケース ")}, std::string("テストケース")}, |
| {{std::string(" 테스트케이스 ")}, std::string("테스트케이스")}, |
| {{std::string(" Дело ")}, std::string("Дело")}, |
| {{std::string(" Próba ")}, std::string("Próba")}, |
| {{std::string(" Épreuve ")}, std::string("Épreuve")}, |
| {{std::string(" αξιολόγηση ")}, std::string("αξιολόγηση")}, |
| {{std::string(" prova ")}, std::string("prova")}, |
| {{std::string(" prova ")}, std::string("prova")}, |
| // 纯数字和标点符号组合 |
| {{std::string(" 0.1234567890!@#$%^&*()_+ ")}, |
| std::string("0.1234567890!@#$%^&*()_+")}, |
| // 额外的单词和符号组合 |
| {{std::string(" hello, world! ")}, std::string("hello, world!")}, |
| {{std::string(" this is a test ")}, std::string("this is a test")}, |
| {{std::string(" spaces in the middle are fine ")}, |
| std::string("spaces in the middle are fine")}, |
| {{std::string(" string_with_underscores ")}, |
| std::string("string_with_underscores")}, |
| {{std::string(" string-with-dashes ")}, std::string("string-with-dashes")}, |
| {{std::string(" string with special: chars; here¡ ")}, |
| std::string("string with special: chars; here¡")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_ltrim_test) { |
| std::string func_name = "ltrim"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("!@#$@* (!&#")}, std::string("!@#$@* (!&#")}, |
| {{std::string("JSKAB(Q@__!")}, std::string("JSKAB(Q@__!")}, |
| {{std::string("MY test Str你好 ")}, std::string("MY test Str你好 ")}, |
| {{std::string(" ")}, std::string("")}, |
| {{std::string("23 12 --!__!_!__!")}, std::string("23 12 --!__!_!__!")}, |
| {{std::string("112+ + +")}, std::string("112+ + +")}, |
| {{std::string(" + 23 ")}, std::string("+ 23 ")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_string_rtrim_test) { |
| std::string func_name = "rtrim"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = {{ |
| {{std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("!@#$@* (!&#")}, std::string("!@#$@* (!&#")}, |
| {{std::string("JSKAB(Q@__!")}, std::string("JSKAB(Q@__!")}, |
| {{std::string("MY test Str你好 ")}, std::string("MY test Str你好")}, |
| {{std::string(" ")}, std::string("")}, |
| {{std::string("23 12 --!__!_!__!")}, std::string("23 12 --!__!_!__!")}, |
| {{std::string("112+ + +")}, std::string("112+ + +")}, |
| {{std::string(" + 23 ")}, std::string(" + 23")}, |
| }}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_string_repeat_test) { |
| std::string func_name = "repeat"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("AbCdEfg"), std::int32_t(1)}, std::string("AbCdEfg")}, |
| {{std::string("AbCdEfg"), std::int32_t(2)}, std::string("AbCdEfgAbCdEfg")}, |
| {{std::string("AbCdEfg"), std::int32_t(0)}, std::string("")}, |
| {{std::string("AbCdEfg"), std::int32_t(6)}, |
| std::string("AbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfg")}, |
| {{std::string("AbCdEfg"), std::int32_t(10)}, |
| std::string( |
| "AbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfgAbCdEfg")}, |
| {{std::string("AbCdEfg"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(1)}, std::string("HELLO123")}, |
| {{std::string("HELLO123"), std::int32_t(2)}, std::string("HELLO123HELLO123")}, |
| {{std::string("HELLO123"), std::int32_t(0)}, std::string("")}, |
| {{std::string("HELLO123"), std::int32_t(6)}, |
| std::string("HELLO123HELLO123HELLO123HELLO123HELLO123HELLO123")}, |
| {{std::string("HELLO123"), std::int32_t(10)}, |
| std::string("HELLO123HELLO123HELLO123HELLO123HELLO123HELLO123HELLO123HELLO123HELLO" |
| "123HELLO123")}, |
| {{std::string("HELLO123"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(1)}, std::string("你好HELLO")}, |
| {{std::string("你好HELLO"), std::int32_t(2)}, std::string("你好HELLO你好HELLO")}, |
| {{std::string("你好HELLO"), std::int32_t(0)}, std::string("")}, |
| {{std::string("你好HELLO"), std::int32_t(6)}, |
| std::string("你好HELLO你好HELLO你好HELLO你好HELLO你好HELLO你好HELLO")}, |
| {{std::string("你好HELLO"), std::int32_t(10)}, |
| std::string("你好HELLO你好HELLO你好HELLO你好HELLO你好HELLO你好HELLO你好HELLO你好HE" |
| "LLO你好HELLO你好HELLO")}, |
| {{std::string("你好HELLO"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(1)}, std::string("123ABC_")}, |
| {{std::string("123ABC_"), std::int32_t(2)}, std::string("123ABC_123ABC_")}, |
| {{std::string("123ABC_"), std::int32_t(0)}, std::string("")}, |
| {{std::string("123ABC_"), std::int32_t(6)}, |
| std::string("123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_")}, |
| {{std::string("123ABC_"), std::int32_t(10)}, |
| std::string( |
| "123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_123ABC_")}, |
| {{std::string("123ABC_"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(1)}, std::string("MYtestSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(2)}, std::string("MYtestSTRMYtestSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(0)}, std::string("")}, |
| {{std::string("MYtestSTR"), std::int32_t(6)}, |
| std::string("MYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtestSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(10)}, |
| std::string("MYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtestSTRMYtest" |
| "STRMYtestSTRMYtestSTR")}, |
| {{std::string("MYtestSTR"), std::int32_t(-1)}, std::string("")}, |
| {{std::string(""), std::int32_t(1)}, std::string("")}, |
| {{std::string(""), std::int32_t(2)}, std::string("")}, |
| {{std::string(""), std::int32_t(0)}, std::string("")}, |
| {{std::string(""), std::int32_t(6)}, std::string("")}, |
| {{std::string(""), std::int32_t(10)}, std::string("")}, |
| {{std::string(""), std::int32_t(-1)}, std::string("")}, |
| {{Null(), std::int32_t(1)}, Null()}, |
| {{Null(), std::int32_t(2)}, Null()}, |
| {{Null(), std::int32_t(0)}, Null()}, |
| {{Null(), std::int32_t(6)}, Null()}, |
| {{Null(), std::int32_t(10)}, Null()}, |
| {{Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(1)}, std::string("A,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(2)}, std::string("A,b,C,D,_EA,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(0)}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(6)}, |
| std::string("A,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(10)}, |
| std::string("A,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_" |
| "EA,b,C,D,_EA,b,C,D,_EA,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(1)}, std::string("1234321312312")}, |
| {{std::string("1234321312312"), std::int32_t(2)}, |
| std::string("12343213123121234321312312")}, |
| {{std::string("1234321312312"), std::int32_t(0)}, std::string("")}, |
| {{std::string("1234321312312"), std::int32_t(6)}, |
| std::string("123432131231212343213123121234321312312123432131231212343213123121234" |
| "321312312")}, |
| {{std::string("1234321312312"), std::int32_t(10)}, |
| std::string("123432131231212343213123121234321312312123432131231212343213123121234" |
| "3213123121234321312312123432131231212343213123121234321312312")}, |
| {{std::string("1234321312312"), std::int32_t(-1)}, std::string("")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(1)}, |
| std::string("heh1h2!u@u@i$o%ll_")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(2)}, |
| std::string("heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(0)}, std::string("")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(6)}, |
| std::string("heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%" |
| "ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(10)}, |
| std::string("heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%" |
| "ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@" |
| "i$o%ll_heh1h2!u@u@i$o%ll_heh1h2!u@u@i$o%ll_")}, |
| {{std::string("heh1h2!u@u@i$o%ll_"), std::int32_t(-1)}, std::string("")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_reverse_test) { |
| std::string func_name = "reverse"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("gfEdCbA")}, |
| {{std::string("HELLO123")}, std::string("321OLLEH")}, |
| {{std::string("你好HELLO")}, std::string("OLLEH好你")}, |
| {{std::string("123ABC_")}, std::string("_CBA321")}, |
| {{std::string("MYtestSTR")}, std::string("RTStsetYM")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("A,b,C,D,_E")}, std::string("E_,D,C,b,A")}, |
| {{std::string("1234321312312")}, std::string("2132131234321")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_")}, std::string("_ll%o$i@u_@u!_2h1heh")}, |
| {{std::string("AbCdEfg")}, std::string("gfEdCbA")}, |
| {{std::string("HELLO123")}, std::string("321OLLEH")}, |
| {{std::string("你好HELLO")}, std::string("OLLEH好你")}, |
| {{std::string("123ABC_")}, std::string("_CBA321")}, |
| {{std::string("MYtestSTR")}, std::string("RTStsetYM")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("A,b,C,D,_E")}, std::string("E_,D,C,b,A")}, |
| {{std::string("1234321312312")}, std::string("2132131234321")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_")}, std::string("_ll%o$i@u_@u!_2h1heh")}, |
| {{std::string("A1!B2@C3#")}, std::string("#3C@2B!1A")}, |
| {{std::string("~!@#$%^&*()_+")}, std::string("+_)(*&^%$#@!~")}, |
| {{std::string("😊😂😍❤️👍")}, std::string("👍️❤😍😂😊")}, |
| {{std::string("äöüß")}, std::string("ßüöä")}, |
| {{std::string("👨👩👧👦")}, |
| std::string("👦👧👩👨")}, |
| {{std::string("안녕하세요")}, std::string("요세하녕안")}, |
| {{std::string("Tab\tSeparated")}, |
| std::string("detarapeS\tbaT")}, // 包含制表符的字符串 |
| {{std::string("\nNewLine")}, std::string("eniLweN\n")}, // 包含换行符的字符串 |
| {{std::string("123\n456")}, std::string("654\n321")}, // 混合数字和换行符 |
| {{std::string("\x01\x02\x03\x04")}, |
| std::string("\x04\x03\x02\x01")}, // 包含非打印字符的字符串 |
| {{std::string("Level【中】")}, std::string("】中【leveL")}, // 混合英文和中文括号 |
| {{std::string("360° Rotation")}, std::string("noitatoR °063")}, // 包含特殊字符 ° |
| {{std::string("👩👩👧👦")}, |
| std::string("👦👧👩👩")}, // 家庭emoji序列 |
| {{std::string("👨🎓👩🎓")}, |
| std::string("🎓👩🎓👨")}, // 毕业生emoji序列 |
| {{std::string("ASCII 👨👨👧👦 UNICODE")}, |
| std::string("EDOCINU 👦👧👨👨 IICSA")}, // 混合ASCII和UNICODE字符 |
| {{std::string("💻 Programming 💾")}, |
| std::string("💾 gnimmargorP 💻")}, // 编程相关emoji |
| {{std::string("0010110")}, std::string("0110100")}, // 二进制序列 |
| {{std::string("readme.md")}, std::string("dm.emdaer")}, // 包含点的文件名 |
| {{std::string("info@example.com")}, |
| std::string("moc.elpmaxe@ofni")}, // 电子邮件地址 |
| {{std::string("1234567890")}, std::string("0987654321")}, // 纯数字 |
| {{std::string("!@#$%^&*()_+")}, std::string("+_)(*&^%$#@!")}, // 纯特殊字符 |
| {{std::string("UPPERlower123")}, std::string("321rewolREPPU")}, // 大小写和数字 |
| {{std::string("测试中文字符")}, std::string("符字文中试测")}, // 中文字符 |
| {{std::string("日本語テスト")}, std::string("トステ語本日")}, // 日文测试 |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_string_length_test) { |
| std::string func_name = "length"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9")}, std::int32_t(12)}, |
| {{std::string("aGVsbG8gd29ybGQ")}, std::int32_t(15)}, |
| {{std::string("SEVMTE8sIV4l")}, std::int32_t(12)}, |
| {{std::string("__123hehe1")}, std::int32_t(10)}, |
| {{std::string("")}, std::int32_t(0)}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, std::int32_t(36)}, |
| {{std::string("ò&ø")}, std::int32_t(5)}, |
| {{std::string("TVl0ZXN0U1RS")}, std::int32_t(12)}, |
| {{Null()}, Null()}, |
| {{std::string("123321!@#@$!@%!@#!@$!@")}, std::int32_t(22)}, |
| {{std::string("123")}, std::int32_t(3)}, |
| {{std::string("Hello, World!")}, std::int32_t(13)}, // 正常ASCII字符 |
| {{std::string("Привет, мир!")}, std::int32_t(21)}, // 俄文,使用Cyrillic characters |
| {{std::string("こんにちは世界")}, std::int32_t(21)}, // 日文,每个字符通常3字节 |
| {{std::string("안녕하세요세계")}, std::int32_t(21)}, // 韩文字符 |
| {{std::string("你好,世界!")}, std::int32_t(18)}, // 简体中文,每个字符通常3字节 |
| {{std::string("مرحبا بالعالم!")}, std::int32_t(26)}, // 阿拉伯语 |
| {{std::string("1234567890")}, std::int32_t(10)}, // 数字 |
| {{std::string("👨👨👧👦")}, std::int32_t(25)}, // 家庭成员Emoji |
| {{std::string("🇺🇸🇨🇳🇯🇵🇰🇷")}, std::int32_t(32)}, // 国旗Emoji |
| {{std::string("\u00F1")}, |
| std::int32_t(2)}, // ñ,为拉丁字母n with tilde,UTF-8中占用2字节 |
| {{std::string("\u65E5\u672C\u8A9E")}, std::int32_t(9)}, // 日本语,每个字符通常3个字节 |
| {{std::string("Hello, 世界!")}, std::int32_t(16)}, // 混合ASCII和非ASCII字符 |
| {{std::string("😀😃😄😁")}, std::int32_t(16)}, // Emoji,每个通常4个字节 |
| {{std::string("Quick brown 狐 jumps over a lazy 狗.")}, std::int32_t(38)}, // 混合字符串 |
| {{std::string("Löwe 老虎 Léopard")}, std::int32_t(21)}, // 欧洲文字和中文的混合 |
| {{std::string("Café 美丽")}, std::int32_t(12)}, // 带重音的字符 |
| {{std::string("Björk")}, std::int32_t(6)}, // 北欧名称 |
| {{std::string("¿Dónde está la biblioteca?")}, std::int32_t(29)}, // 西班牙语句子 |
| {{std::string("Zażółć gęślą jaźń")}, std::int32_t(26)}, // 波兰语句子,含特殊字符 |
| {{Null()}, Null()}, // 空值 |
| {{std::string(" ")}, std::int32_t(1)}, // 空格 |
| {{std::string(" ")}, std::int32_t(2)}, // 双空格 |
| |
| }; |
| |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_string_quote_test) { |
| std::string func_name = "quote"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("hello")}, std::string(R"('hello')")}, |
| {{std::string("hello\t\n\nworld")}, std::string("'hello\t\n\nworld'")}, |
| {{std::string("HELLO,!^%")}, std::string("'HELLO,!^%'")}, |
| {{std::string("MYtestStr\\t\\n")}, std::string("'MYtestStr\\t\\n'")}, |
| {{std::string("")}, std::string("''")}, |
| {{Null()}, Null()}, |
| {{std::string("A")}, std::string("'A'")}, |
| {{std::string(",")}, std::string("','")}, |
| {{std::string("")}, std::string("''")}, |
| {{std::string(",ABC,")}, std::string("',ABC,'")}, |
| {{std::string("123ABC!@# _")}, std::string("'123ABC!@# _'")}, |
| {{std::string("10@()*()$*!@")}, std::string("'10@()*()$*!@'")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_append_trailing_char_if_absent_test) { |
| std::string func_name = "append_trailing_char_if_absent"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("ASD"), std::string("D")}, std::string("ASD")}, |
| {{std::string("AS"), std::string("D")}, std::string("ASD")}, |
| {{std::string(""), std::string("")}, Null()}, |
| {{std::string(""), std::string("A")}, std::string("A")}, |
| {{std::string("AC"), std::string("BACBAC")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{Null(), std::string("ABC")}, Null()}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string("中文"), std::string("文")}, std::string("中文")}, |
| {{std::string("中"), std::string("文")}, std::string("中文")}, |
| {{std::string(""), std::string("文")}, std::string("文")}, |
| {{Null(), std::string("")}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_url_encode_test) { |
| std::string func_name = "url_encode"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("编码")}, std::string("%E7%BC%96%E7%A0%81")}, |
| {{std::string("http://www.baidu.com/?a=中文日文韩文俄文希伯来文Emoji")}, |
| std::string( |
| "http%3A%2F%2Fwww.baidu.com%2F%3Fa%3D%E4%B8%AD%E6%96%87%E6%97%A5%E6%96%87%E9%" |
| "9F%A9%E6%96%87%E4%BF%84%E6%96%87%E5%B8%8C%E4%BC%AF%E6%9D%A5%E6%96%87Emoji")}, |
| {{std::string("http://www.baidu.com?a=http%3A%2F%2Fexample.com%2F😊")}, |
| std::string("http%3A%2F%2Fwww.baidu.com%3Fa%3Dhttp%253A%252F%252Fexample.com%252F%F0%" |
| "9F%98%8A")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_starts_with_test) { |
| std::string func_name = "starts_with"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("hello world"), std::string("hello")}, uint8_t(1)}, |
| {{std::string("hello world"), std::string("world")}, uint8_t(0)}, |
| {{std::string("你好"), std::string("你")}, uint8_t(1)}, |
| {{std::string(""), std::string("")}, uint8_t(1)}, |
| {{std::string("你好"), Null()}, Null()}, |
| {{Null(), std::string("")}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeUInt8, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_ends_with_test) { |
| std::string func_name = "ends_with"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("hello world"), std::string("hello")}, uint8_t(0)}, |
| {{std::string("hello world"), std::string("world")}, uint8_t(1)}, |
| {{std::string("你好"), std::string("好")}, uint8_t(1)}, |
| {{std::string(""), std::string("")}, uint8_t(1)}, |
| {{std::string("你好"), Null()}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{std::string(1000, 'a'), std::string("a")}, uint8_t(1)}, |
| // 特殊的UTF-8字符 |
| {{std::string("This is a pencil ✏"), std::string("✏")}, uint8_t(1)}, |
| // 重复字符 |
| {{std::string("aaaaab"), std::string("b")}, uint8_t(1)}, |
| // 特殊格式的字符串 |
| {{std::string("user@example.com"), std::string("example.com")}, uint8_t(1)}, |
| {{std::string("https://example.com"), std::string(".com")}, uint8_t(1)}, |
| // 非常长的后缀 |
| {{std::string("hello"), std::string(10, 'o')}, uint8_t(0)}, |
| // 大小写不匹配 |
| {{std::string("CaseSensitive"), std::string("sensitive")}, uint8_t(0)}, |
| {{std::string("UpperCase"), std::string("CASE")}, uint8_t(0)}, |
| // 字符边界 |
| {{std::string("BoundaryTest"), std::string("Test")}, uint8_t(1)}, |
| // 空字符串 |
| {{std::string(""), std::string("")}, uint8_t(1)}, |
| // Null 情景 |
| {{std::string("Doris"), Null()}, Null()}, |
| {{Null(), std::string("Ends")}, Null()}, |
| {{Null(), Null()}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeUInt8, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_ascii_test) { |
| std::string func_name = "ascii"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9")}, std::int32_t(89)}, |
| {{std::string("aGVsbG8gd29ybGQ")}, std::int32_t(97)}, |
| {{std::string("SEVMTE8sIV4l")}, std::int32_t(83)}, |
| {{std::string("__123hehe1")}, std::int32_t(95)}, |
| {{std::string("")}, std::int32_t(0)}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, std::int32_t(53)}, |
| {{std::string("ò&ø")}, std::int32_t(195)}, |
| {{std::string("TVl0ZXN0U1RS")}, std::int32_t(84)}, |
| {{Null()}, Null()}, |
| {{std::string("123321!@#@$!@%!@#!@$!@")}, std::int32_t(49)}, |
| {{std::string("123")}, std::int32_t(49)}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_char_length_test) { |
| std::string func_name = "char_length"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9")}, std::int32_t(12)}, |
| {{std::string("aGVsbG8gd29ybGQ")}, std::int32_t(15)}, |
| {{std::string("SEVMTE8sIV4l")}, std::int32_t(12)}, |
| {{std::string("__123hehe1")}, std::int32_t(10)}, |
| {{std::string("")}, std::int32_t(0)}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, std::int32_t(36)}, |
| {{std::string("ò&ø")}, std::int32_t(3)}, |
| {{std::string("TVl0ZXN0U1RS")}, std::int32_t(12)}, |
| {{Null()}, Null()}, |
| {{std::string("123321!@#@$!@%!@#!@$!@")}, std::int32_t(22)}, |
| {{std::string("123")}, std::int32_t(3)}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_concat_test) { |
| std::string func_name = "concat"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("")}, std::string("")}, |
| {{std::string("123")}, std::string("123")}, |
| {{Null()}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("AbCdEfg"), std::string("AbCdEfg")}, std::string("AbCdEfgAbCdEfg")}, |
| {{std::string("AbCdEfg"), std::string("HELLO123")}, std::string("AbCdEfgHELLO123")}, |
| {{std::string("AbCdEfg"), std::string("你好HELLO")}, |
| std::string("AbCdEfg你好HELLO")}, |
| {{std::string("AbCdEfg"), std::string("123ABC_")}, std::string("AbCdEfg123ABC_")}, |
| {{std::string("AbCdEfg"), std::string("MYtestSTR")}, |
| std::string("AbCdEfgMYtestSTR")}, |
| {{std::string("AbCdEfg"), std::string("")}, std::string("AbCdEfg")}, |
| {{std::string("AbCdEfg"), Null()}, Null()}, |
| {{std::string("AbCdEfg"), std::string("A,b,C,D,_E")}, |
| std::string("AbCdEfgA,b,C,D,_E")}, |
| {{std::string("AbCdEfg"), std::string("1234321312312")}, |
| std::string("AbCdEfg1234321312312")}, |
| {{std::string("AbCdEfg"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("AbCdEfgheh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("HELLO123"), std::string("AbCdEfg")}, std::string("HELLO123AbCdEfg")}, |
| {{std::string("HELLO123"), std::string("HELLO123")}, |
| std::string("HELLO123HELLO123")}, |
| {{std::string("HELLO123"), std::string("你好HELLO")}, |
| std::string("HELLO123你好HELLO")}, |
| {{std::string("HELLO123"), std::string("123ABC_")}, std::string("HELLO123123ABC_")}, |
| {{std::string("HELLO123"), std::string("MYtestSTR")}, |
| std::string("HELLO123MYtestSTR")}, |
| {{std::string("HELLO123"), std::string("")}, std::string("HELLO123")}, |
| {{std::string("HELLO123"), Null()}, Null()}, |
| {{std::string("HELLO123"), std::string("A,b,C,D,_E")}, |
| std::string("HELLO123A,b,C,D,_E")}, |
| {{std::string("HELLO123"), std::string("1234321312312")}, |
| std::string("HELLO1231234321312312")}, |
| {{std::string("HELLO123"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("HELLO123heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("你好HELLO"), std::string("AbCdEfg")}, |
| std::string("你好HELLOAbCdEfg")}, |
| {{std::string("你好HELLO"), std::string("HELLO123")}, |
| std::string("你好HELLOHELLO123")}, |
| {{std::string("你好HELLO"), std::string("你好HELLO")}, |
| std::string("你好HELLO你好HELLO")}, |
| {{std::string("你好HELLO"), std::string("123ABC_")}, |
| std::string("你好HELLO123ABC_")}, |
| {{std::string("你好HELLO"), std::string("MYtestSTR")}, |
| std::string("你好HELLOMYtestSTR")}, |
| {{std::string("你好HELLO"), std::string("")}, std::string("你好HELLO")}, |
| {{std::string("你好HELLO"), Null()}, Null()}, |
| {{std::string("你好HELLO"), std::string("A,b,C,D,_E")}, |
| std::string("你好HELLOA,b,C,D,_E")}, |
| {{std::string("你好HELLO"), std::string("1234321312312")}, |
| std::string("你好HELLO1234321312312")}, |
| {{std::string("你好HELLO"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("你好HELLOheh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("123ABC_"), std::string("AbCdEfg")}, std::string("123ABC_AbCdEfg")}, |
| {{std::string("123ABC_"), std::string("HELLO123")}, std::string("123ABC_HELLO123")}, |
| {{std::string("123ABC_"), std::string("你好HELLO")}, |
| std::string("123ABC_你好HELLO")}, |
| {{std::string("123ABC_"), std::string("123ABC_")}, std::string("123ABC_123ABC_")}, |
| {{std::string("123ABC_"), std::string("MYtestSTR")}, |
| std::string("123ABC_MYtestSTR")}, |
| {{std::string("123ABC_"), std::string("")}, std::string("123ABC_")}, |
| {{std::string("123ABC_"), Null()}, Null()}, |
| {{std::string("123ABC_"), std::string("A,b,C,D,_E")}, |
| std::string("123ABC_A,b,C,D,_E")}, |
| {{std::string("123ABC_"), std::string("1234321312312")}, |
| std::string("123ABC_1234321312312")}, |
| {{std::string("123ABC_"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("123ABC_heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("MYtestSTR"), std::string("AbCdEfg")}, |
| std::string("MYtestSTRAbCdEfg")}, |
| {{std::string("MYtestSTR"), std::string("HELLO123")}, |
| std::string("MYtestSTRHELLO123")}, |
| {{std::string("MYtestSTR"), std::string("你好HELLO")}, |
| std::string("MYtestSTR你好HELLO")}, |
| {{std::string("MYtestSTR"), std::string("123ABC_")}, |
| std::string("MYtestSTR123ABC_")}, |
| {{std::string("MYtestSTR"), std::string("MYtestSTR")}, |
| std::string("MYtestSTRMYtestSTR")}, |
| {{std::string("MYtestSTR"), std::string("")}, std::string("MYtestSTR")}, |
| {{std::string("MYtestSTR"), Null()}, Null()}, |
| {{std::string("MYtestSTR"), std::string("A,b,C,D,_E")}, |
| std::string("MYtestSTRA,b,C,D,_E")}, |
| {{std::string("MYtestSTR"), std::string("1234321312312")}, |
| std::string("MYtestSTR1234321312312")}, |
| {{std::string("MYtestSTR"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("MYtestSTRheh1h2_!u@_u@i$o%ll_")}, |
| {{std::string(""), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string(""), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string(""), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string(""), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string(""), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string(""), std::string("")}, std::string("")}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string(""), std::string("1234321312312")}, std::string("1234321312312")}, |
| {{std::string(""), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{Null(), std::string("AbCdEfg")}, Null()}, |
| {{Null(), std::string("HELLO123")}, Null()}, |
| {{Null(), std::string("你好HELLO")}, Null()}, |
| {{Null(), std::string("123ABC_")}, Null()}, |
| {{Null(), std::string("MYtestSTR")}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("A,b,C,D,_E")}, Null()}, |
| {{Null(), std::string("1234321312312")}, Null()}, |
| {{Null(), std::string("heh1h2_!u@_u@i$o%ll_")}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::string("AbCdEfg")}, |
| std::string("A,b,C,D,_EAbCdEfg")}, |
| {{std::string("A,b,C,D,_E"), std::string("HELLO123")}, |
| std::string("A,b,C,D,_EHELLO123")}, |
| {{std::string("A,b,C,D,_E"), std::string("你好HELLO")}, |
| std::string("A,b,C,D,_E你好HELLO")}, |
| {{std::string("A,b,C,D,_E"), std::string("123ABC_")}, |
| std::string("A,b,C,D,_E123ABC_")}, |
| {{std::string("A,b,C,D,_E"), std::string("MYtestSTR")}, |
| std::string("A,b,C,D,_EMYtestSTR")}, |
| {{std::string("A,b,C,D,_E"), std::string("")}, std::string("A,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), Null()}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::string("A,b,C,D,_E")}, |
| std::string("A,b,C,D,_EA,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::string("1234321312312")}, |
| std::string("A,b,C,D,_E1234321312312")}, |
| {{std::string("A,b,C,D,_E"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("A,b,C,D,_Eheh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("1234321312312"), std::string("AbCdEfg")}, |
| std::string("1234321312312AbCdEfg")}, |
| {{std::string("1234321312312"), std::string("HELLO123")}, |
| std::string("1234321312312HELLO123")}, |
| {{std::string("1234321312312"), std::string("你好HELLO")}, |
| std::string("1234321312312你好HELLO")}, |
| {{std::string("1234321312312"), std::string("123ABC_")}, |
| std::string("1234321312312123ABC_")}, |
| {{std::string("1234321312312"), std::string("MYtestSTR")}, |
| std::string("1234321312312MYtestSTR")}, |
| {{std::string("1234321312312"), std::string("")}, std::string("1234321312312")}, |
| {{std::string("1234321312312"), Null()}, Null()}, |
| {{std::string("1234321312312"), std::string("A,b,C,D,_E")}, |
| std::string("1234321312312A,b,C,D,_E")}, |
| {{std::string("1234321312312"), std::string("1234321312312")}, |
| std::string("12343213123121234321312312")}, |
| {{std::string("1234321312312"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("1234321312312heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("AbCdEfg")}, |
| std::string("heh1h2_!u@_u@i$o%ll_AbCdEfg")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("HELLO123")}, |
| std::string("heh1h2_!u@_u@i$o%ll_HELLO123")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("你好HELLO")}, |
| std::string("heh1h2_!u@_u@i$o%ll_你好HELLO")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("123ABC_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_123ABC_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("MYtestSTR")}, |
| std::string("heh1h2_!u@_u@i$o%ll_MYtestSTR")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null()}, Null()}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("A,b,C,D,_E")}, |
| std::string("heh1h2_!u@_u@i$o%ll_A,b,C,D,_E")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("1234321312312")}, |
| std::string("heh1h2_!u@_u@i$o%ll_1234321312312")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_heh1h2_!u@_u@i$o%ll_")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string(""), std::string("1"), std::string("")}, std::string("1")}, |
| {{std::string("123"), std::string("456"), std::string("789")}, |
| std::string("123456789")}, |
| {{std::string("123"), Null(), std::string("789")}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| } |
| |
| TEST(function_string_test, function_elt_test) { |
| std::string func_name = "elt"; |
| |
| { |
| InputTypeSet input_types = { |
| PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, |
| }; |
| |
| DataSet data_set = { |
| {{Null(), std::string(""), std::string("")}, Null()}, |
| {{Null(), std::string(""), Null()}, Null()}, |
| {{Null(), std::string(""), std::string("!@#$@* (!&#")}, Null()}, |
| {{Null(), Null(), std::string("")}, Null()}, |
| {{Null(), Null(), Null()}, Null()}, |
| {{Null(), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{Null(), std::string("!@#$@* (!&#"), std::string("")}, Null()}, |
| {{Null(), std::string("!@#$@* (!&#"), Null()}, Null()}, |
| {{Null(), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(1), std::string(""), std::string("")}, std::string("")}, |
| {{std::int32_t(1), std::string(""), Null()}, std::string("")}, |
| {{std::int32_t(1), std::string(""), std::string("!@#$@* (!&#")}, std::string("")}, |
| // {{std::int32_t(1), Null(), std::string("")}, Null()}, |
| // {{std::int32_t(1), Null(), Null()}, Null()}, |
| // {{std::int32_t(1), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(1), std::string("!@#$@* (!&#"), std::string("")}, |
| std::string("!@#$@* (!&#")}, |
| {{std::int32_t(1), std::string("!@#$@* (!&#"), Null()}, std::string("!@#$@* (!&#")}, |
| {{std::int32_t(1), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, |
| std::string("!@#$@* (!&#")}, |
| {{std::int32_t(0), std::string(""), std::string("")}, Null()}, |
| {{std::int32_t(0), std::string(""), Null()}, Null()}, |
| {{std::int32_t(0), std::string(""), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(0), Null(), std::string("")}, Null()}, |
| {{std::int32_t(0), Null(), Null()}, Null()}, |
| {{std::int32_t(0), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), std::string("")}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), Null()}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(100), std::string(""), std::string("")}, Null()}, |
| {{std::int32_t(100), std::string(""), Null()}, Null()}, |
| {{std::int32_t(100), std::string(""), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(100), Null(), std::string("")}, Null()}, |
| {{std::int32_t(100), Null(), Null()}, Null()}, |
| {{std::int32_t(100), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(100), std::string("!@#$@* (!&#"), std::string("")}, Null()}, |
| {{std::int32_t(100), std::string("!@#$@* (!&#"), Null()}, Null()}, |
| {{std::int32_t(100), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, |
| Null()}, |
| {{std::int32_t(-1), std::string(""), std::string("")}, Null()}, |
| {{std::int32_t(-1), std::string(""), Null()}, Null()}, |
| {{std::int32_t(-1), std::string(""), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(-1), Null(), std::string("")}, Null()}, |
| {{std::int32_t(-1), Null(), Null()}, Null()}, |
| {{std::int32_t(-1), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(-1), std::string("!@#$@* (!&#"), std::string("")}, Null()}, |
| {{std::int32_t(-1), std::string("!@#$@* (!&#"), Null()}, Null()}, |
| {{std::int32_t(-1), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, |
| Null()}, |
| {{std::int32_t(0), std::string(""), std::string("")}, Null()}, |
| {{std::int32_t(0), std::string(""), Null()}, Null()}, |
| {{std::int32_t(0), std::string(""), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(0), Null(), std::string("")}, Null()}, |
| {{std::int32_t(0), Null(), Null()}, Null()}, |
| {{std::int32_t(0), Null(), std::string("!@#$@* (!&#")}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), std::string("")}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), Null()}, Null()}, |
| {{std::int32_t(0), std::string("!@#$@* (!&#"), std::string("!@#$@* (!&#")}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| } |
| |
| TEST(function_string_test, function_concat_ws_test) { |
| std::string func_name = "concat_ws"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("AbCdEfg"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("AbCdEfg"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("AbCdEfg"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("AbCdEfg"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("AbCdEfg"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("AbCdEfg"), std::string("")}, std::string("")}, |
| {{std::string("AbCdEfg"), Null()}, std::string("")}, |
| {{std::string("AbCdEfg"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("AbCdEfg"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("AbCdEfg"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("HELLO123"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("HELLO123"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("HELLO123"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("HELLO123"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("HELLO123"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("HELLO123"), std::string("")}, std::string("")}, |
| {{std::string("HELLO123"), Null()}, std::string("")}, |
| {{std::string("HELLO123"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("HELLO123"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("HELLO123"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("你好HELLO"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("你好HELLO"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("你好HELLO"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("你好HELLO"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("你好HELLO"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("你好HELLO"), std::string("")}, std::string("")}, |
| {{std::string("你好HELLO"), Null()}, std::string("")}, |
| {{std::string("你好HELLO"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("你好HELLO"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("你好HELLO"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("123ABC_"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("123ABC_"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("123ABC_"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("123ABC_"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("123ABC_"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("123ABC_"), std::string("")}, std::string("")}, |
| {{std::string("123ABC_"), Null()}, std::string("")}, |
| {{std::string("123ABC_"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("123ABC_"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("123ABC_"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("MYtestSTR"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("MYtestSTR"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("MYtestSTR"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("MYtestSTR"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("MYtestSTR"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("MYtestSTR"), std::string("")}, std::string("")}, |
| {{std::string("MYtestSTR"), Null()}, std::string("")}, |
| {{std::string("MYtestSTR"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("MYtestSTR"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("MYtestSTR"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string(""), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string(""), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string(""), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string(""), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string(""), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string(""), std::string("")}, std::string("")}, |
| {{std::string(""), Null()}, std::string("")}, |
| {{std::string(""), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string(""), std::string("1234321312312")}, std::string("1234321312312")}, |
| {{std::string(""), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{Null(), std::string("AbCdEfg")}, Null()}, |
| {{Null(), std::string("HELLO123")}, Null()}, |
| {{Null(), std::string("你好HELLO")}, Null()}, |
| {{Null(), std::string("123ABC_")}, Null()}, |
| {{Null(), std::string("MYtestSTR")}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("A,b,C,D,_E")}, Null()}, |
| {{Null(), std::string("1234321312312")}, Null()}, |
| {{Null(), std::string("heh1h2_!u@_u@i$o%ll_")}, Null()}, |
| {{std::string("A,b,C,D,_E"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("A,b,C,D,_E"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("A,b,C,D,_E"), std::string("你好HELLO")}, std::string("你好HELLO")}, |
| {{std::string("A,b,C,D,_E"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("A,b,C,D,_E"), std::string("MYtestSTR")}, std::string("MYtestSTR")}, |
| {{std::string("A,b,C,D,_E"), std::string("")}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), Null()}, std::string("")}, |
| {{std::string("A,b,C,D,_E"), std::string("A,b,C,D,_E")}, std::string("A,b,C,D,_E")}, |
| {{std::string("A,b,C,D,_E"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("A,b,C,D,_E"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("1234321312312"), std::string("AbCdEfg")}, std::string("AbCdEfg")}, |
| {{std::string("1234321312312"), std::string("HELLO123")}, std::string("HELLO123")}, |
| {{std::string("1234321312312"), std::string("你好HELLO")}, |
| std::string("你好HELLO")}, |
| {{std::string("1234321312312"), std::string("123ABC_")}, std::string("123ABC_")}, |
| {{std::string("1234321312312"), std::string("MYtestSTR")}, |
| std::string("MYtestSTR")}, |
| {{std::string("1234321312312"), std::string("")}, std::string("")}, |
| {{std::string("1234321312312"), Null()}, std::string("")}, |
| {{std::string("1234321312312"), std::string("A,b,C,D,_E")}, |
| std::string("A,b,C,D,_E")}, |
| {{std::string("1234321312312"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("1234321312312"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("AbCdEfg")}, |
| std::string("AbCdEfg")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("HELLO123")}, |
| std::string("HELLO123")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("你好HELLO")}, |
| std::string("你好HELLO")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("123ABC_")}, |
| std::string("123ABC_")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("MYtestSTR")}, |
| std::string("MYtestSTR")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("")}, std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), Null()}, std::string("")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("A,b,C,D,_E")}, |
| std::string("A,b,C,D,_E")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("1234321312312")}, |
| std::string("1234321312312")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_"), std::string("heh1h2_!u@_u@i$o%ll_")}, |
| std::string("heh1h2_!u@_u@i$o%ll_")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("-"), std::string(""), std::string("")}, std::string("-")}, |
| {{std::string(""), std::string("123"), std::string("456")}, std::string("123456")}, |
| {{std::string(""), std::string(""), std::string("")}, std::string("")}, |
| {{Null(), std::string(""), std::string("")}, Null()}, |
| {{Null(), std::string(""), Null()}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("-"), std::string(""), std::string(""), std::string("")}, |
| std::string("--")}, |
| {{std::string(""), std::string("123"), std::string("456"), std::string("789")}, |
| std::string("123456789")}, |
| {{std::string("-"), std::string(""), std::string("?"), std::string("")}, |
| std::string("-?-")}, |
| {{Null(), std::string(""), std::string("?"), std::string("")}, Null()}, |
| {{std::string("-"), std::string("123"), Null(), std::string("456")}, |
| std::string("123-456")}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_ARRAY, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| TestArray vec1 = {std::string(""), std::string(""), std::string("")}; |
| TestArray vec2 = {std::string("123"), std::string("456"), std::string("789")}; |
| TestArray vec3 = {std::string(""), std::string("?"), std::string("")}; |
| TestArray vec4 = {std::string("abc"), std::string(""), std::string("def")}; |
| TestArray vec5 = {std::string("abc"), std::string("def"), std::string("ghi")}; |
| DataSet data_set = {{{std::string("-"), vec1}, std::string("--")}, |
| {{std::string(""), vec2}, std::string("123456789")}, |
| {{std::string("-"), vec3}, std::string("-?-")}, |
| {{Null(), vec4}, Null()}, |
| {{std::string("-"), vec5}, std::string("abc-def-ghi")}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| }; |
| } |
| |
| TEST(function_string_test, function_null_or_empty_test) { |
| std::string func_name = "null_or_empty"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("")}, uint8_t(true)}, |
| {{std::string("aa")}, uint8_t(false)}, |
| {{std::string("我")}, uint8_t(false)}, |
| {{Null()}, uint8_t(true)}}; |
| |
| check_function_all_arg_comb<DataTypeUInt8, false>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_to_base64_test) { |
| std::string func_name = "to_base64"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("ABC")}, std::string("QUJD")}, |
| {{std::string("ABB")}, std::string("QUJC")}, |
| {{std::string("HEHE")}, std::string("SEVIRQ==")}, |
| {{std::string("__123hehe1")}, std::string("X18xMjNoZWhlMQ==")}, |
| {{std::string("")}, std::string("")}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, |
| std::string("NVpXSzVaT0k1Wk9JNVpPSThKK1loQ0RqZ0lMaWdKVGlnSlFo")}, |
| {{std::string("ò&ø")}, std::string("w7Imw7g=")}, |
| {{std::string("hehe")}, std::string("aGVoZQ==")}, |
| // // 特殊字符 |
| {{std::string("`~!@#$%^&*()-_=+")}, std::string("YH4hQCMkJV4mKigpLV89Kw==")}, |
| // // 末尾空格,这对 base64 编码意义重大 |
| {{std::string("test ")}, std::string("dGVzdCA=")}, |
| // // 空字符串 |
| {{std::string("")}, std::string("")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_from_base64_test) { |
| std::string func_name = "from_base64"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9")}, std::string("asd你好")}, |
| {{std::string("aGVsbG8gd29ybGQ")}, Null()}, |
| {{std::string("SEVMTE8sIV4l")}, std::string("HELLO,!^%")}, |
| {{std::string("__123hehe1")}, Null()}, |
| {{std::string("")}, std::string("")}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, |
| std::string("啊哈哈哈😄 。——!")}, |
| {{std::string("ò&ø")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS")}, std::string("MYtestSTR")}, |
| {{Null()}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_reverse_test) { |
| std::string func_name = "reverse"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("gfEdCbA")}, |
| {{std::string("HELLO123")}, std::string("321OLLEH")}, |
| {{std::string("你好HELLO")}, std::string("OLLEH好你")}, |
| {{std::string("123ABC_")}, std::string("_CBA321")}, |
| {{std::string("MYtestSTR")}, std::string("RTStsetYM")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("A,b,C,D,_E")}, std::string("E_,D,C,b,A")}, |
| {{std::string("1234321312312")}, std::string("2132131234321")}, |
| {{std::string("heh1h2_!u@_u@i$o%ll_")}, std::string("_ll%o$i@u_@u!_2h1heh")}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_instr_test) { |
| std::string func_name = "instr"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("ABC"), std::string("ABC")}, std::int32_t(1)}, |
| {{std::string("ABC"), std::string("B")}, std::int32_t(2)}, |
| {{std::string("ABC"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABCABCACBACBACBACBABCBACBACB")}, std::int32_t(0)}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{std::string("ABC"), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("")}, std::int32_t(1)}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{std::string("B"), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("B")}, std::int32_t(1)}, |
| {{std::string("B"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABCABCACBACBACBACBABCBACBACB")}, std::int32_t(0)}, |
| {{std::string("B"), Null()}, Null()}, |
| {{std::string("B"), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("")}, std::int32_t(1)}, |
| {{std::string("B"), Null()}, Null()}, |
| {{std::string("!@3$%^&*("), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("B")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("!@3$%^&*(")}, std::int32_t(1)}, |
| {{std::string("!@3$%^&*("), std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), Null()}, Null()}, |
| {{std::string("!@3$%^&*("), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("")}, std::int32_t(1)}, |
| {{std::string("!@3$%^&*("), Null()}, Null()}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("ABC")}, std::int32_t(1)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("B")}, std::int32_t(2)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("!@3$%^&*(")}, |
| std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(1)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), Null()}, Null()}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("1233213214126434563")}, |
| std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("")}, std::int32_t(1)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), Null()}, Null()}, |
| {{Null(), std::string("ABC")}, Null()}, |
| {{Null(), std::string("B")}, Null()}, |
| {{Null(), std::string("!@3$%^&*(")}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("1233213214126434563")}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{std::string("1233213214126434563"), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("B")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), Null()}, Null()}, |
| {{std::string("1233213214126434563"), std::string("1233213214126434563")}, |
| std::int32_t(1)}, |
| {{std::string("1233213214126434563"), std::string("")}, std::int32_t(1)}, |
| {{std::string("1233213214126434563"), Null()}, Null()}, |
| {{std::string(""), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string(""), std::string("B")}, std::int32_t(0)}, |
| {{std::string(""), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string(""), std::string("ABCABCACBACBACBACBABCBACBACB")}, std::int32_t(0)}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string(""), std::string("")}, std::int32_t(1)}, |
| {{std::string(""), Null()}, Null()}, |
| {{Null(), std::string("ABC")}, Null()}, |
| {{Null(), std::string("B")}, Null()}, |
| {{Null(), std::string("!@3$%^&*(")}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("1233213214126434563")}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_locate_test) { |
| std::string func_name = "locate"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("ABC"), std::string("ABC")}, std::int32_t(1)}, |
| {{std::string("ABC"), std::string("B")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(1)}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{std::string("ABC"), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABC")}, std::int32_t(2)}, |
| {{std::string("B"), std::string("B")}, std::int32_t(1)}, |
| {{std::string("B"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABCABCACBACBACBACBABCBACBACB")}, std::int32_t(2)}, |
| {{std::string("B"), Null()}, Null()}, |
| {{std::string("B"), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("B"), std::string("")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("B")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("!@3$%^&*(")}, std::int32_t(1)}, |
| {{std::string("!@3$%^&*("), std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), Null()}, Null()}, |
| {{std::string("!@3$%^&*("), std::string("1233213214126434563")}, std::int32_t(0)}, |
| {{std::string("!@3$%^&*("), std::string("")}, std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("ABC")}, |
| std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("B")}, std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("!@3$%^&*(")}, |
| std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(1)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), Null()}, Null()}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("1233213214126434563")}, |
| std::int32_t(0)}, |
| {{std::string("ABCABCACBACBACBACBABCBACBACB"), std::string("")}, std::int32_t(0)}, |
| {{Null(), std::string("ABC")}, Null()}, |
| {{Null(), std::string("B")}, Null()}, |
| {{Null(), std::string("!@3$%^&*(")}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("1233213214126434563")}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| {{std::string("1233213214126434563"), std::string("ABC")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("B")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("!@3$%^&*(")}, std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABCABCACBACBACBACBABCBACBACB")}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), Null()}, Null()}, |
| {{std::string("1233213214126434563"), std::string("1233213214126434563")}, |
| std::int32_t(1)}, |
| {{std::string("1233213214126434563"), std::string("")}, std::int32_t(0)}, |
| {{std::string(""), std::string("ABC")}, std::int32_t(1)}, |
| {{std::string(""), std::string("B")}, std::int32_t(1)}, |
| {{std::string(""), std::string("!@3$%^&*(")}, std::int32_t(1)}, |
| {{std::string(""), std::string("ABCABCACBACBACBACBABCBACBACB")}, std::int32_t(1)}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string("1233213214126434563")}, std::int32_t(1)}, |
| {{std::string(""), std::string("")}, std::int32_t(1)}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_INT}; |
| |
| DataSet data_set = { |
| {{std::string("ABC"), std::string("ABC"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABC"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABC"), std::int32_t(1)}, std::int32_t(1)}, |
| {{std::string("ABC"), std::string("B"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("B"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("B"), std::int32_t(1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("!@3$%^&*("), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("ABC"), std::string("!@3$%^&*("), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("!@3$%^&*("), std::int32_t(1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("ABC"), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(1)}, |
| std::int32_t(1)}, |
| {{std::string("ABC"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("ABC"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("ABC"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("ABC"), std::string(""), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string(""), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string(""), std::int32_t(1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABC"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABC"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABC"), std::int32_t(1)}, std::int32_t(2)}, |
| {{std::string("B"), std::string("B"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("B"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("B"), std::int32_t(1)}, std::int32_t(1)}, |
| {{std::string("B"), std::string("!@3$%^&*("), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("!@3$%^&*("), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("!@3$%^&*("), std::int32_t(1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("B"), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("B"), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(1)}, |
| std::int32_t(2)}, |
| {{std::string("B"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("B"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("B"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("B"), std::string(""), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string("B"), std::string(""), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string("B"), std::string(""), std::int32_t(1)}, std::int32_t(0)}, |
| {{Null(), std::string("ABC"), std::int32_t(100)}, Null()}, |
| {{Null(), std::string("ABC"), std::int32_t(-1)}, Null()}, |
| {{Null(), std::string("ABC"), std::int32_t(1)}, Null()}, |
| {{Null(), std::string("B"), std::int32_t(100)}, Null()}, |
| {{Null(), std::string("B"), std::int32_t(-1)}, Null()}, |
| {{Null(), std::string("B"), std::int32_t(1)}, Null()}, |
| {{Null(), std::string("!@3$%^&*("), std::int32_t(100)}, Null()}, |
| {{Null(), std::string("!@3$%^&*("), std::int32_t(-1)}, Null()}, |
| {{Null(), std::string("!@3$%^&*("), std::int32_t(1)}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(100)}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(-1)}, Null()}, |
| {{Null(), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(1)}, Null()}, |
| {{Null(), Null(), std::int32_t(100)}, Null()}, |
| {{Null(), Null(), std::int32_t(-1)}, Null()}, |
| {{Null(), Null(), std::int32_t(1)}, Null()}, |
| {{Null(), std::string(""), std::int32_t(100)}, Null()}, |
| {{Null(), std::string(""), std::int32_t(-1)}, Null()}, |
| {{Null(), std::string(""), std::int32_t(1)}, Null()}, |
| {{std::string("1233213214126434563"), std::string("ABC"), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABC"), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABC"), std::int32_t(1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("B"), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("B"), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("B"), std::int32_t(1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("!@3$%^&*("), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("!@3$%^&*("), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("!@3$%^&*("), std::int32_t(1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string("ABCABCACBACBACBACBABCBACBACB"), |
| std::int32_t(1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), Null(), std::int32_t(100)}, Null()}, |
| {{std::string("1233213214126434563"), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string("1233213214126434563"), Null(), std::int32_t(1)}, Null()}, |
| {{std::string("1233213214126434563"), std::string(""), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string(""), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string("1233213214126434563"), std::string(""), std::int32_t(1)}, |
| std::int32_t(0)}, |
| {{std::string(""), std::string("ABC"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string(""), std::string("ABC"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string(""), std::string("ABC"), std::int32_t(1)}, std::int32_t(1)}, |
| {{std::string(""), std::string("B"), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string(""), std::string("B"), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string(""), std::string("B"), std::int32_t(1)}, std::int32_t(1)}, |
| {{std::string(""), std::string("!@3$%^&*("), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string(""), std::string("!@3$%^&*("), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string(""), std::string("!@3$%^&*("), std::int32_t(1)}, std::int32_t(1)}, |
| {{std::string(""), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(100)}, |
| std::int32_t(0)}, |
| {{std::string(""), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(-1)}, |
| std::int32_t(0)}, |
| {{std::string(""), std::string("ABCABCACBACBACBACBABCBACBACB"), std::int32_t(1)}, |
| std::int32_t(1)}, |
| {{std::string(""), Null(), std::int32_t(100)}, Null()}, |
| {{std::string(""), Null(), std::int32_t(-1)}, Null()}, |
| {{std::string(""), Null(), std::int32_t(1)}, Null()}, |
| {{std::string(""), std::string(""), std::int32_t(100)}, std::int32_t(0)}, |
| {{std::string(""), std::string(""), std::int32_t(-1)}, std::int32_t(0)}, |
| {{std::string(""), std::string(""), std::int32_t(1)}, std::int32_t(1)}, |
| }; |
| |
| static_cast<void>( |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set)); |
| } |
| } |
| |
| TEST(function_string_test, function_find_in_set_test) { |
| std::string func_name = "find_in_set"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("ABC"), std::string("A,B,C")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string(",,,,,,")}, std::int32_t(0)}, |
| {{std::string("ABC"), std::string(",ABC,")}, std::int32_t(2)}, |
| {{std::string("ABC"), Null()}, Null()}, |
| {{std::string("ABC"), std::string("")}, std::int32_t(0)}, |
| {{std::string("A"), std::string("A,B,C")}, std::int32_t(1)}, |
| {{std::string("A"), std::string(",,,,,,")}, std::int32_t(0)}, |
| {{std::string("A"), std::string(",ABC,")}, std::int32_t(0)}, |
| {{std::string("A"), Null()}, Null()}, |
| {{std::string("A"), std::string("")}, std::int32_t(0)}, |
| {{std::string(","), std::string("A,B,C")}, std::int32_t(0)}, |
| {{std::string(","), std::string(",,,,,,")}, std::int32_t(0)}, |
| {{std::string(","), std::string(",ABC,")}, std::int32_t(0)}, |
| {{std::string(","), Null()}, Null()}, |
| {{std::string(","), std::string("")}, std::int32_t(0)}, |
| {{std::string(""), std::string("A,B,C")}, std::int32_t(0)}, |
| {{std::string(""), std::string(",,,,,,")}, std::int32_t(1)}, |
| {{std::string(""), std::string(",ABC,")}, std::int32_t(1)}, |
| {{std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string("")}, std::int32_t(1)}, |
| {{Null(), std::string("A,B,C")}, Null()}, |
| {{Null(), std::string(",,,,,,")}, Null()}, |
| {{Null(), std::string(",ABC,")}, Null()}, |
| {{Null(), Null()}, Null()}, |
| {{Null(), std::string("")}, Null()}, |
| }; |
| |
| static_cast<void>( |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set)); |
| } |
| |
| TEST(function_string_test, function_md5sum_test) { |
| std::string func_name = "md5sum"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("asd你好")}, {std::string("a38c15675555017e6b8ea042f2eb24f5")}}, |
| {{std::string("hello world")}, {std::string("5eb63bbbe01eeed093cb22bb8f5acdc3")}}, |
| {{std::string("HELLO,!^%")}, {std::string("b8e6e34d1cc3dc76b784ddfdfb7df800")}}, |
| {{std::string("")}, {std::string("d41d8cd98f00b204e9800998ecf8427e")}}, |
| {{std::string(" ")}, {std::string("7215ee9c7d9dc229d2921a40e899ec5f")}}, |
| {{Null()}, {Null()}}, |
| {{std::string("MYtestSTR")}, {std::string("cd24c90b3fc1192eb1879093029e87d4")}}, |
| {{std::string("ò&ø")}, {std::string("fd157b4cb921fa91acc667380184d59c")}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = {{{std::string("asd"), std::string("你好")}, |
| {std::string("a38c15675555017e6b8ea042f2eb24f5")}}, |
| {{std::string("hello "), std::string("world")}, |
| {std::string("5eb63bbbe01eeed093cb22bb8f5acdc3")}}, |
| {{std::string("HELLO"), std::string(",!^%")}, |
| {std::string("b8e6e34d1cc3dc76b784ddfdfb7df800")}}, |
| {{Null(), std::string("HELLO")}, {Null()}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = {{{std::string("a"), std::string("sd"), std::string("你好")}, |
| {std::string("a38c15675555017e6b8ea042f2eb24f5")}}, |
| {{std::string(""), std::string(""), std::string("")}, |
| {std::string("d41d8cd98f00b204e9800998ecf8427e")}}, |
| {{std::string("HEL"), std::string("LO,!"), std::string("^%")}, |
| {std::string("b8e6e34d1cc3dc76b784ddfdfb7df800")}}, |
| {{Null(), std::string("HELLO"), Null()}, {Null()}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_sm3sum_test) { |
| std::string func_name = "sm3sum"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("asd你好")}, |
| {std::string("0d6b9dfa8fe5708eb0dccfbaff4f2964abaaa976cc4445a7ecace49c0ceb31d3")}}, |
| {{std::string("hello world")}, |
| {std::string("44f0061e69fa6fdfc290c494654a05dc0c053da7e5c52b84ef93a9d67d3fff88")}}, |
| {{std::string("HELLO,!^%")}, |
| {std::string("5fc6e38f40b31a659a59e1daba9b68263615f20c02037b419d9deb3509e6b5c6")}}, |
| {{std::string("")}, |
| {std::string("1ab21d8355cfa17f8e61194831e81a8f22bec8c728fefb747ed035eb5082aa2b")}}, |
| {{std::string(" ")}, |
| {std::string("2ae1d69bb8483e5944310c877573b21d0a420c3bf4a2a91b1a8370d760ba67c5")}}, |
| {{Null()}, {Null()}}, |
| {{std::string("MYtestSTR")}, |
| {std::string("3155ae9f834cae035385fc15b69b6f2c051b91de943ea9a03ab8bfd497aef4c6")}}, |
| {{std::string("ò&ø")}, |
| {std::string( |
| "aa47ac31c85aa819d4cc80c932e7900fa26a3073a67aa7eb011bc2ba4924a066")}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("asd"), std::string("你好")}, |
| {std::string("0d6b9dfa8fe5708eb0dccfbaff4f2964abaaa976cc4445a7ecace49c0ceb31d3")}}, |
| {{std::string("hello "), std::string("world")}, |
| {std::string("44f0061e69fa6fdfc290c494654a05dc0c053da7e5c52b84ef93a9d67d3fff88")}}, |
| {{std::string("HELLO "), std::string(",!^%")}, |
| {std::string("1f5866e786ebac9ffed0dbd8f2586e3e99d1d05f7efe7c5915478b57b7423570")}}, |
| {{Null(), std::string("HELLO")}, {Null()}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("a"), std::string("sd"), std::string("你好")}, |
| {std::string("0d6b9dfa8fe5708eb0dccfbaff4f2964abaaa976cc4445a7ecace49c0ceb31d3")}}, |
| {{std::string(""), std::string(""), std::string("")}, |
| {std::string("1ab21d8355cfa17f8e61194831e81a8f22bec8c728fefb747ed035eb5082aa2b")}}, |
| {{std::string("HEL"), std::string("LO,!"), std::string("^%")}, |
| {std::string("5fc6e38f40b31a659a59e1daba9b68263615f20c02037b419d9deb3509e6b5c6")}}, |
| {{Null(), std::string("HELLO"), Null()}, {Null()}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_aes_encrypt_test) { |
| //FIXME: these tests have no meaning because the result is from themselves. |
| std::string func_name = "aes_encrypt"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* mode = "AES_128_ECB"; |
| const char* key = "doris"; |
| const char* src[6] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee", ""}; |
| std::string r[6]; |
| |
| for (int i = 0; i < 6; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| |
| int outlen = EncryptionUtil::encrypt( |
| EncryptionMode::AES_128_ECB, (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), nullptr, 0, true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = {{{std::string(src[0]), std::string(key), std::string(mode)}, r[0]}, |
| {{std::string(src[1]), std::string(key), std::string(mode)}, r[1]}, |
| {{std::string(src[2]), std::string(key), std::string(mode)}, r[2]}, |
| {{std::string(src[3]), std::string(key), std::string(mode)}, r[3]}, |
| {{std::string(src[4]), std::string(key), std::string(mode)}, r[4]}, |
| {{std::string(src[5]), std::string(key), std::string(mode)}, r[5]}, |
| {{Null(), std::string(key), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "AES_256_ECB"; |
| const char* key = "vectorized"; |
| const char* src[6] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee", ""}; |
| std::string r[6]; |
| |
| for (int i = 0; i < 6; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::AES_256_ECB, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = { |
| {{std::string(src[0]), std::string(key), std::string(iv), std::string(mode)}, r[0]}, |
| {{std::string(src[1]), std::string(key), std::string(iv), std::string(mode)}, r[1]}, |
| {{std::string(src[2]), std::string(key), std::string(iv), std::string(mode)}, r[2]}, |
| {{std::string(src[3]), std::string(key), std::string(iv), std::string(mode)}, r[3]}, |
| {{std::string(src[4]), std::string(key), std::string(iv), std::string(mode)}, r[4]}, |
| {{std::string(src[5]), std::string(key), std::string(iv), std::string(mode)}, r[5]}, |
| {{Null(), std::string(key), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_aes_decrypt_test) { |
| std::string func_name = "aes_decrypt"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* mode = "AES_128_ECB"; |
| const char* key = "doris"; |
| const char* src[5] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee"}; |
| std::string r[5]; |
| |
| for (int i = 0; i < 5; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| |
| int outlen = EncryptionUtil::encrypt( |
| EncryptionMode::AES_128_ECB, (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), nullptr, 0, true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = {{{r[0], std::string(key), std::string(mode)}, std::string(src[0])}, |
| {{r[1], std::string(key), std::string(mode)}, std::string(src[1])}, |
| {{r[2], std::string(key), std::string(mode)}, std::string(src[2])}, |
| {{r[3], std::string(key), std::string(mode)}, std::string(src[3])}, |
| {{r[4], std::string(key), std::string(mode)}, std::string(src[4])}, |
| {{Null(), std::string(key), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| const char* key = "vectorized"; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "AES_128_OFB"; |
| const char* src[5] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee"}; |
| |
| std::string r[5]; |
| for (int i = 0; i < 5; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::AES_128_OFB, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| DataSet data_set = { |
| {{r[0], std::string(key), std::string(iv), std::string(mode)}, std::string(src[0])}, |
| {{r[1], std::string(key), std::string(iv), std::string(mode)}, std::string(src[1])}, |
| {{r[2], std::string(key), std::string(iv), std::string(mode)}, std::string(src[2])}, |
| {{r[3], std::string(key), std::string(iv), std::string(mode)}, std::string(src[3])}, |
| {{r[4], std::string(key), std::string(iv), std::string(mode)}, std::string(src[4])}, |
| {{Null(), std::string(key), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_sm4_encrypt_test) { |
| std::string func_name = "sm4_encrypt"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* key = "doris"; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "SM4_128_ECB"; |
| const char* src[6] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee", ""}; |
| std::string r[6]; |
| |
| for (int i = 0; i < 6; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::SM4_128_ECB, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = { |
| {{std::string(src[0]), std::string(key), std::string(iv), std::string(mode)}, r[0]}, |
| {{std::string(src[1]), std::string(key), std::string(iv), std::string(mode)}, r[1]}, |
| {{std::string(src[2]), std::string(key), std::string(iv), std::string(mode)}, r[2]}, |
| {{std::string(src[3]), std::string(key), std::string(iv), std::string(mode)}, r[3]}, |
| {{std::string(src[4]), std::string(key), std::string(iv), std::string(mode)}, r[4]}, |
| {{std::string(src[5]), std::string(key), std::string(iv), std::string(mode)}, r[5]}, |
| {{Null(), std::string(key), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* key = "vectorized"; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "SM4_128_CTR"; |
| const char* src[6] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee", ""}; |
| std::string r[6]; |
| |
| for (int i = 0; i < 6; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::SM4_128_CTR, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = { |
| {{std::string(src[0]), std::string(key), std::string(iv), std::string(mode)}, r[0]}, |
| {{std::string(src[1]), std::string(key), std::string(iv), std::string(mode)}, r[1]}, |
| {{std::string(src[2]), std::string(key), std::string(iv), std::string(mode)}, r[2]}, |
| {{std::string(src[3]), std::string(key), std::string(iv), std::string(mode)}, r[3]}, |
| {{std::string(src[4]), std::string(key), std::string(iv), std::string(mode)}, r[4]}, |
| {{std::string(src[5]), std::string(key), std::string(iv), std::string(mode)}, r[5]}, |
| {{Null(), std::string(key), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_sm4_decrypt_test) { |
| std::string func_name = "sm4_decrypt"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* key = "doris"; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "SM4_128_ECB"; |
| const char* src[5] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee"}; |
| std::string r[5]; |
| |
| for (int i = 0; i < 5; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::SM4_128_ECB, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = { |
| {{r[0], std::string(key), std::string(iv), std::string(mode)}, std::string(src[0])}, |
| {{r[1], std::string(key), std::string(iv), std::string(mode)}, std::string(src[1])}, |
| {{r[2], std::string(key), std::string(iv), std::string(mode)}, std::string(src[2])}, |
| {{r[3], std::string(key), std::string(iv), std::string(mode)}, std::string(src[3])}, |
| {{r[4], std::string(key), std::string(iv), std::string(mode)}, std::string(src[4])}, |
| {{Null(), std::string(key), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| const char* key = "vectorized"; |
| const char* iv = "0123456789abcdef"; |
| const char* mode = "SM4_128_OFB"; |
| const char* src[5] = {"aaaaaa", "bbbbbb", "cccccc", "dddddd", "eeeeee"}; |
| std::string r[5]; |
| |
| for (int i = 0; i < 5; i++) { |
| int cipher_len = strlen(src[i]) + 16; |
| std::vector<char> p(cipher_len); |
| int iv_len = 32; |
| std::unique_ptr<char[]> init_vec; |
| init_vec.reset(new char[iv_len]); |
| std::memset(init_vec.get(), 0, strlen(iv) + 1); |
| memcpy(init_vec.get(), iv, strlen(iv)); |
| int outlen = EncryptionUtil::encrypt(EncryptionMode::SM4_128_OFB, |
| (unsigned char*)src[i], strlen(src[i]), |
| (unsigned char*)key, strlen(key), init_vec.get(), |
| strlen(iv), true, (unsigned char*)p.data()); |
| r[i] = std::string(p.data(), outlen); |
| } |
| |
| DataSet data_set = { |
| {{r[0], std::string(key), std::string(iv), std::string(mode)}, std::string(src[0])}, |
| {{r[1], std::string(key), std::string(iv), std::string(mode)}, std::string(src[1])}, |
| {{r[2], std::string(key), std::string(iv), std::string(mode)}, std::string(src[2])}, |
| {{r[3], std::string(key), std::string(iv), std::string(mode)}, std::string(src[3])}, |
| {{r[4], std::string(key), std::string(iv), std::string(mode)}, std::string(src[4])}, |
| {{Null(), Null(), std::string(iv), std::string(mode)}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_extract_url_parameter_test) { |
| std::string func_name = "extract_url_parameter"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{VARCHAR(""), VARCHAR("k1")}, {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa"), VARCHAR("")}, {VARCHAR("")}}, |
| {{VARCHAR("https://doris.apache.org/"), VARCHAR("k1")}, {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?"), VARCHAR("k1")}, {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa"), VARCHAR("k1")}, {VARCHAR("aa")}}, |
| {{VARCHAR("http://doris.apache.org:8080?k1&k2=bb#99"), VARCHAR("k1")}, {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa#999"), VARCHAR("k1")}, {VARCHAR("aa")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa&k2=bb&test=dd#999/"), VARCHAR("k1")}, |
| {VARCHAR("aa")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa&k2=bb&test=dd#999/"), VARCHAR("k2")}, |
| {VARCHAR("bb")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa&k2=bb&test=dd#999/"), VARCHAR("999")}, |
| {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa&k2=bb&test=dd#999/"), VARCHAR("k3")}, |
| {VARCHAR("")}}, |
| {{VARCHAR("http://doris.apache.org?k1=aa&k2=bb&test=dd#999/"), VARCHAR("test")}, |
| {VARCHAR("dd")}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_parse_url_test) { |
| std::string func_name = "parse_url"; |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("zhangsan"), std::string("HOST")}, {Null()}}, |
| {{std::string("facebook.com/path/p1"), std::string("HOST")}, {Null()}}, |
| {{std::string("http://fb.com/path/p1.p?q=1#f"), std::string("HOST")}, |
| {std::string("fb.com")}}, |
| {{std::string("https://www.facebook.com/aa/bb?returnpage=https://www.facebook.com/" |
| "aa/bb/cc"), |
| std::string("HOST")}, |
| {std::string("www.facebook.com")}}, |
| {{std::string("http://facebook.com/path/p1.php?query=1"), std::string("AUTHORITY")}, |
| {std::string("facebook.com")}}, |
| {{std::string("http://facebook.com/path/p1.php?query=1"), std::string("authority")}, |
| {std::string("facebook.com")}}, |
| {{std::string("http://www.baidu.com:9090/a/b/c.php"), std::string("FILE")}, |
| {std::string("/a/b/c.php")}}, |
| {{std::string("http://www.baidu.com:9090/a/b/c.php"), std::string("file")}, |
| {std::string("/a/b/c.php")}}, |
| {{std::string("http://www.baidu.com:9090/a/b/c.php"), std::string("PATH")}, |
| {std::string("/a/b/c.php")}}, |
| {{std::string("http://www.baidu.com:9090/a/b/c.php"), std::string("path")}, |
| {std::string("/a/b/c.php")}}, |
| {{std::string("http://facebook.com/path/p1.php?query=1"), std::string("PROTOCOL")}, |
| {std::string("http")}}, |
| {{std::string("http://facebook.com/path/p1.php?query=1"), std::string("protocol")}, |
| {std::string("http")}}, |
| {{std::string("http://www.baidu.com:9090?a=b"), std::string("QUERY")}, |
| {std::string("a=b")}}, |
| {{std::string("http://www.baidu.com:9090?a=b"), std::string("query")}, |
| {std::string("a=b")}}, |
| {{std::string("http://www.baidu.com:9090?a=b"), std::string("REF")}, {Null()}}, |
| {{std::string("http://www.baidu.com:9090?a=b"), std::string("ref")}, {Null()}}, |
| {{std::string("http://www.baidu.com:9090/a/b/c?a=b"), std::string("PORT")}, |
| {std::string("9090")}}, |
| {{std::string("http://www.baidu.com/a/b/c?a=b"), std::string("PORT")}, {Null()}}, |
| {{std::string("http://fb.com/path/p1.p?q=1#f"), std::string("QUERY")}, |
| {std::string("q=1")}}, |
| {{std::string( |
| "https://www.facebook.com/aa/bb?returnpage=https://www.facebook.com/"), |
| std::string("HosT")}, |
| std::string("www.facebook.com")}, |
| {{std::string("http://www.baidu.com"), std::string("FILE")}, {std::string("")}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("http://fb.com/path/p1.p?q=1#f"), std::string("QUERY"), |
| std::string("q")}, |
| {std::string("1")}}, |
| {{std::string("fb.com/path/p1.p?q=1#f"), std::string("QUERY"), std::string("q")}, |
| {std::string("1")}}, |
| {{std::string("http://facebook.com/path/p1"), std::string("QUERY"), |
| std::string("q")}, |
| {Null()}}, |
| {{std::string("http://fb.com/path/p1.p?q=1#f"), std::string("HOST"), |
| std::string("q")}, |
| {Null()}}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_hex_test) { |
| std::string func_name = "hex"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("AbCdEfg")}, std::string("41624364456667")}, |
| {{std::string("你好HELLO")}, std::string("E4BDA0E5A5BD48454C4C4F")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("!@#$@* (!&#")}, std::string("21402324402A2028212623")}, |
| {{std::string("JSKAB(Q@__!")}, std::string("4A534B41422851405F5F21")}, |
| {{std::string("MY test Str你好 ")}, |
| std::string("4D59207465737420537472E4BDA0E5A5BD2020")}, |
| {{std::string(" ")}, std::string("2020202020202020202020202020202020")}, |
| {{std::string("23 12 --!__!_!__!")}, std::string("3233203132202D2D215F5F215F215F5F21")}, |
| {{std::string("112+ + +")}, std::string("3131322B202B202B")}, |
| {{std::string(" + 23 ")}, std::string("20202020202B20202020202020323320")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_unhex_test) { |
| std::string unhex_func_name = "unhex"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("41624364456667")}, std::string("AbCdEfg")}, |
| {{std::string("E4BDA0E5A5BD48454C4C4F")}, std::string("你好HELLO")}, |
| {{std::string("")}, std::string("")}, |
| {{Null()}, Null()}, |
| {{std::string("21402324402A2028212623")}, std::string("!@#$@* (!&#")}, |
| {{std::string("4A534B41422851405F5F21")}, std::string("JSKAB(Q@__!")}, |
| // {{std::string("M4D59207465737420537472E4BDA0E5A5BD2020")}, Null()}, |
| {{std::string("2020202020202020202020202020202020")}, std::string(" ")}, |
| {{std::string("3233203132202D2D215F5F215F215F5F21")}, std::string("23 12 --!__!_!__!")}, |
| {{std::string("3131322B202B202B")}, std::string("112+ + +")}, |
| {{std::string("20202020202B20202020202020323320")}, std::string(" + 23 ")}, |
| // {{std::string("!")}, Null()}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(unhex_func_name, input_types, data_set); |
| |
| std::string unhex_null_func_name = "unhex_null"; |
| data_set = { |
| {{std::string("41624364456667")}, std::string("AbCdEfg")}, |
| {{std::string("E4BDA0E5A5BD48454C4C4F")}, std::string("你好HELLO")}, |
| {{std::string("")}, Null()}, |
| {{Null()}, Null()}, |
| {{std::string("21402324402A2028212623")}, std::string("!@#$@* (!&#")}, |
| {{std::string("4A534B41422851405F5F21")}, std::string("JSKAB(Q@__!")}, |
| {{std::string("M4D59207465737420537472E4BDA0E5A5BD2020")}, Null()}, |
| {{std::string("2020202020202020202020202020202020")}, std::string(" ")}, |
| {{std::string("3233203132202D2D215F5F215F215F5F21")}, std::string("23 12 --!__!_!__!")}, |
| {{std::string("3131322B202B202B")}, std::string("112+ + +")}, |
| {{std::string("20202020202B20202020202020323320")}, std::string(" + 23 ")}, |
| {{std::string("41G42")}, Null()}, |
| {{std::string("!")}, Null()}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(unhex_null_func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_coalesce_test) { |
| std::string func_name = "coalesce"; |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_INT, PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_INT}; |
| DataSet data_set = {{{Null(), Null(), (int32_t)1}, {(int32_t)1}}, |
| {{Null(), Null(), (int32_t)2}, {(int32_t)2}}, |
| {{Null(), Null(), (int32_t)3}, {(int32_t)3}}, |
| {{Null(), Null(), (int32_t)4}, {(int32_t)4}}}; |
| static_cast<void>( |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set)); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_INT}; |
| DataSet data_set = { |
| {{std::string("qwer"), Null(), (int32_t)1}, {std::string("qwer")}}, |
| {{std::string("asdf"), Null(), (int32_t)2}, {std::string("asdf")}}, |
| {{std::string("zxcv"), Null(), (int32_t)3}, {std::string("zxcv")}}, |
| {{std::string("vbnm"), Null(), (int32_t)4}, {std::string("vbnm")}}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| { |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{Null(), std::string("abc"), std::string("hij")}, {std::string("abc")}}, |
| {{Null(), std::string("def"), std::string("klm")}, {std::string("def")}}, |
| {{Null(), std::string(""), std::string("xyz")}, {std::string("")}}, |
| {{Null(), Null(), std::string("uvw")}, {std::string("uvw")}}}; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_replace) { |
| std::string func_name = "replace"; |
| InputTypeSet input_types = { |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, |
| }; |
| DataSet data_set = { |
| {{std::string("A"), std::string("A"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string("A"), std::string(",")}, std::string(",")}, |
| {{std::string("A"), std::string("A"), std::string("")}, std::string("")}, |
| {{std::string("A"), std::string("A"), Null()}, Null()}, |
| {{std::string("A"), std::string("A"), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string("A"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("A"), std::string(","), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(","), Null()}, Null()}, |
| {{std::string("A"), std::string(","), std::string(",ABC,")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string("123ABC!@# _")}, std::string("A")}, |
| {{std::string("A"), std::string(""), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string(""), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string(""), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(""), Null()}, Null()}, |
| {{std::string("A"), std::string(""), std::string(",ABC,")}, std::string("A")}, |
| {{std::string("A"), std::string(""), std::string("123ABC!@# _")}, std::string("A")}, |
| {{std::string("A"), Null(), std::string("A")}, Null()}, |
| {{std::string("A"), Null(), std::string(",")}, Null()}, |
| {{std::string("A"), Null(), std::string("")}, Null()}, |
| {{std::string("A"), Null(), Null()}, Null()}, |
| {{std::string("A"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string("A"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string("A"), std::string(",ABC,"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string("A"), std::string(",ABC,"), std::string(",ABC,")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("A")}, |
| {{std::string(","), std::string("A"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string("A"), Null()}, Null()}, |
| {{std::string(","), std::string("A"), std::string(",ABC,")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string("123ABC!@# _")}, std::string(",")}, |
| {{std::string(","), std::string(","), std::string("A")}, std::string("A")}, |
| {{std::string(","), std::string(","), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string(","), std::string("")}, std::string("")}, |
| {{std::string(","), std::string(","), Null()}, Null()}, |
| {{std::string(","), std::string(","), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string(","), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string(","), std::string(""), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string(""), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string(""), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string(""), Null()}, Null()}, |
| {{std::string(","), std::string(""), std::string(",ABC,")}, std::string(",")}, |
| {{std::string(","), std::string(""), std::string("123ABC!@# _")}, std::string(",")}, |
| {{std::string(","), Null(), std::string("A")}, Null()}, |
| {{std::string(","), Null(), std::string(",")}, Null()}, |
| {{std::string(","), Null(), std::string("")}, Null()}, |
| {{std::string(","), Null(), Null()}, Null()}, |
| {{std::string(","), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(","), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(","), std::string(",ABC,"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(","), std::string(",ABC,"), std::string(",ABC,")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string(",")}, |
| {{std::string(""), std::string("A"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string("A"), Null()}, Null()}, |
| {{std::string(""), std::string("A"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(","), Null()}, Null()}, |
| {{std::string(""), std::string(","), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string(""), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string(""), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string(""), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string(""), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string(""), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), Null(), std::string("A")}, Null()}, |
| {{std::string(""), Null(), std::string(",")}, Null()}, |
| {{std::string(""), Null(), std::string("")}, Null()}, |
| {{std::string(""), Null(), Null()}, Null()}, |
| {{std::string(""), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(""), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(""), std::string(",ABC,"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(""), std::string(",ABC,"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("")}, |
| {{Null(), std::string("A"), std::string("A")}, Null()}, |
| {{Null(), std::string("A"), std::string(",")}, Null()}, |
| {{Null(), std::string("A"), std::string("")}, Null()}, |
| {{Null(), std::string("A"), Null()}, Null()}, |
| {{Null(), std::string("A"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string("A"), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(","), std::string("A")}, Null()}, |
| {{Null(), std::string(","), std::string(",")}, Null()}, |
| {{Null(), std::string(","), std::string("")}, Null()}, |
| {{Null(), std::string(","), Null()}, Null()}, |
| {{Null(), std::string(","), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(","), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(""), std::string("A")}, Null()}, |
| {{Null(), std::string(""), std::string(",")}, Null()}, |
| {{Null(), std::string(""), std::string("")}, Null()}, |
| {{Null(), std::string(""), Null()}, Null()}, |
| {{Null(), std::string(""), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(""), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), Null(), std::string("A")}, Null()}, |
| {{Null(), Null(), std::string(",")}, Null()}, |
| {{Null(), Null(), std::string("")}, Null()}, |
| {{Null(), Null(), Null()}, Null()}, |
| {{Null(), Null(), std::string(",ABC,")}, Null()}, |
| {{Null(), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("A")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string(",")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("")}, Null()}, |
| {{Null(), std::string(",ABC,"), Null()}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("A")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string(",")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(",ABC,"), std::string("A"), std::string("A")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string(",")}, std::string(",,BC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string("")}, std::string(",BC,")}, |
| {{std::string(",ABC,"), std::string("A"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string("A"), std::string(",ABC,")}, |
| std::string(",,ABC,BC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string(",123ABC!@# _BC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("A")}, std::string("AABCA")}, |
| {{std::string(",ABC,"), std::string(","), std::string(",")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("")}, std::string("ABC")}, |
| {{std::string(",ABC,"), std::string(","), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(","), std::string(",ABC,")}, |
| std::string(",ABC,ABC,ABC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _ABC123ABC!@# _")}, |
| {{std::string(",ABC,"), std::string(""), std::string("A")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(""), std::string(",")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(""), std::string("")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(""), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(""), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(""), std::string("123ABC!@# _")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), Null(), std::string("A")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string(",")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string("")}, Null()}, |
| {{std::string(",ABC,"), Null(), Null()}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("A")}, std::string("A")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string(",")}, std::string(",")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("")}, std::string("")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("A")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string(",")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string(",ABC,")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string(",")}, |
| std::string("123,BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("")}, |
| std::string("123BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string(",ABC,")}, |
| std::string("123,ABC,BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string("123123ABC!@# _BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string(",")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string(",ABC,")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string(",")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string(",ABC,")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), Null(), std::string("A")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string(",")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string("")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string(",")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string(",ABC,")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("A")}, |
| std::string("A")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string(",")}, |
| std::string(",")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("")}, |
| std::string("")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_replace_empty) { |
| std::string func_name = "replace_empty"; |
| InputTypeSet input_types = { |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_VARCHAR, |
| }; |
| DataSet data_set = { |
| {{std::string("A"), std::string("A"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string("A"), std::string(",")}, std::string(",")}, |
| {{std::string("A"), std::string("A"), std::string("")}, std::string("")}, |
| {{std::string("A"), std::string("A"), Null()}, Null()}, |
| {{std::string("A"), std::string("A"), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string("A"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("A"), std::string(","), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(","), Null()}, Null()}, |
| {{std::string("A"), std::string(","), std::string(",ABC,")}, std::string("A")}, |
| {{std::string("A"), std::string(","), std::string("123ABC!@# _")}, std::string("A")}, |
| {{std::string("A"), std::string(""), std::string("A")}, std::string("AAA")}, |
| {{std::string("A"), std::string(""), std::string(",")}, std::string(",A,")}, |
| {{std::string("A"), std::string(""), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(""), Null()}, Null()}, |
| {{std::string("A"), std::string(""), std::string(",ABC,")}, std::string(",ABC,A,ABC,")}, |
| {{std::string("A"), std::string(""), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _A123ABC!@# _")}, |
| {{std::string("A"), Null(), std::string("A")}, Null()}, |
| {{std::string("A"), Null(), std::string(",")}, Null()}, |
| {{std::string("A"), Null(), std::string("")}, Null()}, |
| {{std::string("A"), Null(), Null()}, Null()}, |
| {{std::string("A"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string("A"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string("A"), std::string(",ABC,"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string("A"), std::string(",ABC,"), std::string(",ABC,")}, std::string("A")}, |
| {{std::string("A"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("A")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string(",")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("")}, std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string("A")}, |
| {{std::string("A"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("A")}, |
| {{std::string(","), std::string("A"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string("A"), Null()}, Null()}, |
| {{std::string(","), std::string("A"), std::string(",ABC,")}, std::string(",")}, |
| {{std::string(","), std::string("A"), std::string("123ABC!@# _")}, std::string(",")}, |
| {{std::string(","), std::string(","), std::string("A")}, std::string("A")}, |
| {{std::string(","), std::string(","), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string(","), std::string("")}, std::string("")}, |
| {{std::string(","), std::string(","), Null()}, Null()}, |
| {{std::string(","), std::string(","), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string(","), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string(","), std::string(""), std::string("A")}, std::string("A,A")}, |
| {{std::string(","), std::string(""), std::string(",")}, std::string(",,,")}, |
| {{std::string(","), std::string(""), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string(""), Null()}, Null()}, |
| {{std::string(","), std::string(""), std::string(",ABC,")}, std::string(",ABC,,,ABC,")}, |
| {{std::string(","), std::string(""), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _,123ABC!@# _")}, |
| {{std::string(","), Null(), std::string("A")}, Null()}, |
| {{std::string(","), Null(), std::string(",")}, Null()}, |
| {{std::string(","), Null(), std::string("")}, Null()}, |
| {{std::string(","), Null(), Null()}, Null()}, |
| {{std::string(","), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(","), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(","), std::string(",ABC,"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(","), std::string(",ABC,"), std::string(",ABC,")}, std::string(",")}, |
| {{std::string(","), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("A")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string(",")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("")}, std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",")}, |
| {{std::string(","), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string(",")}, |
| {{std::string(""), std::string("A"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string("A"), Null()}, Null()}, |
| {{std::string(""), std::string("A"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string("A"), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(","), Null()}, Null()}, |
| {{std::string(""), std::string(","), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string(","), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string(""), std::string("A")}, std::string("A")}, |
| {{std::string(""), std::string(""), std::string(",")}, std::string(",")}, |
| {{std::string(""), std::string(""), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(""), Null()}, Null()}, |
| {{std::string(""), std::string(""), std::string(",ABC,")}, std::string(",ABC,")}, |
| {{std::string(""), std::string(""), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string(""), Null(), std::string("A")}, Null()}, |
| {{std::string(""), Null(), std::string(",")}, Null()}, |
| {{std::string(""), Null(), std::string("")}, Null()}, |
| {{std::string(""), Null(), Null()}, Null()}, |
| {{std::string(""), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(""), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(""), std::string(",ABC,"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(""), std::string(",ABC,"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string(",ABC,"), std::string("123ABC!@# _")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("A")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string(",")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string(",ABC,")}, std::string("")}, |
| {{std::string(""), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("")}, |
| {{Null(), std::string("A"), std::string("A")}, Null()}, |
| {{Null(), std::string("A"), std::string(",")}, Null()}, |
| {{Null(), std::string("A"), std::string("")}, Null()}, |
| {{Null(), std::string("A"), Null()}, Null()}, |
| {{Null(), std::string("A"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string("A"), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(","), std::string("A")}, Null()}, |
| {{Null(), std::string(","), std::string(",")}, Null()}, |
| {{Null(), std::string(","), std::string("")}, Null()}, |
| {{Null(), std::string(","), Null()}, Null()}, |
| {{Null(), std::string(","), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(","), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(""), std::string("A")}, Null()}, |
| {{Null(), std::string(""), std::string(",")}, Null()}, |
| {{Null(), std::string(""), std::string("")}, Null()}, |
| {{Null(), std::string(""), Null()}, Null()}, |
| {{Null(), std::string(""), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(""), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), Null(), std::string("A")}, Null()}, |
| {{Null(), Null(), std::string(",")}, Null()}, |
| {{Null(), Null(), std::string("")}, Null()}, |
| {{Null(), Null(), Null()}, Null()}, |
| {{Null(), Null(), std::string(",ABC,")}, Null()}, |
| {{Null(), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("A")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string(",")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("")}, Null()}, |
| {{Null(), std::string(",ABC,"), Null()}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string(",ABC,"), std::string("123ABC!@# _")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("A")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string(",")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string(",ABC,")}, Null()}, |
| {{Null(), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(",ABC,"), std::string("A"), std::string("A")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string(",")}, std::string(",,BC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string("")}, std::string(",BC,")}, |
| {{std::string(",ABC,"), std::string("A"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string("A"), std::string(",ABC,")}, |
| std::string(",,ABC,BC,")}, |
| {{std::string(",ABC,"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string(",123ABC!@# _BC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("A")}, std::string("AABCA")}, |
| {{std::string(",ABC,"), std::string(","), std::string(",")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("")}, std::string("ABC")}, |
| {{std::string(",ABC,"), std::string(","), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(","), std::string(",ABC,")}, |
| std::string(",ABC,ABC,ABC,")}, |
| {{std::string(",ABC,"), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _ABC123ABC!@# _")}, |
| {{std::string(",ABC,"), std::string(""), std::string("A")}, std::string("A,AAABACA,A")}, |
| {{std::string(",ABC,"), std::string(""), std::string(",")}, std::string(",,,A,B,C,,,")}, |
| {{std::string(",ABC,"), std::string(""), std::string("")}, std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(""), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(""), std::string(",ABC,")}, |
| std::string(",ABC,,,ABC,A,ABC,B,ABC,C,ABC,,,ABC,")}, |
| {{std::string(",ABC,"), std::string(""), std::string("123ABC!@# _")}, |
| std::string( |
| "123ABC!@# _,123ABC!@# _A123ABC!@# _B123ABC!@# _C123ABC!@# _,123ABC!@# _")}, |
| {{std::string(",ABC,"), Null(), std::string("A")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string(",")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string("")}, Null()}, |
| {{std::string(",ABC,"), Null(), Null()}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string(",ABC,"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("A")}, std::string("A")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string(",")}, std::string(",")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("")}, std::string("")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("A")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string(",")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string(",ABC,"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string(",ABC,")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string(",")}, |
| std::string("123,BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("")}, |
| std::string("123BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string(",ABC,")}, |
| std::string("123,ABC,BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("A"), std::string("123ABC!@# _")}, |
| std::string("123123ABC!@# _BC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string(",")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string(",ABC,")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(","), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("A")}, |
| std::string("A1A2A3AAABACA!A@A#A A_A")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string(",")}, |
| std::string(",1,2,3,A,B,C,!,@,#, ,_,")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(""), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string(",ABC,")}, |
| std::string( |
| ",ABC,1,ABC,2,ABC,3,ABC,A,ABC,B,ABC,C,ABC,!,ABC,@,ABC,#,ABC, ,ABC,_,ABC,")}, |
| {{std::string("123ABC!@# _"), std::string(""), std::string("123ABC!@# _")}, |
| std::string( |
| "123ABC!@# _1123ABC!@# _2123ABC!@# _3123ABC!@# _A123ABC!@# _B123ABC!@# " |
| "_C123ABC!@# _!123ABC!@# _@123ABC!@# _#123ABC!@# _ 123ABC!@# __123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), Null(), std::string("A")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string(",")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string("")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string(",ABC,")}, Null()}, |
| {{std::string("123ABC!@# _"), Null(), std::string("123ABC!@# _")}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("A")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string(",")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string(",ABC,")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string(",ABC,"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("A")}, |
| std::string("A")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string(",")}, |
| std::string(",")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("")}, |
| std::string("")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), Null()}, Null()}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string(",ABC,")}, |
| std::string(",ABC,")}, |
| {{std::string("123ABC!@# _"), std::string("123ABC!@# _"), std::string("123ABC!@# _")}, |
| std::string("123ABC!@# _")}, |
| }; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_bit_length_test) { |
| std::string func_name = "bit_length"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9")}, std::int32_t(96)}, |
| {{std::string("aGVsbG8gd29ybGQ")}, std::int32_t(120)}, |
| {{std::string("SEVMTE8sIV4l")}, std::int32_t(96)}, |
| {{std::string("__123hehe1")}, std::int32_t(80)}, |
| {{std::string("")}, std::int32_t(0)}, |
| {{std::string("5ZWK5ZOI5ZOI5ZOI8J+YhCDjgILigJTigJQh")}, std::int32_t(288)}, |
| {{std::string("ò&ø")}, std::int32_t(40)}, |
| {{std::string("TVl0ZXN0U1RS")}, std::int32_t(96)}, |
| {{Null()}, Null()}, |
| {{std::string("123321!@#@$!@%!@#!@$!@")}, std::int32_t(176)}, |
| {{std::string("123")}, std::int32_t(24)}, |
| }; |
| static_cast<void>( |
| check_function_all_arg_comb<DataTypeInt32, true>(func_name, input_types, data_set)); |
| } |
| |
| TEST(function_string_test, function_uuid_test) { |
| { |
| std::string func_name = "uuid_to_int"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| uint64_t high = 9572195551486940809ULL; |
| uint64_t low = 1759290071393952876ULL; |
| __int128 result = (__int128)high * (__int128)10000000000000000000ULL + (__int128)low; |
| DataSet data_set = {{{Null()}, Null()}, |
| {{std::string("6ce4766f-6783-4b30-b357-bba1c7600348")}, result}, |
| {{std::string("6ce4766f67834b30b357bba1c7600348")}, result}, |
| {{std::string("ffffffff-ffff-ffff-ffff-ffffffffffff")}, (__int128)-1}, |
| {{std::string("00000000-0000-0000-0000-000000000000")}, (__int128)0}, |
| {{std::string("123")}, Null()}}; |
| check_function_all_arg_comb<DataTypeInt128, true>(func_name, input_types, data_set); |
| } |
| { |
| std::string func_name = "int_to_uuid"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_LARGEINT}; |
| uint64_t high = 9572195551486940809ULL; |
| uint64_t low = 1759290071393952876ULL; |
| __int128 value = (__int128)high * (__int128)10000000000000000000ULL + (__int128)low; |
| DataSet data_set = {{{Null()}, Null()}, |
| {{value}, std::string("6ce4766f-6783-4b30-b357-bba1c7600348")}, |
| {{(__int128)-1}, std::string("ffffffff-ffff-ffff-ffff-ffffffffffff")}, |
| {{(__int128)0}, std::string("00000000-0000-0000-0000-000000000000")}}; |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| } |
| |
| TEST(function_string_test, function_overlay_test) { |
| std::string func_name = "overlay"; |
| { |
| InputTypeSet input_types = { |
| PrimitiveType::TYPE_VARCHAR, |
| PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_VARCHAR, |
| }; |
| DataSet data_set = { |
| {{ |
| Null(), |
| INT(7), |
| INT(5), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| Null(), |
| INT(5), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| INT(7), |
| Null(), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| INT(7), |
| INT(5), |
| Null(), |
| }, |
| {Null()}}, |
| {{VARCHAR("http://www.baidu.com:9090"), INT(22), INT(4), VARCHAR("")}, |
| {VARCHAR("http://www.baidu.com:")}}, |
| {{VARCHAR("aaaaa"), INT(0), INT(50), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("aaaaa"), INT(2), INT(3), VARCHAR("bbbbb")}, {VARCHAR("abbbbba")}}, |
| {{VARCHAR("aaaaa"), INT(6), INT(2), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("aaaaa"), INT(-10), INT(2), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("こaaaa"), INT(-1), INT(2), VARCHAR("にちは")}, {VARCHAR("こaaaa")}}, |
| {{VARCHAR("こaaaa"), INT(2), INT(2), VARCHAR("にちは")}, {VARCHAR("こにちはaa")}}, |
| {{VARCHAR("你好123世界"), INT(2), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你我的23世界")}}, |
| {{VARCHAR("你好123世界"), INT(-1), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你好123世界")}}, |
| {{VARCHAR("你好123世界"), INT(10), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你好123世界")}}, |
| {{VARCHAR("你好123世界"), INT(2), INT(10), VARCHAR("我的")}, {VARCHAR("你我的")}}, |
| {{VARCHAR("aaaaa"), INT(2), INT(-1), VARCHAR("bbbbb")}, {VARCHAR("abbbbb")}}}; |
| static_cast<void>(check_function<DataTypeString, true>(func_name, input_types, data_set)); |
| } |
| { |
| InputTypeSet input_types = { |
| PrimitiveType::TYPE_VARCHAR, |
| Consted {PrimitiveType::TYPE_INT}, |
| Consted {PrimitiveType::TYPE_INT}, |
| Consted {PrimitiveType::TYPE_VARCHAR}, |
| }; |
| DataSet data_set = { |
| {{ |
| Null(), |
| INT(7), |
| INT(5), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| Null(), |
| INT(5), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| INT(7), |
| Null(), |
| VARCHAR("9090"), |
| }, |
| {Null()}}, |
| {{ |
| VARCHAR("Test"), |
| INT(7), |
| INT(5), |
| Null(), |
| }, |
| {Null()}}, |
| {{VARCHAR("http://www.baidu.com:9090"), INT(22), INT(4), VARCHAR("")}, |
| {VARCHAR("http://www.baidu.com:")}}, |
| {{VARCHAR("aaaaa"), INT(0), INT(50), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("aaaaa"), INT(2), INT(3), VARCHAR("bbbbb")}, {VARCHAR("abbbbba")}}, |
| {{VARCHAR("aaaaa"), INT(6), INT(2), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("aaaaa"), INT(-10), INT(2), VARCHAR("bbbbb")}, {VARCHAR("aaaaa")}}, |
| {{VARCHAR("こaaaa"), INT(-1), INT(2), VARCHAR("にちは")}, {VARCHAR("こaaaa")}}, |
| {{VARCHAR("こaaaa"), INT(2), INT(2), VARCHAR("にちは")}, {VARCHAR("こにちはaa")}}, |
| {{VARCHAR("你好123世界"), INT(2), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你我的23世界")}}, |
| {{VARCHAR("你好123世界"), INT(-1), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你好123世界")}}, |
| {{VARCHAR("你好123世界"), INT(10), INT(2), VARCHAR("我的")}, |
| {VARCHAR("你好123世界")}}, |
| {{VARCHAR("你好123世界"), INT(2), INT(10), VARCHAR("我的")}, {VARCHAR("你我的")}}, |
| {{VARCHAR("aaaaa"), INT(2), INT(-1), VARCHAR("bbbbb")}, {VARCHAR("abbbbb")}}}; |
| for (const auto& line : data_set) { |
| DataSet const_dataset = {line}; |
| static_cast<void>( |
| check_function<DataTypeString, true>(func_name, input_types, const_dataset)); |
| } |
| } |
| } |
| |
| TEST(function_string_test, function_initcap) { |
| std::string func_name {"initcap"}; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = {{{std::string("SKJ_ASD_SAD _1A")}, std::string("Skj_Asd_Sad _1a")}, |
| {{std::string("BC'S aaaaA'' 'S")}, std::string("Bc'S Aaaaa'' 'S")}, |
| {{std::string("NULL")}, std::string("Null")}, |
| {{Null()}, Null()}, |
| {{std::string("GROSSE àstanbul , ÀÇAC123 ΣΟΦΟΣ")}, |
| std::string("Grosse Àstanbul , Àçac123 Σοφος")}, |
| {{std::string("HELLO, WORLD!")}, std::string("Hello, World!")}, |
| {{std::string("HHHH+-1; asAAss__!")}, std::string("Hhhh+-1; Asaass__!")}, |
| {{std::string("a,B,C,D")}, std::string("A,B,C,D")}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_lpad_test) { |
| std::string func_name = "lpad"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("__123hehe1")}, |
| std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("")}, std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("ò&ø")}, std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, |
| std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, |
| Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("__123hehe1")}, |
| std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, |
| std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), Null()}, Null()}, |
| {{std::string(""), std::int32_t(1), std::string("__123hehe1")}, std::string("_")}, |
| // {{std::string(""), std::int32_t(1), std::string("")}, std::string("")}, |
| // {{std::string(""), std::int32_t(1), std::string("ò&ø")}, std::string("ò")}, |
| {{std::string(""), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, std::string("T")}, |
| {{std::string(""), std::int32_t(1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string(""), std::int32_t(-1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string(""), std::int32_t(-100), Null()}, Null()}, |
| {{std::string(""), std::int32_t(0), std::string("__123hehe1")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("__123hehe1")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("ò&ø")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("__123hehe1")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("__123hehe1")}, |
| std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("")}, std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("ò&ø")}, std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, |
| std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, |
| Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("__123hehe1")}, |
| std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, |
| std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), Null()}, Null()}, |
| {{Null(), std::int32_t(1), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(1), Null()}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(-1), Null()}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(-100), Null()}, Null()}, |
| {{Null(), std::int32_t(0), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(0), Null()}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_rpad_test) { |
| std::string func_name = "rpad"; |
| |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_INT, |
| PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("__123hehe1")}, |
| std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("")}, std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("ò&ø")}, std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, |
| std::string("Y")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, |
| Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("__123hehe1")}, |
| std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("YXNk5L2g5aW9"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, |
| std::string("")}, |
| // {{std::string("YXNk5L2g5aW9"), std::int32_t(0), Null()}, Null()}, |
| // {{std::string(""), std::int32_t(1), std::string("__123hehe1")}, std::string("_")}, |
| // {{std::string(""), std::int32_t(1), std::string("")}, std::string("")}, |
| {{std::string(""), std::int32_t(1), std::string("ò&ø")}, std::string("ò")}, |
| {{std::string(""), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, std::string("T")}, |
| {{std::string(""), std::int32_t(1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string(""), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string(""), std::int32_t(-1), Null()}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string(""), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string(""), std::int32_t(-100), Null()}, Null()}, |
| {{std::string(""), std::int32_t(0), std::string("__123hehe1")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, std::string("")}, |
| {{std::string(""), std::int32_t(0), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("__123hehe1")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("ò&ø")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, std::string("ò")}, |
| {{std::string("ò&ø"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("__123hehe1")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, std::string("")}, |
| {{std::string("ò&ø"), std::int32_t(0), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("__123hehe1")}, |
| std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("")}, std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("ò&ø")}, std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, |
| std::string("T")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(1), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-1), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, |
| Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(-100), Null()}, Null()}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("__123hehe1")}, |
| std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("")}, std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("ò&ø")}, std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, |
| std::string("")}, |
| {{std::string("TVl0ZXN0U1RS"), std::int32_t(0), Null()}, Null()}, |
| {{Null(), std::int32_t(1), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(1), Null()}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(-1), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(-1), Null()}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(-100), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(-100), Null()}, Null()}, |
| {{Null(), std::int32_t(0), std::string("__123hehe1")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("ò&ø")}, Null()}, |
| {{Null(), std::int32_t(0), std::string("TVl0ZXN0U1RS")}, Null()}, |
| {{Null(), std::int32_t(0), Null()}, Null()}, |
| }; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| TEST(function_string_test, function_xpath_string_test) { |
| std::string func_name = "xpath_string"; |
| InputTypeSet input_types = {PrimitiveType::TYPE_VARCHAR, PrimitiveType::TYPE_VARCHAR}; |
| |
| DataSet data_set = { |
| {{std::string("<a>123</a>"), std::string("/a")}, std::string("123")}, |
| {{std::string("<a><b>123</b></a>"), std::string("/a/b")}, std::string("123")}, |
| {{std::string("<a><b>123</b><c>456</c></a>"), std::string("/a/c")}, std::string("456")}, |
| {{std::string("<a><b>123</b><c>456</c></a>"), std::string("/a/d")}, std::string("")}, |
| {{std::string("<a><b>123</b><b>456</b></a>"), std::string("/a/b[1]")}, |
| std::string("123")}, |
| {{std::string("<a><b>123</b><b>456</b></a>"), std::string("/a/b[2]")}, |
| std::string("456")}, |
| {{std::string("<a><b>123</b><b>456</b></a>"), std::string("/a/b[3]")}, std::string("")}, |
| {{std::string("<a><b attr='val'>123</b></a>"), std::string("/a/b[@attr]")}, |
| std::string("123")}, |
| {{std::string("<a><b attr='val'>123</b></a>"), std::string("/a/b[@attr='val']")}, |
| std::string("123")}, |
| {{std::string("<a><b attr='val'>123</b></a>"), std::string("/a/b[@attr='wrong']")}, |
| std::string("")}, |
| {{std::string("<a><!-- comment -->123</a>"), std::string("/a")}, std::string("123")}, |
| {{std::string("<a><![CDATA[123]]></a>"), std::string("/a")}, std::string("123")}, |
| {{std::string("<a>123<b>456</b>789</a>"), std::string("/a")}, std::string("123456789")}, |
| {{std::string("<a> 123 </a>"), std::string("/a")}, std::string(" 123 ")}, |
| {{std::string("<a></a>"), std::string("/a")}, std::string("")}, |
| {{std::string("<a/>"), std::string("/a")}, std::string("")}, |
| {{std::string("<a>123</a>"), std::string("")}, Null()}, |
| {{std::string(""), std::string("/a")}, Null()}, |
| {{Null(), std::string("/a")}, Null()}, |
| {{std::string("<a>123</a>"), Null()}, Null()}, |
| {{std::string("<book><title>Intro to Hive</title><author>John " |
| "Doe</author><publisher>Tech Press</publisher></book>"), |
| std::string("//title/text()")}, |
| std::string("Intro to Hive")}, |
| {{std::string("<book><title>Intro to Hive</title><author>John " |
| "Doe</author><publisher>Tech Press</publisher></book>"), |
| std::string("//author/text()")}, |
| std::string("John Doe")}, |
| {{std::string("<book><title>Intro to Hive</title><author>John " |
| "Doe</author><publisher>Tech Press</publisher></book>"), |
| std::string("//publisher/text()")}, |
| std::string("Tech Press")}, |
| {{std::string("<book><title>Intro to Hive</title><author>John " |
| "Doe</author><publisher>Tech Press</publisher></book>"), |
| std::string("/book")}, |
| std::string("Intro to HiveJohn DoeTech Press")}, |
| {{Null(), Null()}, Null()}}; |
| |
| check_function_all_arg_comb<DataTypeString, true>(func_name, input_types, data_set); |
| } |
| |
| } // namespace doris::vectorized |