mirror of
https://gitee.com/johng/gf.git
synced 2024-12-02 04:07:47 +08:00
325 lines
8.0 KiB
Go
325 lines
8.0 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with this file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
package gfpool_test
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/gogf/gf/v2/os/gfile"
|
|
"github.com/gogf/gf/v2/os/gfpool"
|
|
"github.com/gogf/gf/v2/os/glog"
|
|
"github.com/gogf/gf/v2/os/gtime"
|
|
"github.com/gogf/gf/v2/test/gtest"
|
|
"github.com/gogf/gf/v2/text/gstr"
|
|
)
|
|
|
|
// TestOpen test open file cache
|
|
func TestOpen(t *testing.T) {
|
|
testFile := start("TestOpen.txt")
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
f, err := gfpool.Open(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertEQ(err, nil)
|
|
f.Close()
|
|
|
|
f2, err1 := gfpool.Open(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertEQ(err1, nil)
|
|
t.AssertEQ(f, f2)
|
|
f2.Close()
|
|
})
|
|
|
|
stop(testFile)
|
|
}
|
|
|
|
// TestOpenErr test open file error
|
|
func TestOpenErr(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
testErrFile := "errorPath"
|
|
_, err := gfpool.Open(testErrFile, os.O_RDWR, 0666)
|
|
t.AssertNE(err, nil)
|
|
|
|
// delete file error
|
|
testFile := start("TestOpenDeleteErr.txt")
|
|
pool := gfpool.New(testFile, os.O_RDWR, 0666)
|
|
_, err1 := pool.File()
|
|
t.AssertEQ(err1, nil)
|
|
stop(testFile)
|
|
_, err1 = pool.File()
|
|
t.AssertNE(err1, nil)
|
|
|
|
// append mode delete file error and create again
|
|
testFile = start("TestOpenCreateErr.txt")
|
|
pool = gfpool.New(testFile, os.O_CREATE, 0666)
|
|
_, err1 = pool.File()
|
|
t.AssertEQ(err1, nil)
|
|
stop(testFile)
|
|
_, err1 = pool.File()
|
|
t.AssertEQ(err1, nil)
|
|
|
|
// append mode delete file error
|
|
testFile = start("TestOpenAppendErr.txt")
|
|
pool = gfpool.New(testFile, os.O_APPEND, 0666)
|
|
_, err1 = pool.File()
|
|
t.AssertEQ(err1, nil)
|
|
stop(testFile)
|
|
_, err1 = pool.File()
|
|
t.AssertNE(err1, nil)
|
|
|
|
// trunc mode delete file error
|
|
testFile = start("TestOpenTruncErr.txt")
|
|
pool = gfpool.New(testFile, os.O_TRUNC, 0666)
|
|
_, err1 = pool.File()
|
|
t.AssertEQ(err1, nil)
|
|
stop(testFile)
|
|
_, err1 = pool.File()
|
|
t.AssertNE(err1, nil)
|
|
})
|
|
}
|
|
|
|
// TestOpenExpire test open file cache expire
|
|
func TestOpenExpire(t *testing.T) {
|
|
testFile := start("TestOpenExpire.txt")
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
f, err := gfpool.Open(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666, 100*time.Millisecond)
|
|
t.AssertEQ(err, nil)
|
|
f.Close()
|
|
|
|
time.Sleep(150 * time.Millisecond)
|
|
f2, err1 := gfpool.Open(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666, 100*time.Millisecond)
|
|
t.AssertEQ(err1, nil)
|
|
//t.AssertNE(f, f2)
|
|
f2.Close()
|
|
})
|
|
|
|
stop(testFile)
|
|
}
|
|
|
|
// TestNewPool test gfpool new function
|
|
func TestNewPool(t *testing.T) {
|
|
testFile := start("TestNewPool.txt")
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
f, err := gfpool.Open(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertEQ(err, nil)
|
|
f.Close()
|
|
|
|
pool := gfpool.New(testFile, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
f2, err1 := pool.File()
|
|
// pool not equal
|
|
t.AssertEQ(err1, nil)
|
|
//t.AssertNE(f, f2)
|
|
f2.Close()
|
|
|
|
pool.Close()
|
|
})
|
|
|
|
stop(testFile)
|
|
}
|
|
|
|
// test before
|
|
func start(name string) string {
|
|
testFile := os.TempDir() + string(os.PathSeparator) + name
|
|
if gfile.Exists(testFile) {
|
|
gfile.Remove(testFile)
|
|
}
|
|
content := "123"
|
|
gfile.PutContents(testFile, content)
|
|
return testFile
|
|
}
|
|
|
|
// test after
|
|
func stop(testFile string) {
|
|
if gfile.Exists(testFile) {
|
|
err := gfile.Remove(testFile)
|
|
if err != nil {
|
|
glog.Error(context.TODO(), err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func Test_ConcurrentOS(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
path := gfile.Temp(gtime.TimestampNanoStr())
|
|
defer gfile.Remove(path)
|
|
f1, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f1.Close()
|
|
|
|
f2, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f2.Close()
|
|
|
|
for i := 0; i < 100; i++ {
|
|
_, err = f1.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
for i := 0; i < 100; i++ {
|
|
_, err = f2.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f1.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f2.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2200)
|
|
})
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
path := gfile.Temp(gtime.TimestampNanoStr())
|
|
defer gfile.Remove(path)
|
|
f1, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f1.Close()
|
|
|
|
f2, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f2.Close()
|
|
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f1.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f2.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2000)
|
|
})
|
|
gtest.C(t, func(t *gtest.T) {
|
|
path := gfile.Temp(gtime.TimestampNanoStr())
|
|
defer gfile.Remove(path)
|
|
f1, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f1.Close()
|
|
|
|
f2, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f2.Close()
|
|
|
|
s1 := ""
|
|
for i := 0; i < 1000; i++ {
|
|
s1 += "@1234567890#"
|
|
}
|
|
_, err = f2.Write([]byte(s1))
|
|
t.AssertNil(err)
|
|
|
|
s2 := ""
|
|
for i := 0; i < 1000; i++ {
|
|
s2 += "@1234567890#"
|
|
}
|
|
_, err = f2.Write([]byte(s2))
|
|
t.AssertNil(err)
|
|
|
|
t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2000)
|
|
})
|
|
// DATA RACE
|
|
// gtest.C(t, func(t *gtest.T) {
|
|
// path := gfile.Temp(gtime.TimestampNanoStr())
|
|
// defer gfile.Remove(path)
|
|
// f1, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
// t.AssertNil(err)
|
|
// defer f1.Close()
|
|
//
|
|
// f2, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
// t.AssertNil(err)
|
|
// defer f2.Close()
|
|
//
|
|
// wg := sync.WaitGroup{}
|
|
// ch := make(chan struct{})
|
|
// for i := 0; i < 1000; i++ {
|
|
// wg.Add(1)
|
|
// go func() {
|
|
// defer wg.Done()
|
|
// <-ch
|
|
// _, err = f1.Write([]byte("@1234567890#"))
|
|
// t.AssertNil(err)
|
|
// }()
|
|
// }
|
|
// for i := 0; i < 1000; i++ {
|
|
// wg.Add(1)
|
|
// go func() {
|
|
// defer wg.Done()
|
|
// <-ch
|
|
// _, err = f2.Write([]byte("@1234567890#"))
|
|
// t.AssertNil(err)
|
|
// }()
|
|
// }
|
|
// close(ch)
|
|
// wg.Wait()
|
|
// t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2000)
|
|
// })
|
|
}
|
|
|
|
func Test_ConcurrentGFPool(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
path := gfile.Temp(gtime.TimestampNanoStr())
|
|
defer gfile.Remove(path)
|
|
f1, err := gfpool.Open(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f1.Close()
|
|
|
|
f2, err := gfpool.Open(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
t.AssertNil(err)
|
|
defer f2.Close()
|
|
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f1.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
for i := 0; i < 1000; i++ {
|
|
_, err = f2.Write([]byte("@1234567890#"))
|
|
t.AssertNil(err)
|
|
}
|
|
t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2000)
|
|
})
|
|
// DATA RACE
|
|
// gtest.C(t, func(t *gtest.T) {
|
|
// path := gfile.Temp(gtime.TimestampNanoStr())
|
|
// defer gfile.Remove(path)
|
|
// f1, err := gfpool.Open(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
// t.AssertNil(err)
|
|
// defer f1.Close()
|
|
//
|
|
// f2, err := gfpool.Open(path, os.O_RDWR|os.O_CREATE|os.O_TRUNC|os.O_APPEND, 0666)
|
|
// t.AssertNil(err)
|
|
// defer f2.Close()
|
|
//
|
|
// wg := sync.WaitGroup{}
|
|
// ch := make(chan struct{})
|
|
// for i := 0; i < 1000; i++ {
|
|
// wg.Add(1)
|
|
// go func() {
|
|
// defer wg.Done()
|
|
// <-ch
|
|
// _, err = f1.Write([]byte("@1234567890#"))
|
|
// t.AssertNil(err)
|
|
// }()
|
|
// }
|
|
// for i := 0; i < 1000; i++ {
|
|
// wg.Add(1)
|
|
// go func() {
|
|
// defer wg.Done()
|
|
// <-ch
|
|
// _, err = f2.Write([]byte("@1234567890#"))
|
|
// t.AssertNil(err)
|
|
// }()
|
|
// }
|
|
// close(ch)
|
|
// wg.Wait()
|
|
// t.Assert(gstr.Count(gfile.GetContents(path), "@1234567890#"), 2000)
|
|
// })
|
|
}
|