-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdebug_writer_test.go
More file actions
77 lines (65 loc) · 1.64 KB
/
debug_writer_test.go
File metadata and controls
77 lines (65 loc) · 1.64 KB
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
package squashfs
import (
"bytes"
"fmt"
"testing"
"testing/fstest"
)
func TestDebugWriterEntries(t *testing.T) {
testFS := make(fstest.MapFS)
// Create 100 directories with 50 files each (matching the failing test)
for d := 0; d < 100; d++ {
for f := 0; f < 50; f++ {
path := fmt.Sprintf("dir%03d/file%03d.txt", d, f)
testFS[path] = &fstest.MapFile{
Data: []byte(fmt.Sprintf("data %d %d", d, f)),
}
}
}
var buf bytes.Buffer
w, err := NewWriter(&buf)
if err != nil {
t.Fatalf("NewWriter failed: %s", err)
}
err = w.AddFS(testFS)
if err != nil {
t.Fatalf("WalkDir failed: %s", err)
}
t.Logf("Total inodes: %d", w.inodeCount)
t.Logf("Root has %d entries", len(w.rootInode.entries))
err = w.Finalize()
if err != nil {
t.Fatalf("Finalize failed: %s", err)
}
data := buf.Bytes()
t.Logf("Total size: %d bytes", len(data))
// Read it back
sqfs, err := New(bytes.NewReader(data))
if err != nil {
t.Fatalf("Failed to read back: %s", err)
}
entries, err := sqfs.ReadDir(".")
if err != nil {
t.Fatalf("Failed to read root: %s", err)
}
t.Logf("Read back %d entries from root", len(entries))
if len(entries) != 100 {
t.Errorf("Expected 100 entries, got %d", len(entries))
// List what we got
for i, e := range entries {
if i < 5 || i >= len(entries)-5 {
t.Logf(" Entry %d: %s", i, e.Name())
}
}
}
// Try to access each directory
for d := 0; d < 100; d++ {
name := fmt.Sprintf("dir%03d", d)
subEntries, err := sqfs.ReadDir(name)
if err != nil {
t.Errorf("ReadDir %s: %v", name, err)
} else if len(subEntries) != 50 {
t.Errorf("%s: expected 50 entries, got %d", name, len(subEntries))
}
}
}