|
@@ -24,6 +24,7 @@ import (
|
|
|
"github.com/syncthing/syncthing/lib/events"
|
|
|
"github.com/syncthing/syncthing/lib/fs"
|
|
|
"github.com/syncthing/syncthing/lib/protocol"
|
|
|
+ "github.com/syncthing/syncthing/lib/rand"
|
|
|
)
|
|
|
|
|
|
func TestRequestSimple(t *testing.T) {
|
|
@@ -1339,7 +1340,7 @@ func TestRequestIndexSenderClusterConfigBeforeStart(t *testing.T) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-func TestRequestReceiveEncryptedLocalNoSend(t *testing.T) {
|
|
|
+func TestRequestReceiveEncrypted(t *testing.T) {
|
|
|
if testing.Short() {
|
|
|
t.Skip("skipping on short testing - scrypt is too slow")
|
|
|
}
|
|
@@ -1364,10 +1365,11 @@ func TestRequestReceiveEncryptedLocalNoSend(t *testing.T) {
|
|
|
m.fmut.RUnlock()
|
|
|
fset.Update(protocol.LocalDeviceID, files)
|
|
|
|
|
|
- indexChan := make(chan []protocol.FileInfo, 1)
|
|
|
+ indexChan := make(chan []protocol.FileInfo, 10)
|
|
|
done := make(chan struct{})
|
|
|
defer close(done)
|
|
|
fc := newFakeConnection(device1, m)
|
|
|
+ fc.folder = fcfg.ID
|
|
|
fc.setIndexFn(func(_ context.Context, _ string, fs []protocol.FileInfo) error {
|
|
|
select {
|
|
|
case indexChan <- fs:
|
|
@@ -1402,6 +1404,32 @@ func TestRequestReceiveEncryptedLocalNoSend(t *testing.T) {
|
|
|
case <-time.After(5 * time.Second):
|
|
|
t.Fatal("timed out before receiving index")
|
|
|
}
|
|
|
+
|
|
|
+ // Detects deletion, as we never really created the file on disk
|
|
|
+ // Shouldn't send anything because receive-encrypted
|
|
|
+ must(t, m.ScanFolder(fcfg.ID))
|
|
|
+ // One real file to be sent
|
|
|
+ name := "foo"
|
|
|
+ data := make([]byte, 2000)
|
|
|
+ rand.Read(data)
|
|
|
+ fc.addFile(name, 0664, protocol.FileInfoTypeFile, data)
|
|
|
+ fc.sendIndexUpdate()
|
|
|
+
|
|
|
+ select {
|
|
|
+ case fs := <-indexChan:
|
|
|
+ if len(fs) != 1 {
|
|
|
+ t.Error("Expected index with one file, got", fs)
|
|
|
+ }
|
|
|
+ if got := fs[0].Name; got != name {
|
|
|
+ t.Errorf("Expected file %v, got %v", got, files[0].Name)
|
|
|
+ }
|
|
|
+ case <-time.After(5 * time.Second):
|
|
|
+ t.Fatal("timed out before receiving index")
|
|
|
+ }
|
|
|
+
|
|
|
+ // Simulate request from device that is untrusted too, i.e. with non-empty, but garbage hash
|
|
|
+ _, err := m.Request(device1, fcfg.ID, name, 0, 1064, 0, []byte("garbage"), 0, false)
|
|
|
+ must(t, err)
|
|
|
}
|
|
|
|
|
|
func TestRequestGlobalInvalidToValid(t *testing.T) {
|