package test import ( "ai_scheduler/internal/entitys" "ai_scheduler/internal/pkg/mapstructure" "encoding/json" "fmt" "testing" "time" "gitea.cdlsxd.cn/self-tools/l_request" ) func Test_task(t *testing.T) { var c entitys.TaskConfig config := `{"param": {"type": "object", "required": ["number"], "properties": {"number": {"type": "string", "description": "订单编号/流水号"}}}, "request": {"url": "http://www.baidu.com/${number}", "headers": {"Authorization": "${authorization}"}, "method": "GET"}}` err := json.Unmarshal([]byte(config), &c) t.Log(err) } type configData struct { Param map[string]interface{} `json:"param"` Do map[string]interface{} `json:"do"` } func Test_task2(t *testing.T) { var ( c l_request.Request config configData ) configJson := `{"tool": "zltxOrderDetail", "param": {"type": "object", "optional": [], "required": ["order_number"], "properties": {"order_number": {"type": "string", "description": "订单编号/流水号"}}}}` err := json.Unmarshal([]byte(configJson), &config) if err != nil { panic(err) } mapstructure.Decode(config.Do, &c) t.Log(err) } func producer(ch chan<- int) { for i := 0; i < 100; i++ { ch <- i // 发送数据到通道 fmt.Printf("Sent: %d\n", i) time.Sleep(500 * time.Millisecond) // 模拟生产延迟 } close(ch) // 关闭通道,通知接收方数据发送完毕 } func consumer(ch <-chan int) { for v := range ch { // 阻塞等待数据,有数据立即处理 fmt.Printf("Received: %d\n", v) } } func Test_a(t *testing.T) { ch := make(chan int, 3) // 有缓冲通道(可选) go producer(ch) consumer(ch) // 主线程阻塞,直到通道关闭 }