Remove file watch upon interruption
TestValidatorOverwriteEmailListViaRenameAndReplace was deadlocking on Windows because, on Windows, fsnotify.Watcher will continue to watch a renamed file using its new name. On other systems, it appears the watch on a file is removed after a rename. The fix is to explicitly remove the watch to ensure the watch is resumed under the original name.
This commit is contained in:
		
							parent
							
								
									5f2df7167a
								
							
						
					
					
						commit
						020a35e85f
					
				
							
								
								
									
										14
									
								
								watcher.go
								
								
								
								
							
							
						
						
									
										14
									
								
								watcher.go
								
								
								
								
							|  | @ -12,17 +12,18 @@ import ( | ||||||
| 	"gopkg.in/fsnotify.v1" | 	"gopkg.in/fsnotify.v1" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func WaitForReplacement(event fsnotify.Event, watcher *fsnotify.Watcher) { | func WaitForReplacement(filename string, op fsnotify.Op, | ||||||
|  | 	watcher *fsnotify.Watcher) { | ||||||
| 	const sleep_interval = 50 * time.Millisecond | 	const sleep_interval = 50 * time.Millisecond | ||||||
| 
 | 
 | ||||||
| 	// Avoid a race when fsnofity.Remove is preceded by fsnotify.Chmod.
 | 	// Avoid a race when fsnofity.Remove is preceded by fsnotify.Chmod.
 | ||||||
| 	if event.Op&fsnotify.Chmod != 0 { | 	if op&fsnotify.Chmod != 0 { | ||||||
| 		time.Sleep(sleep_interval) | 		time.Sleep(sleep_interval) | ||||||
| 	} | 	} | ||||||
| 	for { | 	for { | ||||||
| 		if _, err := os.Stat(event.Name); err == nil { | 		if _, err := os.Stat(filename); err == nil { | ||||||
| 			if err := watcher.Add(event.Name); err == nil { | 			if err := watcher.Add(filename); err == nil { | ||||||
| 				log.Printf("watching resumed for %s", event.Name) | 				log.Printf("watching resumed for %s", filename) | ||||||
| 				return | 				return | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | @ -52,7 +53,8 @@ func WatchForUpdates(filename string, done <-chan bool, action func()) bool { | ||||||
| 				// can't be opened.
 | 				// can't be opened.
 | ||||||
| 				if event.Op&(fsnotify.Remove|fsnotify.Rename|fsnotify.Chmod) != 0 { | 				if event.Op&(fsnotify.Remove|fsnotify.Rename|fsnotify.Chmod) != 0 { | ||||||
| 					log.Printf("watching interrupted on event: %s", event) | 					log.Printf("watching interrupted on event: %s", event) | ||||||
| 					WaitForReplacement(event, watcher) | 					watcher.Remove(filename) | ||||||
|  | 					WaitForReplacement(filename, event.Op, watcher) | ||||||
| 				} | 				} | ||||||
| 				log.Printf("reloading after event: %s", event) | 				log.Printf("reloading after event: %s", event) | ||||||
| 				action() | 				action() | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue