monitoring
monitoring copied to clipboard
fix(deps): update module github.com/fsnotify/fsnotify to v1.7.0
This PR contains the following updates:
| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| github.com/fsnotify/fsnotify | v1.4.7 -> v1.7.0 |
Release Notes
fsnotify/fsnotify (github.com/fsnotify/fsnotify)
v1.7.0
This version of fsnotify needs Go 1.17.
Additions
-
illumos: add FEN backend to support illumos and Solaris. (#371)
-
all: add
NewBufferedWatcher()to use a buffered channel, which can be useful in cases where you can't control the kernel buffer and receive a large number of events in bursts. (#550, #572) -
all: add
AddWith(), which is identical toAdd()but allows passing options. (#521) -
windows: allow setting the ReadDirectoryChangesW() buffer size with
fsnotify.WithBufferSize(); the default of 64K is the highest value that works on all platforms and is enough for most purposes, but in some cases a highest buffer is needed. (#521)
Changes and fixes
-
inotify: remove watcher if a watched path is renamed (#518)
After a rename the reported name wasn't updated, or even an empty string. Inotify doesn't provide any good facilities to update it, so just remove the watcher. This is already how it worked on kqueue and FEN.
On Windows this does work, and remains working.
-
windows: don't listen for file attribute changes (#520)
File attribute changes are sent as
FILE_ACTION_MODIFIEDby the Windows API, with no way to see if they're a file write or attribute change, so would show up as a fsnotify.Write event. This is never useful, and could result in many spurious Write events. -
windows: return
ErrEventOverflowif the buffer is full (#525)Before it would merely return "short read", making it hard to detect this error.
-
kqueue: make sure events for all files are delivered properly when removing a watched directory (#526)
Previously they would get sent with
""(empty string) or"."as the path name. -
kqueue: don't emit spurious Create events for symbolic links (#524)
The link would get resolved but kqueue would "forget" it already saw the link itself, resulting on a Create for every Write event for the directory.
-
all: return
ErrClosedonAdd()when the watcher is closed (#516) -
other: add
Watcher.ErrorsandWatcher.Eventsto the no-opWatcherinbackend_other.go, making it easier to use on unsupported platforms such as WASM, AIX, etc. (#528) -
other: use the
backend_other.gono-op if theappenginebuild tag is set; Google AppEngine forbids usage of the unsafe package so the inotify backend won't compile there.
v1.6.0
This version of fsnotify needs Go 1.16 (this was already the case since 1.5.1, but not documented). It also increases the minimum Linux version to 2.6.32.
Additions
-
all: add
Event.Has()andOp.Has()(#477)This makes checking events a lot easier; for example:
if event.Op&Write == Write && !(event.Op&Remove == Remove) { }Becomes:
if event.Has(Write) && !event.Has(Remove) { } -
all: add cmd/fsnotify (#463)
A command-line utility for testing and some examples.
Changes and fixes
-
inotify: don't ignore events for files that don't exist (#260, #470)
Previously the inotify watcher would call
os.Lstat()to check if a file still exists before emitting events.This was inconsistent with other platforms and resulted in inconsistent event reporting (e.g. when a file is quickly removed and re-created), and generally a source of confusion. It was added in 2013 to fix a memory leak that no longer exists.
-
all: return
ErrNonExistentWatchwhenRemove()is called on a path that's not watched (#460) -
inotify: replace epoll() with non-blocking inotify (#434)
Non-blocking inotify was not generally available at the time this library was written in 2014, but now it is. As a result, the minimum Linux version is bumped from 2.6.27 to 2.6.32. This hugely simplifies the code and is faster.
-
kqueue: don't check for events every 100ms (#480)
The watcher would wake up every 100ms, even when there was nothing to do. Now it waits until there is something to do.
-
macos: retry opening files on EINTR (#475)
-
kqueue: skip unreadable files (#479)
kqueue requires a file descriptor for every file in a directory; this would fail if a file was unreadable by the current user. Now these files are simply skipped.
-
windows: fix renaming a watched directory if the parent is also watched (#370)
-
windows: increase buffer size from 4K to 64K (#485)
-
windows: close file handle on Remove() (#288)
-
kqueue: put pathname in the error if watching a file fails (#471)
-
inotify, windows: calling Close() more than once could race (#465)
-
kqueue: improve Close() performance (#233)
-
all: various documentation additions and clarifications.
v1.5.4
What's Changed
- Fix compilation for OpenBSD by @mattn in https://github.com/fsnotify/fsnotify/pull/443
- go.mod: use latest x/sys by @kevinburkesegment in https://github.com/fsnotify/fsnotify/pull/444
- README.md: link to pkg.go.dev for golang.org/x/sys package by @tklauser in https://github.com/fsnotify/fsnotify/pull/441
- Windows: add missing defer to Watcher.WatchList by @Sojamann in https://github.com/fsnotify/fsnotify/pull/447
- Prepare for v1.5.4 by @shogo82148 in https://github.com/fsnotify/fsnotify/pull/448
New Contributors
- @mattn made their first contribution in https://github.com/fsnotify/fsnotify/pull/443
- @kevinburkesegment made their first contribution in https://github.com/fsnotify/fsnotify/pull/444
- @Sojamann made their first contribution in https://github.com/fsnotify/fsnotify/pull/447
Full Changelog: https://github.com/fsnotify/fsnotify/compare/v1.5.2...v1.5.4
v1.5.3
v1.5.2
What's Changed
- Removed dead link by @COil in https://github.com/fsnotify/fsnotify/pull/337
- Update issue templates by @nathany in https://github.com/fsnotify/fsnotify/pull/410
- Test on Go 1.18 and two most recent versions by @nathany in https://github.com/fsnotify/fsnotify/pull/411
- fix go vet warnings: call to (*T).Fatalf from a non-test goroutine by @shogo82148 in https://github.com/fsnotify/fsnotify/pull/416
- Run cross-compilation builds on every push by @nshalman in https://github.com/fsnotify/fsnotify/pull/420
- Don't set
poller.fdtwice innewFdPollerby @tklauser in https://github.com/fsnotify/fsnotify/pull/406 - Re-enable tests for PRs by @nshalman in https://github.com/fsnotify/fsnotify/pull/415
- Enable cross-compilation builds on PRs by @nshalman in https://github.com/fsnotify/fsnotify/pull/423
- Integration Tests: change 1ms sleeps to 50ms by @nshalman in https://github.com/fsnotify/fsnotify/pull/422
- Add FreeBSD testing in Github Actions (fix #389) by @r-darwish in https://github.com/fsnotify/fsnotify/pull/419
- Allow build on unsupported GOOS by @tklauser in https://github.com/fsnotify/fsnotify/pull/424
- Fix potential crash on windows if raw.FileNameLength exceeds syscall.MAX_PATH by @hu13 in https://github.com/fsnotify/fsnotify/pull/361
- Add a feature to return the directories and files that are being monitored by @NitroCao in https://github.com/fsnotify/fsnotify/pull/374
New Contributors
- @COil made their first contribution in https://github.com/fsnotify/fsnotify/pull/337
- @r-darwish made their first contribution in https://github.com/fsnotify/fsnotify/pull/419
- @hu13 made their first contribution in https://github.com/fsnotify/fsnotify/pull/361
- @NitroCao made their first contribution in https://github.com/fsnotify/fsnotify/pull/374
Full Changelog: https://github.com/fsnotify/fsnotify/compare/v1.5.1...v1.5.2
v1.5.1: Revert Add AddRaw to not follow symlinks
v1.5.0: Add AddRaw which does not dereference symlinks
- Go: Increase minimum required version to Go 1.12 #381
- Feature: Add
AddRawmethod which does not follow symlinks when adding a watch #289 - Windows: Follow symlinks by default like on all other systems #289
- CI: Use GitHub Actions for CI and cover go 1.12-1.17 #378 #381 #385
- Go 1.14+: Fix unsafe pointer conversion #325
v1.4.9: Move example usage to the readme
v1.4.8: Use close-on-exec
- CI: test more go versions (@nathany
1d13583) - Tests: Queued inotify events could have been read by the test before max_queued_events was hit (@matthias-stone #265)
- Tests: t.Fatalf -> t.Errorf in go routines (@gdey #266)
- CI: Less verbosity (@nathany #267)
- Tests: Darwin: Exchangedata is deprecated on 10.13 (@nathany #267)
- Tests: Check if channels are closed in the example (@alexeykazakov #244)
- CI: Only run golint on latest version of go and fix issues (@cpuguy83 #284)
- CI: Add windows to travis matrix (@cpuguy83 #284)
- Docs: Remover appveyor badge (@nathany
11844c0) - Linux: create epoll and pipe fds with close-on-exec (@JohannesEbke #219)
- Linux: open files with close-on-exec (@linxiulei #273)
- Docs: Plan to support fanotify (@nathany
ab058b4) - Project: Add go.mod (@nathany #309)
- Project: Revise editor config (@nathany #309)
- Project: Update copyright for 2019 (@nathany #309)
- CI: Drop go1.8 from CI matrix (@nathany #309)
- Docs: Updating the FAQ section for supportability with NFS & FUSE filesystems (@Pratik32
4bf2d1f)
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
- [ ] If you want to rebase/retry this PR, check this box
This PR was generated by Mend Renovate. View the repository job log.
[APPROVALNOTIFIER] This PR is NOT APPROVED
This pull-request has been approved by: Once this PR has been reviewed and has the lgtm label, please assign csuzhangxc for approval. For more information see the Code Review Process.
The full list of commands accepted by this bot can be found here.
Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment