mirror of
				https://github.com/hibiken/asynq.git
				synced 2025-10-26 11:16:12 +08:00 
			
		
		
		
	Add Deadline option when enqueuing tasks
Deadline option sets the deadline for the given task's context deadline.
This commit is contained in:
		| @@ -17,6 +17,7 @@ import ( | ||||
| 	h "github.com/hibiken/asynq/internal/asynqtest" | ||||
| 	"github.com/hibiken/asynq/internal/base" | ||||
| 	"github.com/hibiken/asynq/internal/rdb" | ||||
| 	"github.com/rs/xid" | ||||
| ) | ||||
|  | ||||
| func TestProcessorSuccess(t *testing.T) { | ||||
| @@ -363,3 +364,85 @@ func TestPerform(t *testing.T) { | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCreateContextWithTimeRestrictions(t *testing.T) { | ||||
| 	var ( | ||||
| 		noTimeout  = time.Duration(0) | ||||
| 		noDeadline = time.Time{} | ||||
| 	) | ||||
|  | ||||
| 	tests := []struct { | ||||
| 		desc         string | ||||
| 		timeout      time.Duration | ||||
| 		deadline     time.Time | ||||
| 		wantDeadline time.Time | ||||
| 	}{ | ||||
| 		{"only with timeout", 10 * time.Second, noDeadline, time.Now().Add(10 * time.Second)}, | ||||
| 		{"only with deadline", noTimeout, time.Now().Add(time.Hour), time.Now().Add(time.Hour)}, | ||||
| 		{"with timeout and deadline (timeout < deadline)", 10 * time.Second, time.Now().Add(time.Hour), time.Now().Add(10 * time.Second)}, | ||||
| 		{"with timeout and deadline (timeout > deadline)", 10 * time.Minute, time.Now().Add(30 * time.Second), time.Now().Add(30 * time.Second)}, | ||||
| 	} | ||||
|  | ||||
| 	for _, tc := range tests { | ||||
| 		msg := &base.TaskMessage{ | ||||
| 			Type:     "something", | ||||
| 			ID:       xid.New(), | ||||
| 			Timeout:  tc.timeout.String(), | ||||
| 			Deadline: tc.deadline.Format(time.RFC3339), | ||||
| 		} | ||||
|  | ||||
| 		ctx, cancel := createContext(msg) | ||||
|  | ||||
| 		select { | ||||
| 		case x := <-ctx.Done(): | ||||
| 			t.Errorf("%s: <-ctx.Done() == %v, want nothing (it should block)", tc.desc, x) | ||||
| 		default: | ||||
| 		} | ||||
|  | ||||
| 		got, ok := ctx.Deadline() | ||||
| 		if !ok { | ||||
| 			t.Errorf("%s: ctx.Deadline() returned false, want deadline to be set", tc.desc) | ||||
| 		} | ||||
| 		if !cmp.Equal(tc.wantDeadline, got, cmpopts.EquateApproxTime(time.Second)) { | ||||
| 			t.Errorf("%s: ctx.Deadline() returned %v, want %v", tc.desc, got, tc.wantDeadline) | ||||
| 		} | ||||
|  | ||||
| 		cancel() | ||||
|  | ||||
| 		select { | ||||
| 		case <-ctx.Done(): | ||||
| 		default: | ||||
| 			t.Errorf("ctx.Done() blocked, want it to be non-blocking") | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCreateContextWithoutTimeRestrictions(t *testing.T) { | ||||
| 	msg := &base.TaskMessage{ | ||||
| 		Type:     "something", | ||||
| 		ID:       xid.New(), | ||||
| 		Timeout:  time.Duration(0).String(),        // zero value to indicate no timeout | ||||
| 		Deadline: time.Time{}.Format(time.RFC3339), // zero value to indicate no deadline | ||||
| 	} | ||||
|  | ||||
| 	ctx, cancel := createContext(msg) | ||||
|  | ||||
| 	select { | ||||
| 	case x := <-ctx.Done(): | ||||
| 		t.Errorf("<-ctx.Done() == %v, want nothing (it should block)", x) | ||||
| 	default: | ||||
| 	} | ||||
|  | ||||
| 	_, ok := ctx.Deadline() | ||||
| 	if ok { | ||||
| 		t.Error("ctx.Deadline() returned true, want deadline to not be set") | ||||
| 	} | ||||
|  | ||||
| 	cancel() | ||||
|  | ||||
| 	select { | ||||
| 	case <-ctx.Done(): | ||||
| 	default: | ||||
| 		t.Error("ctx.Done() blocked, want it to be non-blocking") | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user