Parser / archive: - Add .sds extension as tar-format alias (archive.go) - Add tests for multipart upload size limits (multipart_limits_test.go) - Remove supermicro crashdump parser (ADL-015) Dell parser: - Remove GPU duplicates from PCIeDevices (DCIM_VideoView vs DCIM_PCIDeviceView both list the same GPU; VideoView record is authoritative) Server: - Add LOGPILE_CONVERT_MAX_MB env var for independent convert batch size limit - Improve "file too large" error message with current limit value Web: - Add CONVERT_MAX_FILES_PER_BATCH = 1000 cap - Minor UI copy and CSS fixes Bible: - bible-local/06-parsers.md: add pci.ids enrichment rule (enrich model from pciids when name is empty but vendor_id+device_id are present) - Sync bible submodule and local overview/architecture docs Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
127 lines
3.2 KiB
Go
127 lines
3.2 KiB
Go
package parser
|
|
|
|
import (
|
|
"archive/tar"
|
|
"bytes"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
func TestExtractArchiveFromReaderTXT(t *testing.T) {
|
|
content := "loader_brand=\"XigmaNAS\"\nSystem uptime:\n"
|
|
files, err := ExtractArchiveFromReader(strings.NewReader(content), "xigmanas.txt")
|
|
if err != nil {
|
|
t.Fatalf("extract txt from reader: %v", err)
|
|
}
|
|
if len(files) != 1 {
|
|
t.Fatalf("expected 1 file, got %d", len(files))
|
|
}
|
|
if files[0].Path != "xigmanas.txt" {
|
|
t.Fatalf("expected filename xigmanas.txt, got %q", files[0].Path)
|
|
}
|
|
if string(files[0].Content) != content {
|
|
t.Fatalf("content mismatch")
|
|
}
|
|
}
|
|
|
|
func TestExtractArchiveTXT(t *testing.T) {
|
|
dir := t.TempDir()
|
|
path := filepath.Join(dir, "sample.txt")
|
|
want := "plain text log"
|
|
if err := os.WriteFile(path, []byte(want), 0o600); err != nil {
|
|
t.Fatalf("write sample txt: %v", err)
|
|
}
|
|
|
|
files, err := ExtractArchive(path)
|
|
if err != nil {
|
|
t.Fatalf("extract txt file: %v", err)
|
|
}
|
|
if len(files) != 1 {
|
|
t.Fatalf("expected 1 file, got %d", len(files))
|
|
}
|
|
if files[0].Path != "sample.txt" {
|
|
t.Fatalf("expected sample.txt, got %q", files[0].Path)
|
|
}
|
|
if string(files[0].Content) != want {
|
|
t.Fatalf("content mismatch")
|
|
}
|
|
}
|
|
|
|
func TestExtractArchiveFromReaderTXT_TruncatedWhenTooLarge(t *testing.T) {
|
|
large := bytes.Repeat([]byte("a"), maxSingleFileSize+1024)
|
|
files, err := ExtractArchiveFromReader(bytes.NewReader(large), "huge.log")
|
|
if err != nil {
|
|
t.Fatalf("extract huge txt from reader: %v", err)
|
|
}
|
|
if len(files) != 1 {
|
|
t.Fatalf("expected 1 file, got %d", len(files))
|
|
}
|
|
|
|
f := files[0]
|
|
if !f.Truncated {
|
|
t.Fatalf("expected file to be marked as truncated")
|
|
}
|
|
if got := len(f.Content); got != maxSingleFileSize {
|
|
t.Fatalf("expected truncated size %d, got %d", maxSingleFileSize, got)
|
|
}
|
|
if f.TruncatedMessage == "" {
|
|
t.Fatalf("expected truncation message")
|
|
}
|
|
}
|
|
|
|
func TestIsSupportedArchiveFilename(t *testing.T) {
|
|
cases := []struct {
|
|
name string
|
|
want bool
|
|
}{
|
|
{name: "dump.tar.gz", want: true},
|
|
{name: "nvidia-bug-report-1651124000923.log.gz", want: true},
|
|
{name: "snapshot.zip", want: true},
|
|
{name: "h3c_20250819.sds", want: true},
|
|
{name: "report.log", want: true},
|
|
{name: "xigmanas.txt", want: true},
|
|
{name: "raw_export.json", want: false},
|
|
{name: "archive.bin", want: false},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
got := IsSupportedArchiveFilename(tc.name)
|
|
if got != tc.want {
|
|
t.Fatalf("IsSupportedArchiveFilename(%q)=%v, want %v", tc.name, got, tc.want)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestExtractArchiveFromReaderSDS(t *testing.T) {
|
|
var buf bytes.Buffer
|
|
tw := tar.NewWriter(&buf)
|
|
|
|
payload := []byte("STARTTIME:0\nENDTIME:0\n")
|
|
if err := tw.WriteHeader(&tar.Header{
|
|
Name: "bmc/pack.info",
|
|
Mode: 0o600,
|
|
Size: int64(len(payload)),
|
|
}); err != nil {
|
|
t.Fatalf("write tar header: %v", err)
|
|
}
|
|
if _, err := tw.Write(payload); err != nil {
|
|
t.Fatalf("write tar payload: %v", err)
|
|
}
|
|
if err := tw.Close(); err != nil {
|
|
t.Fatalf("close tar writer: %v", err)
|
|
}
|
|
|
|
files, err := ExtractArchiveFromReader(bytes.NewReader(buf.Bytes()), "sample.sds")
|
|
if err != nil {
|
|
t.Fatalf("extract sds from reader: %v", err)
|
|
}
|
|
if len(files) != 1 {
|
|
t.Fatalf("expected 1 extracted file, got %d", len(files))
|
|
}
|
|
if files[0].Path != "bmc/pack.info" {
|
|
t.Fatalf("expected bmc/pack.info, got %q", files[0].Path)
|
|
}
|
|
}
|