| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  | // Copyright 2011 Xing Xing <mikespook@gmail.com> All rights reserved.
 | 
					
						
							|  |  |  | // Use of this source code is governed by a MIT
 | 
					
						
							|  |  |  | // license that can be found in the LICENSE file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | This module is Gearman API for golang.  | 
					
						
							|  |  |  | The protocol was implemented by native way. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package gearman | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  |     "time" | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |     "sync" | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |     "testing" | 
					
						
							|  |  |  |     "strings" | 
					
						
							|  |  |  |     "github.com/mikespook/gearman-go/client" | 
					
						
							|  |  |  |     "github.com/mikespook/gearman-go/worker" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const( | 
					
						
							|  |  |  |     STR = "The gearman-go is a pure go implemented library." | 
					
						
							|  |  |  |     GEARMAND = "127.0.0.1:4730" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func ToUpper(job *worker.Job) ([]byte, error) { | 
					
						
							|  |  |  |     data := []byte(strings.ToUpper(string(job.Data))) | 
					
						
							|  |  |  |     return data, nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func Sleep(job *worker.Job) ([]byte, error) { | 
					
						
							| 
									
										
										
										
											2013-04-11 20:16:41 +08:00
										 |  |  |     time.Sleep(time.Second * 5) | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |     return nil, nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestJobs(t *testing.T) { | 
					
						
							|  |  |  |     w := worker.New(worker.Unlimited) | 
					
						
							|  |  |  |     if err := w.AddServer(GEARMAND); err != nil { | 
					
						
							|  |  |  |         t.Error(err) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     defer w.Close() | 
					
						
							|  |  |  |     if err := w.AddFunc("ToUpper", ToUpper, 0); err != nil { | 
					
						
							|  |  |  |         t.Error(err) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if err := w.AddFunc("Sleep", Sleep, 0); err != nil { | 
					
						
							|  |  |  |         t.Error(err) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     w.ErrHandler = func(e error) { | 
					
						
							|  |  |  |          t.Error(e) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |     go w.Work() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     c, err := client.New(GEARMAND) | 
					
						
							|  |  |  |     if err != nil { | 
					
						
							|  |  |  |         t.Error(err) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     defer c.Close() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     c.ErrHandler = func(e error) { | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |         t.Error(e) | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |         var w sync.WaitGroup | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |         jobHandler := func(job *client.Job) { | 
					
						
							|  |  |  |             upper := strings.ToUpper(STR) | 
					
						
							|  |  |  |             if (string(job.Data) != upper) { | 
					
						
							|  |  |  |                 t.Error("%s expected, got %s", []byte(upper), job.Data) | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |             w.Done() | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |         w.Add(1) | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |         handle := c.Do("ToUpper", []byte(STR), client.JOB_NORMAL, jobHandler) | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |         w.Wait() | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |         status, err := c.Status(handle, time.Second) | 
					
						
							|  |  |  |         if err != nil { | 
					
						
							|  |  |  |             t.Error(err) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  |         if status.Known { | 
					
						
							|  |  |  |             t.Errorf("%s shouldn't be known", status.Handle) | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-04-23 17:52:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if status.Running { | 
					
						
							|  |  |  |             t.Errorf("%s shouldn't be running", status.Handle) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         handle := c.DoBg("Sleep", nil, client.JOB_NORMAL) | 
					
						
							| 
									
										
										
										
											2013-04-11 20:16:41 +08:00
										 |  |  |         time.Sleep(time.Second) | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |         status, err := c.Status(handle, time.Second) | 
					
						
							|  |  |  |         if err != nil { | 
					
						
							|  |  |  |             t.Error(err) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if !status.Known { | 
					
						
							|  |  |  |             t.Errorf("%s should be known", status.Handle) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if !status.Running { | 
					
						
							| 
									
										
										
										
											2013-04-23 16:58:06 +08:00
										 |  |  |             t.Errorf("%s should be running", status.Handle) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         status, err := c.Status("not exists handle", time.Second) | 
					
						
							|  |  |  |         if err != nil { | 
					
						
							|  |  |  |             t.Error(err) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if status.Known { | 
					
						
							|  |  |  |             t.Errorf("%s shouldn't be known", status.Handle) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if status.Running { | 
					
						
							|  |  |  |             t.Errorf("%s shouldn't be running", status.Handle) | 
					
						
							| 
									
										
										
										
											2013-04-11 13:28:00 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |