| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- package config
- import (
- "os"
- "path/filepath"
- "testing"
- )
- // copyFile is the workhorse invoked by init()'s Windows-only DB migration
- // (config.go:214), the branch guarded by the platform check on config.go:196.
- // The init() guard itself cannot be re-driven from an in-process test (init runs
- // once at package load, the OS check is a compile-time constant, and the old-DB
- // source path is hardcoded to a system location), so these tests pin down the
- // migration payload's contract instead.
- func TestCopyFileCopiesContents(t *testing.T) {
- dir := t.TempDir()
- src := filepath.Join(dir, "src.db")
- dst := filepath.Join(dir, "dst.db")
- want := []byte("3x-ui sqlite payload\x00\x01\x02")
- if err := os.WriteFile(src, want, 0o600); err != nil {
- t.Fatalf("write src: %v", err)
- }
- if err := copyFile(src, dst); err != nil {
- t.Fatalf("copyFile returned error: %v", err)
- }
- got, err := os.ReadFile(dst)
- if err != nil {
- t.Fatalf("read dst: %v", err)
- }
- if string(got) != string(want) {
- t.Errorf("dst contents = %q, want %q", got, want)
- }
- }
- func TestCopyFileMissingSourceReturnsError(t *testing.T) {
- dir := t.TempDir()
- src := filepath.Join(dir, "does-not-exist.db")
- dst := filepath.Join(dir, "dst.db")
- if err := copyFile(src, dst); err == nil {
- t.Fatal("copyFile with missing source returned nil error, want error")
- }
- if _, err := os.Stat(dst); !os.IsNotExist(err) {
- t.Errorf("dst should not be created when source is missing, stat err = %v", err)
- }
- }
- func TestCopyFileOverwritesDestination(t *testing.T) {
- dir := t.TempDir()
- src := filepath.Join(dir, "src.db")
- dst := filepath.Join(dir, "dst.db")
- if err := os.WriteFile(src, []byte("new"), 0o600); err != nil {
- t.Fatalf("write src: %v", err)
- }
- if err := os.WriteFile(dst, []byte("stale-and-longer"), 0o600); err != nil {
- t.Fatalf("write dst: %v", err)
- }
- if err := copyFile(src, dst); err != nil {
- t.Fatalf("copyFile returned error: %v", err)
- }
- got, err := os.ReadFile(dst)
- if err != nil {
- t.Fatalf("read dst: %v", err)
- }
- if string(got) != "new" {
- t.Errorf("dst contents = %q, want %q (truncated overwrite)", got, "new")
- }
- }
|