mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 16:00:24 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			160 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2022 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
 | 
						|
 | 
						|
package models_test
 | 
						|
 | 
						|
import (
 | 
						|
	"encoding/json"
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/db/models"
 | 
						|
	"github.com/iwind/TeaGo/dbs"
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
func TestNewHTTPAccessLogManager(t *testing.T) {
 | 
						|
	var config = &dbs.DBConfig{
 | 
						|
		Driver: "mysql",
 | 
						|
		Dsn:    "root:123456@tcp(127.0.0.1:3306)/db_edge_log?charset=utf8mb4&timeout=30s",
 | 
						|
		Prefix: "edge",
 | 
						|
		Connections: struct {
 | 
						|
			Pool         int           `yaml:"pool"`
 | 
						|
			Max          int           `yaml:"max"`
 | 
						|
			Life         string        `yaml:"life"`
 | 
						|
			LifeDuration time.Duration `yaml:",omitempty"`
 | 
						|
		}{},
 | 
						|
		Models: struct {
 | 
						|
			Package string `yaml:"package"`
 | 
						|
		}{},
 | 
						|
	}
 | 
						|
 | 
						|
	db, err := dbs.NewInstanceFromConfig(config)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer func() {
 | 
						|
		_ = db.Close()
 | 
						|
	}()
 | 
						|
 | 
						|
	var manager = models.SharedHTTPAccessLogManager
 | 
						|
	err = manager.CreateTable(db, "accessLog_1")
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestHTTPAccessLogManager_FindTableNames(t *testing.T) {
 | 
						|
	var config = &dbs.DBConfig{
 | 
						|
		Driver: "mysql",
 | 
						|
		Dsn:    "root:123456@tcp(127.0.0.1:3306)/db_edge_log?charset=utf8mb4&timeout=30s",
 | 
						|
		Prefix: "edge",
 | 
						|
		Connections: struct {
 | 
						|
			Pool         int           `yaml:"pool"`
 | 
						|
			Max          int           `yaml:"max"`
 | 
						|
			Life         string        `yaml:"life"`
 | 
						|
			LifeDuration time.Duration `yaml:",omitempty"`
 | 
						|
		}{},
 | 
						|
		Models: struct {
 | 
						|
			Package string `yaml:"package"`
 | 
						|
		}{},
 | 
						|
	}
 | 
						|
 | 
						|
	db, err := dbs.NewInstanceFromConfig(config)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer func() {
 | 
						|
		_ = db.Close()
 | 
						|
	}()
 | 
						|
 | 
						|
	for i := 0; i < 3; i++ {
 | 
						|
		var before = time.Now()
 | 
						|
		tables, err := models.SharedHTTPAccessLogManager.FindTables(db, "20220306")
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		data, err := json.Marshal(tables)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		t.Log(string(data))
 | 
						|
		t.Log(time.Since(before).Seconds()*1000, "ms")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestHTTPAccessLogManager_FindTables(t *testing.T) {
 | 
						|
	var config = &dbs.DBConfig{
 | 
						|
		Driver: "mysql",
 | 
						|
		Dsn:    "root:123456@tcp(127.0.0.1:3306)/db_edge_log?charset=utf8mb4&timeout=30s",
 | 
						|
		Prefix: "edge",
 | 
						|
		Connections: struct {
 | 
						|
			Pool         int           `yaml:"pool"`
 | 
						|
			Max          int           `yaml:"max"`
 | 
						|
			Life         string        `yaml:"life"`
 | 
						|
			LifeDuration time.Duration `yaml:",omitempty"`
 | 
						|
		}{},
 | 
						|
		Models: struct {
 | 
						|
			Package string `yaml:"package"`
 | 
						|
		}{},
 | 
						|
	}
 | 
						|
 | 
						|
	db, err := dbs.NewInstanceFromConfig(config)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer func() {
 | 
						|
		_ = db.Close()
 | 
						|
	}()
 | 
						|
 | 
						|
	for i := 0; i < 3; i++ {
 | 
						|
		var before = time.Now()
 | 
						|
		tables, err := models.SharedHTTPAccessLogManager.FindTables(db, "20220306")
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		data, err := json.Marshal(tables)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		t.Log(string(data))
 | 
						|
		t.Log(time.Since(before).Seconds()*1000, "ms")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestHTTPAccessLogManager_FindTable(t *testing.T) {
 | 
						|
	var config = &dbs.DBConfig{
 | 
						|
		Driver: "mysql",
 | 
						|
		Dsn:    "root:123456@tcp(127.0.0.1:3306)/db_edge_log?charset=utf8mb4&timeout=30s",
 | 
						|
		Prefix: "edge",
 | 
						|
		Connections: struct {
 | 
						|
			Pool         int           `yaml:"pool"`
 | 
						|
			Max          int           `yaml:"max"`
 | 
						|
			Life         string        `yaml:"life"`
 | 
						|
			LifeDuration time.Duration `yaml:",omitempty"`
 | 
						|
		}{},
 | 
						|
		Models: struct {
 | 
						|
			Package string `yaml:"package"`
 | 
						|
		}{},
 | 
						|
	}
 | 
						|
 | 
						|
	db, err := dbs.NewInstanceFromConfig(config)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	defer func() {
 | 
						|
		_ = db.Close()
 | 
						|
	}()
 | 
						|
 | 
						|
	for i := 0; i < 3; i++ {
 | 
						|
		var before = time.Now()
 | 
						|
		tableDef, err := models.SharedHTTPAccessLogManager.FindTable(db, "20220306", false)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		data, err := json.Marshal(tableDef)
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		t.Log(string(data))
 | 
						|
		t.Log(time.Since(before).Seconds()*1000, "ms")
 | 
						|
	}
 | 
						|
}
 |