2024-02-04 16:27:28 +08:00
|
|
|
package test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"kis-flow/common"
|
|
|
|
"kis-flow/file"
|
|
|
|
"kis-flow/kis"
|
|
|
|
"kis-flow/test/caas"
|
|
|
|
"kis-flow/test/faas"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestForkFlow(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
// 0. 注册Function 回调业务
|
|
|
|
kis.Pool().FaaS("funcName1", faas.FuncDemo1Handler)
|
|
|
|
kis.Pool().FaaS("funcName2", faas.FuncDemo2Handler)
|
|
|
|
kis.Pool().FaaS("funcName3", faas.FuncDemo3Handler)
|
|
|
|
|
|
|
|
// 0. 注册ConnectorInit 和 Connector 回调业务
|
|
|
|
kis.Pool().CaaSInit("ConnName1", caas.InitConnDemo1)
|
|
|
|
kis.Pool().CaaS("ConnName1", "funcName2", common.S, caas.CaasDemoHanler1)
|
|
|
|
|
|
|
|
// 1. 加载配置文件并构建Flow
|
2024-03-20 10:20:12 +08:00
|
|
|
if err := file.ConfigImportYaml("/Users/aceld/gopath/src/kis-flow/test/load_conf/"); err != nil {
|
2024-02-04 16:27:28 +08:00
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// 2. 获取Flow
|
|
|
|
flow1 := kis.Pool().GetFlow("flowName1")
|
|
|
|
|
|
|
|
flow1Clone1 := flow1.Fork(ctx)
|
|
|
|
|
|
|
|
// 3. 提交原始数据
|
|
|
|
_ = flow1Clone1.CommitRow("This is Data1 from Test")
|
|
|
|
_ = flow1Clone1.CommitRow("This is Data2 from Test")
|
|
|
|
_ = flow1Clone1.CommitRow("This is Data3 from Test")
|
|
|
|
|
|
|
|
// 4. 执行flow1
|
|
|
|
if err := flow1Clone1.Run(ctx); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|