2014-11-16 21:13:20 +01:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
2014-09-29 21:43:32 +02:00
|
|
|
//
|
2015-03-07 21:36:35 +01:00
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
// You can obtain one at http://mozilla.org/MPL/2.0/.
|
2014-08-19 12:43:50 +02:00
|
|
|
|
2014-10-11 17:55:11 +02:00
|
|
|
package main
|
2014-08-19 12:43:50 +02:00
|
|
|
|
2014-10-11 17:55:11 +02:00
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2015-01-13 13:22:56 +01:00
|
|
|
"github.com/syncthing/protocol"
|
2014-10-11 17:55:11 +02:00
|
|
|
"github.com/syncthing/syncthing/internal/config"
|
2015-01-12 14:50:30 +01:00
|
|
|
"github.com/syncthing/syncthing/internal/db"
|
2014-10-11 17:55:11 +02:00
|
|
|
"github.com/syncthing/syncthing/internal/model"
|
|
|
|
|
|
|
|
"github.com/syndtr/goleveldb/leveldb"
|
|
|
|
"github.com/syndtr/goleveldb/leveldb/storage"
|
|
|
|
)
|
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
func TestFolderErrors(t *testing.T) {
|
2015-04-25 08:27:45 +02:00
|
|
|
// This test intentionally avoids starting the folders. If they are
|
|
|
|
// started, they will perform an initial scan, which will create missing
|
|
|
|
// folder markers and race with the stuff we do in the test.
|
|
|
|
|
2014-10-11 17:55:11 +02:00
|
|
|
fcfg := config.FolderConfiguration{
|
2015-04-05 22:52:22 +02:00
|
|
|
ID: "folder",
|
|
|
|
RawPath: "testdata/testfolder",
|
2014-10-11 17:55:11 +02:00
|
|
|
}
|
|
|
|
cfg := config.Wrap("/tmp/test", config.Configuration{
|
|
|
|
Folders: []config.FolderConfiguration{fcfg},
|
|
|
|
})
|
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
for _, file := range []string{".stfolder", "testfolder/.stfolder", "testfolder"} {
|
2015-04-25 08:27:45 +02:00
|
|
|
if err := os.Remove("testdata/" + file); err != nil && !os.IsNotExist(err) {
|
|
|
|
t.Fatal(err)
|
2014-10-11 17:55:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-12 14:50:30 +01:00
|
|
|
ldb, _ := leveldb.Open(storage.NewMemStorage(), nil)
|
2014-10-11 17:55:11 +02:00
|
|
|
|
|
|
|
// Case 1 - new folder, directory and marker created
|
|
|
|
|
2015-03-25 22:37:23 +01:00
|
|
|
m := model.NewModel(cfg, protocol.LocalDeviceID, "device", "syncthing", "dev", ldb)
|
2015-03-28 15:25:42 +01:00
|
|
|
m.AddFolder(fcfg)
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
if err := m.CheckFolderHealth("folder"); err != nil {
|
2014-10-11 17:55:11 +02:00
|
|
|
t.Error("Unexpected error", cfg.Folders()["folder"].Invalid)
|
|
|
|
}
|
|
|
|
|
|
|
|
s, err := os.Stat("testdata/testfolder")
|
|
|
|
if err != nil || !s.IsDir() {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err = os.Stat("testdata/testfolder/.stfolder")
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
2015-04-25 08:27:45 +02:00
|
|
|
if err := os.Remove("testdata/testfolder/.stfolder"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := os.Remove("testdata/testfolder/"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2014-10-11 17:55:11 +02:00
|
|
|
|
|
|
|
// Case 2 - new folder, marker created
|
|
|
|
|
2015-04-05 22:52:22 +02:00
|
|
|
fcfg.RawPath = "testdata/"
|
2014-10-11 17:55:11 +02:00
|
|
|
cfg = config.Wrap("/tmp/test", config.Configuration{
|
|
|
|
Folders: []config.FolderConfiguration{fcfg},
|
|
|
|
})
|
|
|
|
|
2015-03-25 22:37:23 +01:00
|
|
|
m = model.NewModel(cfg, protocol.LocalDeviceID, "device", "syncthing", "dev", ldb)
|
2015-03-28 15:25:42 +01:00
|
|
|
m.AddFolder(fcfg)
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
if err := m.CheckFolderHealth("folder"); err != nil {
|
2014-10-11 17:55:11 +02:00
|
|
|
t.Error("Unexpected error", cfg.Folders()["folder"].Invalid)
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err = os.Stat("testdata/.stfolder")
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
2015-04-25 08:27:45 +02:00
|
|
|
if err := os.Remove("testdata/.stfolder"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
// Case 3 - Folder marker missing
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-01-12 14:52:24 +01:00
|
|
|
set := db.NewFileSet("folder", ldb)
|
2014-10-11 17:55:11 +02:00
|
|
|
set.Update(protocol.LocalDeviceID, []protocol.FileInfo{
|
|
|
|
{Name: "dummyfile"},
|
|
|
|
})
|
|
|
|
|
2015-03-25 22:37:23 +01:00
|
|
|
m = model.NewModel(cfg, protocol.LocalDeviceID, "device", "syncthing", "dev", ldb)
|
2015-03-28 15:25:42 +01:00
|
|
|
m.AddFolder(fcfg)
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-04-12 22:12:01 +02:00
|
|
|
if err := m.CheckFolderHealth("folder"); err == nil || err.Error() != "folder marker missing" {
|
2015-03-28 15:25:42 +01:00
|
|
|
t.Error("Incorrect error: Folder marker missing !=", m.CheckFolderHealth("folder"))
|
2014-10-11 17:55:11 +02:00
|
|
|
}
|
|
|
|
|
2015-03-28 15:25:42 +01:00
|
|
|
// Case 3.1 - recover after folder marker missing
|
|
|
|
|
|
|
|
if err = fcfg.CreateMarker(); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.CheckFolderHealth("folder"); err != nil {
|
|
|
|
t.Error("Unexpected error", cfg.Folders()["folder"].Invalid)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Case 4 - Folder path missing
|
|
|
|
|
2015-04-25 08:27:45 +02:00
|
|
|
if err := os.Remove("testdata/testfolder/.stfolder"); err != nil && !os.IsNotExist(err) {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := os.Remove("testdata/testfolder"); err != nil && !os.IsNotExist(err) {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-04-05 22:52:22 +02:00
|
|
|
fcfg.RawPath = "testdata/testfolder"
|
2015-03-28 15:25:42 +01:00
|
|
|
cfg = config.Wrap("testdata/subfolder", config.Configuration{
|
2014-10-11 17:55:11 +02:00
|
|
|
Folders: []config.FolderConfiguration{fcfg},
|
|
|
|
})
|
|
|
|
|
2015-03-25 22:37:23 +01:00
|
|
|
m = model.NewModel(cfg, protocol.LocalDeviceID, "device", "syncthing", "dev", ldb)
|
2015-03-28 15:25:42 +01:00
|
|
|
m.AddFolder(fcfg)
|
2014-10-11 17:55:11 +02:00
|
|
|
|
2015-04-12 22:12:01 +02:00
|
|
|
if err := m.CheckFolderHealth("folder"); err == nil || err.Error() != "folder path missing" {
|
2015-03-28 15:25:42 +01:00
|
|
|
t.Error("Incorrect error: Folder path missing !=", m.CheckFolderHealth("folder"))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Case 4.1 - recover after folder path missing
|
|
|
|
|
2015-04-25 08:27:45 +02:00
|
|
|
if err := os.Mkdir("testdata/testfolder", 0700); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2015-03-28 15:25:42 +01:00
|
|
|
|
2015-04-12 22:12:01 +02:00
|
|
|
if err := m.CheckFolderHealth("folder"); err == nil || err.Error() != "folder marker missing" {
|
2015-03-28 15:25:42 +01:00
|
|
|
t.Error("Incorrect error: Folder marker missing !=", m.CheckFolderHealth("folder"))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Case 4.2 - recover after missing marker
|
|
|
|
|
|
|
|
if err = fcfg.CreateMarker(); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := m.CheckFolderHealth("folder"); err != nil {
|
|
|
|
t.Error("Unexpected error", cfg.Folders()["folder"].Invalid)
|
2014-10-11 17:55:11 +02:00
|
|
|
}
|
|
|
|
}
|
2015-04-09 12:53:13 +02:00
|
|
|
|
|
|
|
func TestShortIDCheck(t *testing.T) {
|
|
|
|
cfg := config.Wrap("/tmp/test", config.Configuration{
|
|
|
|
Devices: []config.DeviceConfiguration{
|
|
|
|
{DeviceID: protocol.DeviceID{8, 16, 24, 32, 40, 48, 56, 0, 0}},
|
|
|
|
{DeviceID: protocol.DeviceID{8, 16, 24, 32, 40, 48, 56, 1, 1}}, // first 56 bits same, differ in the first 64 bits
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
if err := checkShortIDs(cfg); err != nil {
|
|
|
|
t.Error("Unexpected error:", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg = config.Wrap("/tmp/test", config.Configuration{
|
|
|
|
Devices: []config.DeviceConfiguration{
|
|
|
|
{DeviceID: protocol.DeviceID{8, 16, 24, 32, 40, 48, 56, 64, 0}},
|
|
|
|
{DeviceID: protocol.DeviceID{8, 16, 24, 32, 40, 48, 56, 64, 1}}, // first 64 bits same
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
if err := checkShortIDs(cfg); err == nil {
|
|
|
|
t.Error("Should have gotten an error")
|
|
|
|
}
|
|
|
|
}
|