Skip to content

Commit

Permalink
Add ipprefix to the fuzzer
Browse files Browse the repository at this point in the history
  • Loading branch information
mohsaka committed Dec 9, 2024
1 parent 7672dd5 commit f4562af
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 1 deletion.
5 changes: 4 additions & 1 deletion velox/expression/FunctionSignature.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@
#include "velox/expression/FunctionSignature.h"
#include "velox/type/Type.h"

constexpr folly::StringPiece ipPrefixTypeName{"IPPREFIX"};

namespace facebook::velox::exec {

std::string sanitizeName(const std::string& name) {
Expand Down Expand Up @@ -120,7 +122,8 @@ void validateBaseTypeAndCollectTypeParams(

if (!isPositiveInteger(typeName) &&
!tryMapNameToTypeKind(typeName).has_value() &&
!isDecimalName(typeName) && !isDateName(typeName)) {
!isDecimalName(typeName) && !isDateName(typeName) &&
!(ipPrefixTypeName == typeName)) {
VELOX_USER_CHECK(hasType(typeName), "Type doesn't exist: '{}'", typeName);
}

Expand Down
11 changes: 11 additions & 0 deletions velox/expression/fuzzer/ExpressionFuzzer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,12 @@ void addCastFromDateSignature(
signatures.push_back(makeCastSignature("date", toType));
}

void addCastFromIPPrefixSignature(
const std::string& toType,
std::vector<facebook::velox::exec::FunctionSignaturePtr>& signatures) {
signatures.push_back(makeCastSignature("ipprefix", toType));
}

std::vector<facebook::velox::exec::FunctionSignaturePtr>
getSignaturesForCast() {
std::vector<facebook::velox::exec::FunctionSignaturePtr> signatures;
Expand All @@ -149,6 +155,7 @@ getSignaturesForCast() {
addCastFromVarcharSignature("varchar", signatures);
addCastFromDateSignature("varchar", signatures);
addCastFromTimestampSignature("varchar", signatures);
addCastFromIPPrefixSignature("varchar", signatures);

// To timestamp type.
addCastFromVarcharSignature("timestamp", signatures);
Expand All @@ -158,6 +165,9 @@ getSignaturesForCast() {
addCastFromVarcharSignature("date", signatures);
addCastFromTimestampSignature("date", signatures);

// To ipprefix type.
addCastFromVarcharSignature("ipprefix", signatures);

// For each supported translation pair T --> U, add signatures of array(T) -->
// array(U), map(varchar, T) --> map(varchar, U), row(T) --> row(U).
auto size = signatures.size();
Expand Down Expand Up @@ -664,6 +674,7 @@ bool ExpressionFuzzer::isSupportedSignature(
if (usesTypeName(signature, "opaque") ||
usesTypeName(signature, "timestamp with time zone") ||
usesTypeName(signature, "interval day to second") ||
usesTypeName(signature, "ipprefix") ||
(!options_.enableDecimalType && usesTypeName(signature, "decimal")) ||
(!options_.enableComplexTypes && useComplexType) ||
(options_.enableComplexTypes && usesTypeName(signature, "unknown"))) {
Expand Down
2 changes: 2 additions & 0 deletions velox/expression/fuzzer/SparkExpressionFuzzerTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,8 @@ int main(int argc, char** argv) {
// timestamp_millis(bigint) can generate timestamps out of the supported
// range that make other functions throw VeloxRuntimeErrors.
"timestamp_millis(bigint) -> timestamp",
"cast(ipprefix) -> varchar",
"cast(varchar) -> ipprefix",
};

// Required by spark_partition_id function.
Expand Down

0 comments on commit f4562af

Please sign in to comment.