mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 07:43:03 +08:00 
			
		
		
		
	支持阿里云DNS
This commit is contained in:
		
							
								
								
									
										110
									
								
								internal/dnsclients/provider_dnspod_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								internal/dnsclients/provider_dnspod_test.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,110 @@
 | 
			
		||||
package dnsclients
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"github.com/iwind/TeaGo/dbs"
 | 
			
		||||
	"github.com/iwind/TeaGo/logs"
 | 
			
		||||
	"github.com/iwind/TeaGo/maps"
 | 
			
		||||
	"testing"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func TestDNSPodProvider_GetRoutes(t *testing.T) {
 | 
			
		||||
	provider, err := testDNSPodProvider()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	routes, err := provider.GetRoutes("yun4s.cn")
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	logs.PrintAsJSON(routes, t)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestDNSPodProvider_GetRecords(t *testing.T) {
 | 
			
		||||
	provider, err := testDNSPodProvider()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	records, err := provider.GetRecords("yun4s.cn")
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	for _, record := range records {
 | 
			
		||||
		t.Log(record.Id, record.Type, record.Name, record.Value, record.Route)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestDNSPodProvider_AddRecord(t *testing.T) {
 | 
			
		||||
	provider, err := testDNSPodProvider()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	err = provider.AddRecord("yun4s.cn", &Record{
 | 
			
		||||
		Type:  RecordTypeCName,
 | 
			
		||||
		Name:  "hello-forward",
 | 
			
		||||
		Value: "hello.yun4s.cn",
 | 
			
		||||
		Route: "联通",
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	t.Log("ok")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestDNSPodProvider_UpdateRecord(t *testing.T) {
 | 
			
		||||
	provider, err := testDNSPodProvider()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	err = provider.UpdateRecord("yun4s.cn", &Record{
 | 
			
		||||
		Id: "697036856",
 | 
			
		||||
	}, &Record{
 | 
			
		||||
		Type:  RecordTypeA,
 | 
			
		||||
		Name:  "hello",
 | 
			
		||||
		Value: "192.168.1.102",
 | 
			
		||||
		Route: "联通",
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	t.Log("ok")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestDNSPodProvider_DeleteRecord(t *testing.T) {
 | 
			
		||||
	provider, err := testDNSPodProvider()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	err = provider.DeleteRecord("yun4s.cn", &Record{
 | 
			
		||||
		Id: "697040986",
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	t.Log("ok")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func testDNSPodProvider() (ProviderInterface, error) {
 | 
			
		||||
	db, err := dbs.Default()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	one, err := db.FindOne("SELECT * FROM edgeDNSProviders WHERE type='dnspod' ORDER BY id DESC")
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	apiParams := maps.Map{}
 | 
			
		||||
	err = json.Unmarshal([]byte(one.GetString("apiParams")), &apiParams)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	provider := &DNSPodProvider{}
 | 
			
		||||
	err = provider.Auth(apiParams)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return provider, nil
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user