96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package token_test
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"git.huangwc.com/pig/pig-farm-controller/internal/app/service/token"
 | 
						|
	"github.com/golang-jwt/jwt/v5"
 | 
						|
)
 | 
						|
 | 
						|
func TestGenerateToken(t *testing.T) {
 | 
						|
	// 使用一个测试密钥初始化 TokenService
 | 
						|
	testSecret := []byte("test_secret_key")
 | 
						|
	service := token.NewTokenService(testSecret)
 | 
						|
 | 
						|
	userID := uint(123)
 | 
						|
	tokenString, err := service.GenerateToken(userID)
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("生成令牌失败: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	if tokenString == "" {
 | 
						|
		t.Fatal("生成的令牌字符串为空")
 | 
						|
	}
 | 
						|
 | 
						|
	// 解析 token 以确保其有效性及声明
 | 
						|
	claims, err := service.ParseToken(tokenString)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("生成后解析令牌失败: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	if claims.UserID != userID {
 | 
						|
		t.Errorf("期望用户ID %d, 实际为 %d", userID, claims.UserID)
 | 
						|
	}
 | 
						|
 | 
						|
	// 检查 token 是否未过期 (在合理范围内)
 | 
						|
	if claims.ExpiresAt == nil || claims.ExpiresAt.Time.Before(time.Now().Add(-time.Minute)) {
 | 
						|
		t.Errorf("令牌过期时间无效或已过期")
 | 
						|
	}
 | 
						|
 | 
						|
	if claims.Issuer != "pig-farm-controller" {
 | 
						|
		t.Errorf("期望签发者 \"pig-farm-controller\", 实际为 \"%s\"", claims.Issuer)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestParseToken(t *testing.T) {
 | 
						|
	// 使用一个测试密钥初始化 TokenService
 | 
						|
	testSecret := []byte("test_secret_key")
 | 
						|
	service := token.NewTokenService(testSecret)
 | 
						|
 | 
						|
	userID := uint(456)
 | 
						|
 | 
						|
	// 生成一个有效的 token 用于解析测试
 | 
						|
	validToken, err := service.GenerateToken(userID)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("为解析测试生成有效令牌失败: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	// 测试用例 1: 有效 token
 | 
						|
	claims, err := service.ParseToken(validToken)
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("解析有效令牌失败: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	if claims.UserID != userID {
 | 
						|
		t.Errorf("解析有效令牌时期望用户ID %d, 实际为 %d", userID, claims.UserID)
 | 
						|
	}
 | 
						|
 | 
						|
	// 测试用例 2: 无效 token (例如, 错误的签名)
 | 
						|
	invalidToken := "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxMjMsImV4cCI6MTY3ODkwNTYwMCwiaXNzIjoicGlnLWZhcm0tY29udHJvbGxlciJ9.invalid_signature_here"
 | 
						|
	_, err = service.ParseToken(invalidToken)
 | 
						|
	if err == nil {
 | 
						|
		t.Error("解析无效令牌意外成功")
 | 
						|
	}
 | 
						|
 | 
						|
	// 测试用例 3: 过期 token (创建一个过期时间在过去的 token)
 | 
						|
	expiredClaims := token.Claims{
 | 
						|
		UserID: userID,
 | 
						|
		RegisteredClaims: jwt.RegisteredClaims{
 | 
						|
			ExpiresAt: jwt.NewNumericDate(time.Now().Add(-time.Hour)), // 1 小时前
 | 
						|
			Issuer:    "pig-farm-controller",
 | 
						|
		},
 | 
						|
	}
 | 
						|
	expiredTokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, expiredClaims)
 | 
						|
	expiredTokenString, err := expiredTokenClaims.SignedString(testSecret)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("生成过期令牌失败: %v", err)
 | 
						|
	}
 | 
						|
 | 
						|
	_, err = service.ParseToken(expiredTokenString)
 | 
						|
	if err == nil {
 | 
						|
		t.Error("解析过期令牌意外成功")
 | 
						|
	}
 | 
						|
}
 |