雖然我知道在 Go 中恐慌可能不是慣用的,但我想測試以確保函數(shù)在某些條件下而不是在其他條件下發(fā)生恐慌。函數(shù)的一個例子。func PanicOnErr(potentialErr error) { if potentialErr != nil { panic(potentialErr) }}以下是檢查函數(shù)是否會 panic 的實(shí)現(xiàn)。func InvocationCausedPanic(f interface{}, params ...interface{}) bool { // Obtain the function's signature. reflectedFunc := reflect.ValueOf(f) funcType := reflect.TypeOf(f) if funcType.NumIn() != len(params) { panic("InvocationCausedPanic called with a function and an incorrect number of parameter(s).") } reflectedParams := make([]reflect.Value, len(params)) for paramIndex, paramValue := range params { expectedType := funcType.In(paramIndex) actualType := reflect.TypeOf(paramValue) if actualType != expectedType { errStr := fmt.Sprintf("InvocationCausedPanic called with a mismatched parameter type [parameter #%v: expected %v; got %v].", paramIndex, expectedType, actualType) panic(errStr) } reflectedParams[paramIndex] = reflect.ValueOf(paramValue) } return invoke(reflectedFunc, reflectedParams)}func invoke(reflectedFunc reflect.Value, reflectedParams []reflect.Value) (panicked bool) { defer func() { if r := recover(); r != nil { panicked = true } }() reflectedFunc.Call(reflectedParams) return}調(diào)用以下任一方法都會導(dǎo)致類型檢查失敗。InvocationCausedPanic(PanicOnErr, errors.New("Some error."))InvocationCausedPanic(PanicOnErr, nil)但是,似乎可以PanicOnErr使用兩者進(jìn)行調(diào)用,nil并且可以通過調(diào)用生成某些內(nèi)容errors.New(似乎是 類型*errors.errorString)。因此,有沒有辦法檢查某個參數(shù)的類型是否適合調(diào)用某個函數(shù)?雖然我知道可以使用 defer 和 recovery 來更簡單地測試函數(shù),但我很好奇是否可以編寫一個通用函數(shù)來接受任何函數(shù)和參數(shù)并確定它是否導(dǎo)致了恐慌(假設(shè)功能完成)。
1 回答

胡子哥哥
TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超6個贊
使用此函數(shù)確定參數(shù)是否兼容:
func compatible(actual, expected reflect.Type) bool {
if actual == nil {
k := expected.Kind()
return k == reflect.Chan ||
k == reflect.Func ||
k == reflect.Interface ||
k == reflect.Map ||
k == reflect.Ptr ||
k == reflect.Slice
}
return actual.AssignableTo(expected)
}
- 1 回答
- 0 關(guān)注
- 181 瀏覽
添加回答
舉報
0/150
提交
取消