github.com/kaydxh/golang@v0.0.131/pkg/pool/task/worker_test.go (about) 1 /* 2 *Copyright (c) 2022, kaydxh 3 * 4 *Permission is hereby granted, free of charge, to any person obtaining a copy 5 *of this software and associated documentation files (the "Software"), to deal 6 *in the Software without restriction, including without limitation the rights 7 *to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8 *copies of the Software, and to permit persons to whom the Software is 9 *furnished to do so, subject to the following conditions: 10 * 11 *The above copyright notice and this permission notice shall be included in all 12 *copies or substantial portions of the Software. 13 * 14 *THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 *IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 *FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17 *AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18 *LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19 *OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 20 *SOFTWARE. 21 */ 22 package task_test 23 24 import ( 25 "context" 26 "fmt" 27 "testing" 28 "time" 29 30 pool_ "github.com/kaydxh/golang/pkg/pool/task" 31 ) 32 33 func TestWork(t *testing.T) { 34 p := pool_.Worker{ 35 Burst: 10, 36 } 37 38 workChan := make(chan interface{}) 39 ctx := context.Background() 40 workDoneChan := p.Work(ctx, workChan, func(work interface{}) error { 41 fmt.Printf("process task[%v]\n", work) 42 time.Sleep(5 * time.Second) 43 //return nil 44 return fmt.Errorf("error") 45 }, false) 46 _ = workDoneChan 47 48 works := []int{1, 2, 3} 49 for _, w := range works { 50 // 这里select workDoneChan和ctx.Done可能无法感知,因为work func执 51 // 行比较耗时,而for循环在burst足够多的情况下,立马就执行结束了 52 select { 53 case workChan <- w: 54 // 这里和woker func函数执行顺序是不确定的,workChan <- w返回, 55 // 代表work func已经接收数据,开始执行woker处理协程 56 t.Logf("start to do work %v", w) 57 58 case <-workDoneChan: 59 t.Logf("workdone channel is closed, work goroutine is exit") 60 return 61 62 case <-ctx.Done(): 63 //canceled, get Error messgae 64 t.Errorf("err: %v\n", p.Error()) 65 return 66 67 } 68 69 // stop后,将会在workDoneChan读取到任务协助退出 70 //p.Stop() 71 } 72 73 // if need wait finish 74 p.Wait() 75 t.Logf("wait finish, err: %v", p.Error()) 76 }