-
Notifications
You must be signed in to change notification settings - Fork 128
/
Copy pathwatcher_fsevents_test.go
112 lines (104 loc) · 2.67 KB
/
watcher_fsevents_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
// Copyright (c) 2014-2015 The Notify Authors. All rights reserved.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
//go:build darwin && !kqueue && cgo
// +build darwin,!kqueue,cgo
package notify
import (
"reflect"
"testing"
)
func TestSplitflags(t *testing.T) {
cases := [...]struct {
set uint32
flags []uint32
}{
{0, nil},
{0xD, []uint32{0x1, 0x4, 0x8}},
{0x0010 | 0x0040 | 0x0080 | 0x01000, []uint32{0x0010, 0x0040, 0x0080, 0x01000}},
{0x40000 | 0x00100 | 0x00200, []uint32{0x00100, 0x00200, 0x40000}},
}
for i, cas := range cases {
if flags := splitflags(cas.set); !reflect.DeepEqual(flags, cas.flags) {
t.Errorf("want flags=%v; got %v (i=%d)", cas.flags, flags, i)
}
}
}
func TestWatchStrip(t *testing.T) {
const (
create = uint32(FSEventsCreated)
remove = uint32(FSEventsRemoved)
rename = uint32(FSEventsRenamed)
write = uint32(FSEventsModified)
inode = uint32(FSEventsInodeMetaMod)
owner = uint32(FSEventsChangeOwner)
)
cases := [...][]struct {
path string
flag uint32
diff uint32
}{
// 1.
{
{"file", create | write, create | write},
{"file", create | write | inode, write | inode},
},
// 2.
{
{"file", create, create},
{"file", create | remove, remove},
{"file", create | remove, create},
},
// 3.
{
{"file", create | write, create | write},
{"file", create | write | owner, write | owner},
},
// 4.
{
{"file", create | write, create | write},
{"file", write | inode, write | inode},
{"file", remove | write | inode, remove},
},
{
{"file", remove | write | inode, remove},
},
}
Test:
for i, cas := range cases {
if len(cas) == 0 {
t.Log("skipped")
continue
}
w := &watch{prev: make(map[string]uint32)}
for j, cas := range cas {
if diff := w.strip(cas.path, cas.flag); diff != cas.diff {
t.Errorf("want diff=%v; got %v (i=%d, j=%d)", Event(cas.diff),
Event(diff), i, j)
continue Test
}
}
}
}
// Test for cases 3) and 5) with shadowed write&create events.
//
// See comment for (flagdiff).diff method.
func TestWatcherShadowedWriteCreate(t *testing.T) {
w := NewWatcherTest(t, "testdata/vfs.txt")
defer w.Close()
cases := [...]WCase{
// i=0
create(w, "src/github.com/rjeczalik/fs/.fs.go.swp"),
// i=1
write(w, "src/github.com/rjeczalik/fs/.fs.go.swp", []byte("XD")),
// i=2
write(w, "src/github.com/rjeczalik/fs/.fs.go.swp", []byte("XD")),
// i=3
remove(w, "src/github.com/rjeczalik/fs/.fs.go.swp"),
// i=4
create(w, "src/github.com/rjeczalik/fs/.fs.go.swp"),
// i=5
write(w, "src/github.com/rjeczalik/fs/.fs.go.swp", []byte("XD")),
}
w.ExpectAny(cases[:5]) // BUG(rjeczalik): #62
}