aboutsummaryrefslogtreecommitdiff
path: root/internal/authz/model_test.go
blob: 990a92226eb579ca75b8a8524546047cc8df14f5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package authz

import (
	"encoding/hex"
	"os"
	"testing"

	"golang.org/x/crypto/bcrypt"
)

func TestGenerateNewToken(t *testing.T) {
	token, hash, err := GenerateNewToken()
	if err != nil {
		t.Fatalf("GenerateNewToken failed: %v", err)
	}

	// Verify token length (32 bytes = 64 hex chars)
	if len(token) != TokenSize*2 {
		t.Errorf("Expected token length %d, got %d", TokenSize*2, len(token))
	}

	// Verify hash is valid bcrypt
	if len(hash) < 60 {
		t.Errorf("Hash length too short for bcrypt: %d", len(hash))
	}

	// Decode token back to bytes and verify hash matches
	tokenBytes, err := hex.DecodeString(token)
	if err != nil {
		t.Fatalf("Failed to decode token hex: %v", err)
	}

	err = bcrypt.CompareHashAndPassword([]byte(hash), tokenBytes)
	if err != nil {
		t.Errorf("Hash does not match token: %v", err)
	}
}

func TestTokenMap(t *testing.T) {
	// Create a temporary CSV file for testing
	tmpfile, err := os.CreateTemp("", "tokens*.csv")
	if err != nil {
		t.Fatalf("Failed to create temp file: %v", err)
	}
	defer os.Remove(tmpfile.Name())

	// Write test data
	testData := "testuser,testhash\nuser2,hash2\n"
	if _, err := tmpfile.Write([]byte(testData)); err != nil {
		t.Fatalf("Failed to write test data: %v", err)
	}
	tmpfile.Close()

	// Test loading tokens
	tm := NewTokenMap()
	err = tm.LoadTokensFromFile(tmpfile.Name())
	if err != nil {
		t.Fatalf("LoadTokensFromFile failed: %v", err)
	}

	// Verify loaded data
	if hash, ok := tm["testuser"]; !ok || hash != "testhash" {
		t.Errorf("Expected hash 'testhash' for testuser, got %v", hash)
	}
	if hash, ok := tm["user2"]; !ok || hash != "hash2" {
		t.Errorf("Expected hash 'hash2' for user2, got %v", hash)
	}

	// Test loading non-existent file
	err = tm.LoadTokensFromFile("nonexistent.csv")
	if err == nil {
		t.Error("Expected error when loading non-existent file")
	}
}