2014-11-16 21:13:20 +01:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
2014-10-07 14:05:04 +01: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,
|
2017-02-09 07:52:18 +01:00
|
|
|
// You can obtain one at https://mozilla.org/MPL/2.0/.
|
2014-10-07 14:05:04 +01:00
|
|
|
|
2015-01-12 14:50:30 +01:00
|
|
|
package db
|
2014-10-07 14:05:04 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"testing"
|
2018-03-10 11:42:01 +01:00
|
|
|
|
|
|
|
"github.com/syncthing/syncthing/lib/protocol"
|
2014-10-07 14:05:04 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestDeviceKey(t *testing.T) {
|
|
|
|
fld := []byte("folder6789012345678901234567890123456789012345678901234567890123")
|
|
|
|
dev := []byte("device67890123456789012345678901")
|
|
|
|
name := []byte("name")
|
|
|
|
|
2016-01-03 19:08:19 +01:00
|
|
|
db := OpenMemory()
|
|
|
|
db.folderIdx.ID(fld)
|
|
|
|
db.deviceIdx.ID(dev)
|
2014-10-07 14:05:04 +01:00
|
|
|
|
2015-10-31 07:20:35 +01:00
|
|
|
key := db.deviceKey(fld, dev, name)
|
|
|
|
|
|
|
|
fld2 := db.deviceKeyFolder(key)
|
2016-03-31 15:12:46 +00:00
|
|
|
if !bytes.Equal(fld2, fld) {
|
2014-10-07 14:05:04 +01:00
|
|
|
t.Errorf("wrong folder %q != %q", fld2, fld)
|
|
|
|
}
|
2015-10-31 07:20:35 +01:00
|
|
|
dev2 := db.deviceKeyDevice(key)
|
2016-03-31 15:12:46 +00:00
|
|
|
if !bytes.Equal(dev2, dev) {
|
2014-10-07 14:05:04 +01:00
|
|
|
t.Errorf("wrong device %q != %q", dev2, dev)
|
|
|
|
}
|
2015-10-31 07:20:35 +01:00
|
|
|
name2 := db.deviceKeyName(key)
|
2016-03-31 15:12:46 +00:00
|
|
|
if !bytes.Equal(name2, name) {
|
2014-10-07 14:05:04 +01:00
|
|
|
t.Errorf("wrong name %q != %q", name2, name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGlobalKey(t *testing.T) {
|
|
|
|
fld := []byte("folder6789012345678901234567890123456789012345678901234567890123")
|
|
|
|
name := []byte("name")
|
|
|
|
|
2016-01-03 19:08:19 +01:00
|
|
|
db := OpenMemory()
|
|
|
|
db.folderIdx.ID(fld)
|
2015-10-31 07:20:35 +01:00
|
|
|
|
|
|
|
key := db.globalKey(fld, name)
|
2014-10-07 14:05:04 +01:00
|
|
|
|
2017-01-04 10:34:52 +00:00
|
|
|
fld2, ok := db.globalKeyFolder(key)
|
|
|
|
if !ok {
|
|
|
|
t.Error("should have been found")
|
|
|
|
}
|
2016-03-31 15:12:46 +00:00
|
|
|
if !bytes.Equal(fld2, fld) {
|
2014-10-07 14:05:04 +01:00
|
|
|
t.Errorf("wrong folder %q != %q", fld2, fld)
|
|
|
|
}
|
2015-10-31 07:20:35 +01:00
|
|
|
name2 := db.globalKeyName(key)
|
2016-03-31 15:12:46 +00:00
|
|
|
if !bytes.Equal(name2, name) {
|
2014-10-07 14:05:04 +01:00
|
|
|
t.Errorf("wrong name %q != %q", name2, name)
|
|
|
|
}
|
2017-01-04 10:34:52 +00:00
|
|
|
|
|
|
|
_, ok = db.globalKeyFolder([]byte{1, 2, 3, 4, 5})
|
|
|
|
if ok {
|
|
|
|
t.Error("should not have been found")
|
|
|
|
}
|
2014-10-07 14:05:04 +01:00
|
|
|
}
|
2018-03-10 11:42:01 +01:00
|
|
|
|
|
|
|
func TestDropIndexIDs(t *testing.T) {
|
|
|
|
db := OpenMemory()
|
|
|
|
|
|
|
|
d1 := []byte("device67890123456789012345678901")
|
|
|
|
d2 := []byte("device12345678901234567890123456")
|
|
|
|
|
|
|
|
// Set some index IDs
|
|
|
|
|
|
|
|
db.setIndexID(protocol.LocalDeviceID[:], []byte("foo"), 1)
|
|
|
|
db.setIndexID(protocol.LocalDeviceID[:], []byte("bar"), 2)
|
|
|
|
db.setIndexID(d1, []byte("foo"), 3)
|
|
|
|
db.setIndexID(d1, []byte("bar"), 4)
|
|
|
|
db.setIndexID(d2, []byte("foo"), 5)
|
|
|
|
db.setIndexID(d2, []byte("bar"), 6)
|
|
|
|
|
|
|
|
// Verify them
|
|
|
|
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("foo")) != 1 {
|
|
|
|
t.Fatal("fail local 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("bar")) != 2 {
|
|
|
|
t.Fatal("fail local 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("foo")) != 3 {
|
|
|
|
t.Fatal("fail remote 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("bar")) != 4 {
|
|
|
|
t.Fatal("fail remote 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("foo")) != 5 {
|
|
|
|
t.Fatal("fail remote 3")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("bar")) != 6 {
|
|
|
|
t.Fatal("fail remote 4")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Drop the local ones, verify only they got dropped
|
|
|
|
|
|
|
|
db.DropLocalDeltaIndexIDs()
|
|
|
|
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("foo")) != 0 {
|
|
|
|
t.Fatal("fail local 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("bar")) != 0 {
|
|
|
|
t.Fatal("fail local 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("foo")) != 3 {
|
|
|
|
t.Fatal("fail remote 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("bar")) != 4 {
|
|
|
|
t.Fatal("fail remote 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("foo")) != 5 {
|
|
|
|
t.Fatal("fail remote 3")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("bar")) != 6 {
|
|
|
|
t.Fatal("fail remote 4")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set local ones again
|
|
|
|
|
|
|
|
db.setIndexID(protocol.LocalDeviceID[:], []byte("foo"), 1)
|
|
|
|
db.setIndexID(protocol.LocalDeviceID[:], []byte("bar"), 2)
|
|
|
|
|
|
|
|
// Drop the remote ones, verify only they got dropped
|
|
|
|
|
|
|
|
db.DropRemoteDeltaIndexIDs()
|
|
|
|
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("foo")) != 1 {
|
|
|
|
t.Fatal("fail local 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(protocol.LocalDeviceID[:], []byte("bar")) != 2 {
|
|
|
|
t.Fatal("fail local 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("foo")) != 0 {
|
|
|
|
t.Fatal("fail remote 1")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d1, []byte("bar")) != 0 {
|
|
|
|
t.Fatal("fail remote 2")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("foo")) != 0 {
|
|
|
|
t.Fatal("fail remote 3")
|
|
|
|
}
|
|
|
|
if db.getIndexID(d2, []byte("bar")) != 0 {
|
|
|
|
t.Fatal("fail remote 4")
|
|
|
|
}
|
|
|
|
}
|