|
|
@@ -7,20 +7,36 @@
|
|
|
package syncthing
|
|
|
|
|
|
import (
|
|
|
+ "io/ioutil"
|
|
|
+ "os"
|
|
|
+ "path/filepath"
|
|
|
"testing"
|
|
|
+ "time"
|
|
|
|
|
|
"github.com/syncthing/syncthing/lib/config"
|
|
|
"github.com/syncthing/syncthing/lib/events"
|
|
|
"github.com/syncthing/syncthing/lib/protocol"
|
|
|
+ "github.com/syncthing/syncthing/lib/tlsutil"
|
|
|
)
|
|
|
|
|
|
+func tempCfgFilename(t *testing.T) string {
|
|
|
+ t.Helper()
|
|
|
+ f, err := ioutil.TempFile("", "syncthing-testConfig-")
|
|
|
+ if err != nil {
|
|
|
+ t.Fatal(err)
|
|
|
+ }
|
|
|
+ defer f.Close()
|
|
|
+ return f.Name()
|
|
|
+}
|
|
|
+
|
|
|
func TestShortIDCheck(t *testing.T) {
|
|
|
- cfg := config.Wrap("/tmp/test", config.Configuration{
|
|
|
+ cfg := config.Wrap(tempCfgFilename(t), 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
|
|
|
},
|
|
|
}, events.NoopLogger)
|
|
|
+ defer os.Remove(cfg.ConfigPath())
|
|
|
|
|
|
if err := checkShortIDs(cfg); err != nil {
|
|
|
t.Error("Unexpected error:", err)
|
|
|
@@ -37,3 +53,54 @@ func TestShortIDCheck(t *testing.T) {
|
|
|
t.Error("Should have gotten an error")
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+func TestStartupFail(t *testing.T) {
|
|
|
+ tmpDir, err := ioutil.TempDir("", "syncthing-TestStartupFail-")
|
|
|
+ if err != nil {
|
|
|
+ t.Fatal(err)
|
|
|
+ }
|
|
|
+ defer os.RemoveAll(tmpDir)
|
|
|
+
|
|
|
+ cert, err := tlsutil.NewCertificate(filepath.Join(tmpDir, "cert"), filepath.Join(tmpDir, "key"), "syncthing")
|
|
|
+ if err != nil {
|
|
|
+ t.Fatal(err)
|
|
|
+ }
|
|
|
+ id := protocol.NewDeviceID(cert.Certificate[0])
|
|
|
+ conflID := protocol.DeviceID{}
|
|
|
+ copy(conflID[:8], id[:8])
|
|
|
+
|
|
|
+ cfg := config.Wrap(tempCfgFilename(t), config.Configuration{
|
|
|
+ Devices: []config.DeviceConfiguration{
|
|
|
+ {DeviceID: id},
|
|
|
+ {DeviceID: conflID},
|
|
|
+ },
|
|
|
+ }, events.NoopLogger)
|
|
|
+ defer os.Remove(cfg.ConfigPath())
|
|
|
+
|
|
|
+ app := New(cfg, nil, events.NoopLogger, cert, Options{})
|
|
|
+ startErr := app.Start()
|
|
|
+ if startErr == nil {
|
|
|
+ t.Fatal("Expected an error from Start, got nil")
|
|
|
+ }
|
|
|
+
|
|
|
+ done := make(chan struct{})
|
|
|
+ var waitE ExitStatus
|
|
|
+ go func() {
|
|
|
+ waitE = app.Wait()
|
|
|
+ close(done)
|
|
|
+ }()
|
|
|
+
|
|
|
+ select {
|
|
|
+ case <-time.After(time.Second):
|
|
|
+ t.Fatal("Wait did not return within 1s")
|
|
|
+ case <-done:
|
|
|
+ }
|
|
|
+
|
|
|
+ if waitE != ExitError {
|
|
|
+ t.Errorf("Got exit status %v, expected %v", waitE, ExitError)
|
|
|
+ }
|
|
|
+
|
|
|
+ if err = app.Error(); err != startErr {
|
|
|
+ t.Errorf(`Got different errors "%v" from Start and "%v" from Error`, startErr, err)
|
|
|
+ }
|
|
|
+}
|