-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlog_test.go
69 lines (51 loc) · 1.6 KB
/
log_test.go
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
package storage
import (
"encoding/binary"
"os"
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestExtractReadLog(t *testing.T) {
// Setup
tmpFile, err := os.CreateTemp("", "test-log")
require.NoError(t, err)
defer os.Remove(tmpFile.Name())
// Write binary-formatted key-value pairs to the file
writeKeyValue := func(key, value string) error {
keySize := uint32(len(key))
valueSize := uint32(len(value))
err := binary.Write(tmpFile, binary.LittleEndian, keySize)
require.NoError(t, err)
_, err = tmpFile.Write([]byte(key))
require.NoError(t, err)
err = binary.Write(tmpFile, binary.LittleEndian, valueSize)
require.NoError(t, err)
_, err = tmpFile.Write([]byte(value))
require.NoError(t, err)
return nil
}
err = writeKeyValue("key1", "value1")
require.NoError(t, err, "Failed to write key-value pair")
err = writeKeyValue("key2", "value2")
require.NoError(t, err, "Failed to write key-value pair")
err = writeKeyValue("key3", "value3")
require.NoError(t, err, "Failed to write key-value pair")
tmpFile.Close()
// Run function
readLog, err := extractReadLog(tmpFile.Name())
require.NoError(t, err)
// Validate results
assert.Equal(t, readLog.path, tmpFile.Name())
require.NotNil(t, readLog.index, "Expected non-nil index")
expectedOffsets := map[string]int64{
"key1": 8,
"key2": 26,
"key3": 44,
}
for k, expected := range expectedOffsets {
actual, found := readLog.index[k]
require.True(t, found, "Key %s not found in index", k)
assert.Equal(t, expected, actual, "Expected offset %d, got %d", expected, actual)
}
}