mirror of
https://github.com/syncthing/syncthing.git
synced 2024-11-16 10:28:49 -07:00
bdbca75dfa
Move state tracking into the puller/scanner objects. This is a first step towards resolving #1391. Rename Puller and Scanner to roFolder and rwFolder as they have more duties than just pulling and scanning, and don't need to be exported.
154 lines
3.3 KiB
Go
154 lines
3.3 KiB
Go
// Copyright (C) 2014 The Syncthing Authors.
|
|
//
|
|
// 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/.
|
|
|
|
// +build integration
|
|
|
|
package integration
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/syncthing/syncthing/internal/symlinks"
|
|
)
|
|
|
|
func TestIgnores(t *testing.T) {
|
|
// Clean and start a syncthing instance
|
|
|
|
log.Println("Cleaning...")
|
|
err := removeAll("s1", "h1/index")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
p := syncthingProcess{ // id1
|
|
instance: "1",
|
|
argv: []string{"-home", "h1"},
|
|
port: 8081,
|
|
apiKey: apiKey,
|
|
}
|
|
err = p.start()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer p.stop()
|
|
|
|
// Create eight empty files and directories
|
|
|
|
files := []string{"f1", "f2", "f3", "f4", "f11", "f12", "f13", "f14"}
|
|
dirs := []string{"d1", "d2", "d3", "d4", "d11", "d12", "d13", "d14"}
|
|
all := append(files, dirs...)
|
|
|
|
for _, file := range files {
|
|
fd, err := os.Create(filepath.Join("s1", file))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
fd.Close()
|
|
}
|
|
|
|
for _, dir := range dirs {
|
|
err := os.Mkdir(filepath.Join("s1", dir), 0755)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
var syms []string
|
|
if symlinksSupported() {
|
|
syms = []string{"s1", "s2", "s3", "s4", "s11", "s12", "s13", "s14"}
|
|
for _, sym := range syms {
|
|
p := filepath.Join("s1", sym)
|
|
symlinks.Create(p, p, 0)
|
|
}
|
|
all = append(all, syms...)
|
|
}
|
|
|
|
// Rescan and verify that we see them all
|
|
|
|
// Wait for one scan to succeed, or up to 20 seconds...
|
|
// This is to let startup, UPnP etc complete.
|
|
for i := 0; i < 20; i++ {
|
|
resp, err := p.post("/rest/scan?folder=default", nil)
|
|
if err != nil {
|
|
time.Sleep(time.Second)
|
|
continue
|
|
}
|
|
if resp.StatusCode != 200 {
|
|
resp.Body.Close()
|
|
time.Sleep(time.Second)
|
|
continue
|
|
}
|
|
break
|
|
}
|
|
|
|
m, err := p.model("default")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
expected := len(all) // nothing is ignored
|
|
if m.LocalFiles != expected {
|
|
t.Fatalf("Incorrect number of files after initial scan, %d != %d", m.LocalFiles, expected)
|
|
}
|
|
|
|
// Add some of them to an ignore file
|
|
|
|
fd, err := os.Create("s1/.stignore")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
_, err = fd.WriteString("f1*\nf2\nd1*\nd2\ns1*\ns2") // [fds][34] only non-ignored items
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
err = fd.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Rescan and verify that we see them
|
|
|
|
p.post("/rest/scan?folder=default", nil)
|
|
m, err = p.model("default")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
expected = len(all) * 2 / 8 // two out of eight items of each type should remain
|
|
if m.LocalFiles != expected {
|
|
t.Fatalf("Incorrect number of files after first ignore, %d != %d", m.LocalFiles, expected)
|
|
}
|
|
|
|
// Change the pattern to include some of the files and dirs previously ignored
|
|
|
|
fd, err = os.Create("s1/.stignore")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
_, err = fd.WriteString("f2\nd2\ns2\n")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
err = fd.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Rescan and verify that we see them
|
|
|
|
p.post("/rest/scan?folder=default", nil)
|
|
m, err = p.model("default")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
expected = len(all) * 7 / 8 // seven out of eight items of each type should remain
|
|
if m.LocalFiles != expected {
|
|
t.Fatalf("Incorrect number of files after second ignore, %d != %d", m.LocalFiles, expected)
|
|
}
|
|
}
|