test write
This commit is contained in:
parent
95827a2efe
commit
9b94acad71
111
notify.go
111
notify.go
@ -15,6 +15,12 @@ import (
|
|||||||
"github.com/fsnotify/fsnotify"
|
"github.com/fsnotify/fsnotify"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
createFile = iota
|
||||||
|
writeFile
|
||||||
|
deleteFile
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
var (
|
var (
|
||||||
watcher *fsnotify.Watcher
|
watcher *fsnotify.Watcher
|
||||||
@ -42,10 +48,8 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
sm := new(sync.Map)
|
sm := new(sync.Map)
|
||||||
go createEmptyAndDelete(ctx, sm, time.Second, dir2Watch)
|
go createEmptyAndDelete(ctx, sm, time.Second, time.Second, dir2Watch)
|
||||||
go createEmptyAndDelete(ctx, sm, time.Second+(time.Millisecond*200), dir2Watch)
|
go createWriteAndDelete(ctx, sm, time.Second+(time.Millisecond*100), time.Millisecond*200, dir2Watch)
|
||||||
go createEmptyAndDelete(ctx, sm, time.Second+(time.Millisecond*400), dir2Watch)
|
|
||||||
go createEmptyAndDelete(ctx, sm, time.Second+(time.Millisecond*600), dir2Watch)
|
|
||||||
|
|
||||||
done := make(chan os.Signal, 1)
|
done := make(chan os.Signal, 1)
|
||||||
signal.Notify(done, os.Interrupt, syscall.SIGTERM)
|
signal.Notify(done, os.Interrupt, syscall.SIGTERM)
|
||||||
@ -67,8 +71,8 @@ func watcherFunc(ctx context.Context, watcher *fsnotify.Watcher) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
log.Println("event:", event)
|
log.Println("event:", event)
|
||||||
if event.Has(fsnotify.Create) {
|
if event.Has(fsnotify.Write) {
|
||||||
log.Println("created file:", event.Name)
|
log.Println("written to file:", event.Name)
|
||||||
}
|
}
|
||||||
case err, ok := <-watcher.Errors:
|
case err, ok := <-watcher.Errors:
|
||||||
if !ok {
|
if !ok {
|
||||||
@ -126,24 +130,20 @@ func genRandomString(len uint) string {
|
|||||||
return string(b)
|
return string(b)
|
||||||
}
|
}
|
||||||
|
|
||||||
func createEmptyAndDelete(ctx context.Context, sm *sync.Map, initialWait time.Duration, dir string) {
|
func createEmptyAndDelete(ctx context.Context, sm *sync.Map, initialWait time.Duration, iterWait time.Duration, dir string) {
|
||||||
if initialWait < 0 {
|
if initialWait < 0 {
|
||||||
log.Println("initialWait cannot be less than 0")
|
log.Println("initialWait cannot be less than 0")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if iterWait < 0 {
|
||||||
|
log.Println("iterWait cannot be less than 0")
|
||||||
|
}
|
||||||
|
|
||||||
tick := time.NewTicker(initialWait)
|
tick := time.NewTicker(initialWait)
|
||||||
defer tick.Stop()
|
defer tick.Stop()
|
||||||
|
|
||||||
const (
|
|
||||||
createFile = iota
|
|
||||||
deleteFile
|
|
||||||
|
|
||||||
iterWait time.Duration = time.Second
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
next int = createFile
|
next = createFile
|
||||||
nextFileName string
|
nextFileName string
|
||||||
nextFile string
|
nextFile string
|
||||||
f *os.File
|
f *os.File
|
||||||
@ -157,8 +157,8 @@ func createEmptyAndDelete(ctx context.Context, sm *sync.Map, initialWait time.Du
|
|||||||
select {
|
select {
|
||||||
case <-tick.C:
|
case <-tick.C:
|
||||||
tick.Stop()
|
tick.Stop()
|
||||||
switch next {
|
switch {
|
||||||
case createFile:
|
case next == createFile:
|
||||||
nextFileName = filepath.Join(dir, nextFileName)
|
nextFileName = filepath.Join(dir, nextFileName)
|
||||||
log.Printf("creating file: %s\n", nextFileName)
|
log.Printf("creating file: %s\n", nextFileName)
|
||||||
if f, err = os.OpenFile(nextFileName, os.O_WRONLY|os.O_CREATE|os.O_EXCL, 0666); err != nil {
|
if f, err = os.OpenFile(nextFileName, os.O_WRONLY|os.O_CREATE|os.O_EXCL, 0666); err != nil {
|
||||||
@ -167,8 +167,81 @@ func createEmptyAndDelete(ctx context.Context, sm *sync.Map, initialWait time.Du
|
|||||||
}
|
}
|
||||||
_ = f.Close()
|
_ = f.Close()
|
||||||
next = deleteFile
|
next = deleteFile
|
||||||
case deleteFile:
|
case next == deleteFile:
|
||||||
log.Printf("deleting file: %s\n", nextFileName)
|
if err = os.Remove(nextFileName); err != nil {
|
||||||
|
log.Printf("Error deleting file %s: %+v\n", nextFileName, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
next = createFile
|
||||||
|
|
||||||
|
sm.Delete(nextFile)
|
||||||
|
nextFile = genUniqueRandomString(sm, 6)
|
||||||
|
nextFileName = nextFile + ".txt"
|
||||||
|
}
|
||||||
|
tick.Reset(iterWait)
|
||||||
|
case <-ctx.Done():
|
||||||
|
if next == deleteFile {
|
||||||
|
_ = os.Remove(nextFileName)
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func createWriteAndDelete(ctx context.Context, sm *sync.Map, initialWait time.Duration, iterWait time.Duration, dir string) {
|
||||||
|
if initialWait < 0 {
|
||||||
|
log.Println("initialWait cannot be less than 0")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if iterWait < 0 {
|
||||||
|
log.Println("iterWait cannot be less than 0")
|
||||||
|
}
|
||||||
|
|
||||||
|
tick := time.NewTicker(initialWait)
|
||||||
|
defer tick.Stop()
|
||||||
|
|
||||||
|
var (
|
||||||
|
next = createFile
|
||||||
|
nextFileName string
|
||||||
|
nextFile string
|
||||||
|
f *os.File
|
||||||
|
err error
|
||||||
|
currLen int64
|
||||||
|
wLen int
|
||||||
|
)
|
||||||
|
|
||||||
|
targetLen := rand.Int63n(1024*1024) + 102400
|
||||||
|
nextFile = genUniqueRandomString(sm, 6)
|
||||||
|
nextFileName = nextFile + ".txt"
|
||||||
|
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-tick.C:
|
||||||
|
tick.Stop()
|
||||||
|
switch {
|
||||||
|
case next == createFile:
|
||||||
|
nextFileName = filepath.Join(dir, nextFileName)
|
||||||
|
log.Printf("creating file: %s\n", nextFileName)
|
||||||
|
if f, err = os.OpenFile(nextFileName, os.O_WRONLY|os.O_CREATE|os.O_EXCL, 0666); err != nil {
|
||||||
|
log.Printf("Error creating file %s: %+v\n", nextFileName, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
next = writeFile
|
||||||
|
case next == writeFile:
|
||||||
|
if wLen, err = f.WriteString(genRandomString(1024)); err != nil {
|
||||||
|
log.Printf("Error writing file %s: %+v\n", nextFileName, err)
|
||||||
|
_ = f.Close()
|
||||||
|
_ = os.Remove(nextFileName)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Printf("written %d bytes to %s\n", wLen, nextFileName)
|
||||||
|
currLen += int64(wLen)
|
||||||
|
if currLen > targetLen {
|
||||||
|
_ = f.Close()
|
||||||
|
next = deleteFile
|
||||||
|
}
|
||||||
|
case next == deleteFile:
|
||||||
if err = os.Remove(nextFileName); err != nil {
|
if err = os.Remove(nextFileName); err != nil {
|
||||||
log.Printf("Error deleting file %s: %+v\n", nextFileName, err)
|
log.Printf("Error deleting file %s: %+v\n", nextFileName, err)
|
||||||
return
|
return
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user