aboutsummaryrefslogtreecommitdiff
path: root/internal/format/packfile/ofs_test.go
blob: 736f1ac902a8b8db2595eeafa8389b3f899c2fac (about) (plain) (blame)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package packfile_test

import (
	"bytes"
	"errors"
	"math"
	"testing"

	"lindenii.org/go/furgit/internal/format/packfile"
)

func TestParseOfsDeltaDistance(t *testing.T) {
	t.Parallel()

	cases := []struct {
		name     string
		data     []byte
		dist     uint64
		consumed int
	}{
		{name: "zero", data: []byte{0x00}, dist: 0, consumed: 1},
		{name: "one byte max", data: []byte{0x7f}, dist: 127, consumed: 1},
		{name: "two byte min", data: []byte{0x80, 0x00}, dist: 128, consumed: 2},
		{name: "two byte max", data: []byte{0xff, 0x7f}, dist: 16511, consumed: 2},
		{name: "trailing bytes ignored", data: []byte{0x7f, 0xde, 0xad}, dist: 127, consumed: 1},
	}

	for _, tc := range cases {
		t.Run(tc.name, func(t *testing.T) {
			t.Parallel()

			dist, consumed, err := packfile.ParseOfsDeltaDistance(tc.data)
			if err != nil {
				t.Fatalf("ParseOfsDeltaDistance: %v", err)
			}

			if dist != tc.dist {
				t.Fatalf("ParseOfsDeltaDistance = %d, want %d", dist, tc.dist)
			}

			if consumed != tc.consumed {
				t.Fatalf("ParseOfsDeltaDistance consumed = %d, want %d", consumed, tc.consumed)
			}
		})
	}
}

func TestParseOfsDeltaDistanceMalformed(t *testing.T) {
	t.Parallel()

	cases := []struct {
		name string
		data []byte
	}{
		{name: "empty", data: []byte{}},
		{name: "truncated", data: []byte{0x80}},
		{name: "overflow", data: bytes.Repeat([]byte{0xff}, 10)},
		{name: "overlong", data: append(bytes.Repeat([]byte{0x80}, 10), 0x00)},
	}

	for _, tc := range cases {
		t.Run(tc.name, func(t *testing.T) {
			t.Parallel()

			_, _, err := packfile.ParseOfsDeltaDistance(tc.data)
			if !errors.Is(err, packfile.ErrMalformedOfsDeltaDistance) {
				t.Fatalf("ParseOfsDeltaDistance error = %v, want ErrMalformedOfsDeltaDistance", err)
			}
		})
	}
}

func TestOfsDeltaDistanceRoundTrip(t *testing.T) {
	t.Parallel()

	distances := []uint64{
		0, 1, 127, 128, 16511, 16512, 1 << 31, 1 << 57, math.MaxUint64,
	}

	for _, dist := range distances {
		data := packfile.AppendOfsDeltaDistance(nil, dist)
		if len(data) > packfile.MaxOfsDeltaDistanceLen {
			t.Fatalf("AppendOfsDeltaDistance(%d) length = %d, want <= %d",
				dist, len(data), packfile.MaxOfsDeltaDistanceLen)
		}

		got, consumed, err := packfile.ParseOfsDeltaDistance(data)
		if err != nil {
			t.Fatalf("ParseOfsDeltaDistance: %v", err)
		}

		if got != dist {
			t.Fatalf("round trip = %d, want %d", got, dist)
		}

		if consumed != len(data) {
			t.Fatalf("round trip consumed = %d, want %d", consumed, len(data))
		}
	}
}