forked from pathikrit/better-files
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathFileWatcherSpec.scala
64 lines (50 loc) · 2.26 KB
/
FileWatcherSpec.scala
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
package better.files
import Cmds._
import org.scalatest._
import scala.concurrent.duration._
import scala.language.postfixOps
import scala.util.Try
class FileWatcherSpec extends FlatSpec with Matchers {
val isCI = Try(sys.env("CI").toBoolean) getOrElse false //TODO: Move these to core test package
def sleep(t: FiniteDuration = 2 second) = Thread.sleep(t.toMillis)
"file watcher" should "watch directories" in {
assume(isCI)
val dir = File.newTemporaryDirectory()
(dir / "a" / "b" / "c.txt").createIfNotExists(createParents = true)
var log = List.empty[String]
def output(file: File, event: String) = synchronized {
val msg = s"${dir.path relativize file.path} got $event"
println(msg)
log = msg :: log
}
/***************************************************************************/
import java.nio.file.{StandardWatchEventKinds => Events}
import FileWatcher._
import akka.actor.{ActorRef, ActorSystem}
implicit val system = ActorSystem()
val watcher: ActorRef = dir.newWatcher(recursive = true)
watcher ! when(events = Events.ENTRY_CREATE, Events.ENTRY_MODIFY) { // watch for multiple events
case (Events.ENTRY_CREATE, file) => output(file, "created")
case (Events.ENTRY_MODIFY, file) => output(file, "modified")
}
watcher ! on(Events.ENTRY_DELETE) { // register partial function for single event
case file => output(file, "deleted")
}
/***************************************************************************/
sleep(5 seconds)
(dir / "a" / "b" / "c.txt").writeText("Hello world"); sleep()
rm(dir / "a" / "b"); sleep()
mkdir(dir / "d"); sleep()
touch(dir / "d" / "e.txt"); sleep()
mkdirs(dir / "d" / "f" / "g"); sleep()
touch(dir / "d" / "f" / "g" / "e.txt"); sleep()
(dir / "d" / "f" / "g" / "e.txt") moveTo (dir / "a" / "e.txt"); sleep()
sleep(10 seconds)
val expectedEvents = List(
"a/e.txt got created", "d/f/g/e.txt got deleted", "d/f/g/e.txt got modified", "d/f/g/e.txt got created", "d/f got created",
"d/e.txt got modified", "d/e.txt got created", "d got created", "a/b got deleted", "a/b/c.txt got deleted", "a/b/c.txt got modified"
)
expectedEvents diff log shouldBe empty
system.terminate()
}
}