mirror of
				https://github.com/TeaOSLab/EdgeNode.git
				synced 2025-11-04 16:00:25 +08:00 
			
		
		
		
	
		
			
	
	
		
			173 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			173 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								package caches
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import (
							 | 
						||
| 
								 | 
							
									"github.com/iwind/TeaGo/Tea"
							 | 
						||
| 
								 | 
							
									stringutil "github.com/iwind/TeaGo/utils/string"
							 | 
						||
| 
								 | 
							
									"strconv"
							 | 
						||
| 
								 | 
							
									"testing"
							 | 
						||
| 
								 | 
							
									"time"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Init(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Add(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									err = list.Add(stringutil.Md5("123456"), &Item{
							 | 
						||
| 
								 | 
							
										Key:        "123456",
							 | 
						||
| 
								 | 
							
										ExpiredAt:  time.Now().Unix(),
							 | 
						||
| 
								 | 
							
										HeaderSize: 1,
							 | 
						||
| 
								 | 
							
										MetaSize:   2,
							 | 
						||
| 
								 | 
							
										BodySize:   3,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Add_Many(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									for i := 0; i < 100_0000; i++ {
							 | 
						||
| 
								 | 
							
										u := "http://edge.teaos.cn/123456" + strconv.Itoa(i)
							 | 
						||
| 
								 | 
							
										err = list.Add(stringutil.Md5(u), &Item{
							 | 
						||
| 
								 | 
							
											Key:        u,
							 | 
						||
| 
								 | 
							
											ExpiredAt:  time.Now().Unix(),
							 | 
						||
| 
								 | 
							
											HeaderSize: 1,
							 | 
						||
| 
								 | 
							
											MetaSize:   2,
							 | 
						||
| 
								 | 
							
											BodySize:   3,
							 | 
						||
| 
								 | 
							
										})
							 | 
						||
| 
								 | 
							
										if err != nil {
							 | 
						||
| 
								 | 
							
											t.Fatal(err)
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Exist(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									{
							 | 
						||
| 
								 | 
							
										exists, err := list.Exist(stringutil.Md5("123456"))
							 | 
						||
| 
								 | 
							
										if err != nil {
							 | 
						||
| 
								 | 
							
											t.Fatal(err)
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
										t.Log("exists:", exists)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									{
							 | 
						||
| 
								 | 
							
										exists, err := list.Exist(stringutil.Md5("654321"))
							 | 
						||
| 
								 | 
							
										if err != nil {
							 | 
						||
| 
								 | 
							
											t.Fatal(err)
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
										t.Log("exists:", exists)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_FindKeysWithPrefix(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									before := time.Now()
							 | 
						||
| 
								 | 
							
									keys, err := list.FindKeysWithPrefix("1234")
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("keys:", keys)
							 | 
						||
| 
								 | 
							
									t.Log(time.Since(before).Seconds()*1000, "ms")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Remove(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									list.OnRemove(func(item *Item) {
							 | 
						||
| 
								 | 
							
										t.Logf("remove %#v", item)
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									err = list.Remove(stringutil.Md5("123456"))
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Purge(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									err = list.Purge(2, func(hash string) error {
							 | 
						||
| 
								 | 
							
										t.Log(hash)
							 | 
						||
| 
								 | 
							
										return nil
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Stat(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									stat, err := list.Stat(nil)
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("count:", stat.Count, "size:", stat.Size, "valueSize:", stat.ValueSize)
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_Count(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									before := time.Now()
							 | 
						||
| 
								 | 
							
									count, err := list.Count()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("count:", count)
							 | 
						||
| 
								 | 
							
									t.Log(time.Since(before).Seconds()*1000, "ms")
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								func TestFileList_CleanAll(t *testing.T) {
							 | 
						||
| 
								 | 
							
									list := NewFileList(Tea.Root + "/data")
							 | 
						||
| 
								 | 
							
									err := list.Init()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									err = list.CleanAll()
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										t.Fatal(err)
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									t.Log("ok")
							 | 
						||
| 
								 | 
							
									t.Log(list.Count())
							 | 
						||
| 
								 | 
							
								}
							 |