|
| 1 | +package org.partiql.lang.eval.builtins |
| 2 | + |
| 3 | +import com.amazon.ion.Timestamp |
| 4 | +import org.partiql.lang.ION |
| 5 | +import org.partiql.lang.eval.Bindings |
| 6 | +import org.partiql.lang.eval.EvaluationSession |
| 7 | +import org.partiql.lang.eval.ExprValue |
| 8 | +import org.partiql.lang.eval.ExprValueFactory |
| 9 | +import org.partiql.lang.util.newFromIonText |
| 10 | + |
| 11 | +/** |
| 12 | + * Internal function used by ExprFunctionTest to test invalid argument type. |
| 13 | + */ |
| 14 | +internal val invalidArgTypeChecker = InvalidArgTypeChecker() |
| 15 | +internal fun checkInvalidArgType(funcName: String, syntaxSuffix: String = "(", args: List<Argument>) = |
| 16 | + invalidArgTypeChecker.checkInvalidArgType(funcName, syntaxSuffix, args) |
| 17 | + |
| 18 | +/** |
| 19 | + * Internal function used by ExprFunctionTest to test invalid arity. |
| 20 | + */ |
| 21 | +internal val invalidArityChecker = InvalidArityChecker() |
| 22 | +internal fun checkInvalidArity(funcName: String, minArity: Int, maxArity: Int) = |
| 23 | + invalidArityChecker.checkInvalidArity(funcName, minArity, maxArity) |
| 24 | + |
| 25 | +private val valueFactory = ExprValueFactory.standard(ION) |
| 26 | + |
| 27 | +private fun String.toExprValue(): ExprValue = valueFactory.newFromIonText(this) |
| 28 | + |
| 29 | +private fun Map<String, String>.toBindings(): Bindings<ExprValue> = Bindings.ofMap(mapValues { it.value.toExprValue() }) |
| 30 | + |
| 31 | +/** |
| 32 | + * Internal function used by ExprFunctionTest to build EvaluationSession. |
| 33 | + */ |
| 34 | +internal fun Map< String, String>.toSession() = EvaluationSession.build { globals( [email protected]()) } |
| 35 | + |
| 36 | +/** |
| 37 | + * Internal function used by ExprFunctionTest to build EvaluationSession with now. |
| 38 | + */ |
| 39 | +internal fun buildSessionWithNow(numMillis: Long, localOffset: Int) = |
| 40 | + EvaluationSession.build { now(Timestamp.forMillis(numMillis, localOffset)) } |
| 41 | + |
| 42 | +/** |
| 43 | + * Used by ExprFunctionTest to represent a test case. |
| 44 | + */ |
| 45 | +data class ExprFunctionTestCase( |
| 46 | + val source: String, |
| 47 | + val expected: String, |
| 48 | + val session: EvaluationSession = EvaluationSession.standard() |
| 49 | +) |
0 commit comments