mirror of
				https://github.com/hibiken/asynq.git
				synced 2025-10-26 11:16:12 +08:00 
			
		
		
		
	Add example tests
This commit is contained in:
		
							
								
								
									
										78
									
								
								example_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								example_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| // Copyright 2020 Kentaro Hibino. All rights reserved. | ||||
| // Use of this source code is governed by a MIT license | ||||
| // that can be found in the LICENSE file. | ||||
|  | ||||
| package asynq_test | ||||
|  | ||||
| import ( | ||||
| 	"log" | ||||
| 	"os" | ||||
| 	"os/signal" | ||||
|  | ||||
| 	"github.com/hibiken/asynq" | ||||
| 	"golang.org/x/sys/unix" | ||||
| ) | ||||
|  | ||||
| func ExampleServer_Run() { | ||||
| 	srv := asynq.NewServer( | ||||
| 		asynq.RedisClientOpt{Addr: ":6379"}, | ||||
| 		asynq.Config{Concurrency: 20}, | ||||
| 	) | ||||
|  | ||||
| 	h := asynq.NewServeMux() | ||||
| 	// ... Register handlers | ||||
|  | ||||
| 	// Run blocks and waits for os signal to terminate the program. | ||||
| 	if err := srv.Run(h); err != nil { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func ExampleServer_Stop() { | ||||
| 	srv := asynq.NewServer( | ||||
| 		asynq.RedisClientOpt{Addr: ":6379"}, | ||||
| 		asynq.Config{Concurrency: 20}, | ||||
| 	) | ||||
|  | ||||
| 	h := asynq.NewServeMux() | ||||
| 	// ... Register handlers | ||||
|  | ||||
| 	if err := srv.Start(h); err != nil { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	sigs := make(chan os.Signal, 1) | ||||
| 	signal.Notify(sigs, unix.SIGTERM, unix.SIGINT) | ||||
| 	<-sigs // wait for termination signal | ||||
|  | ||||
| 	srv.Stop() | ||||
| } | ||||
|  | ||||
| func ExampleServer_Quiet() { | ||||
| 	srv := asynq.NewServer( | ||||
| 		asynq.RedisClientOpt{Addr: ":6379"}, | ||||
| 		asynq.Config{Concurrency: 20}, | ||||
| 	) | ||||
|  | ||||
| 	h := asynq.NewServeMux() | ||||
| 	// ... Register handlers | ||||
|  | ||||
| 	if err := srv.Start(h); err != nil { | ||||
| 		log.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	sigs := make(chan os.Signal, 1) | ||||
| 	signal.Notify(sigs, unix.SIGTERM, unix.SIGINT, unix.SIGTSTP) | ||||
| 	// Handle SIGTERM, SIGINT to exit the program. | ||||
| 	// Handle SIGTSTP to stop processing new tasks. | ||||
| 	for { | ||||
| 		s := <-sigs | ||||
| 		if s == unix.SIGTSTP { | ||||
| 			srv.Quiet() // stop processing new tasks | ||||
| 			continue | ||||
| 		} | ||||
| 		break | ||||
| 	} | ||||
|  | ||||
| 	srv.Stop() | ||||
| } | ||||
		Reference in New Issue
	
	Block a user