mirror of
				https://github.com/TeaOSLab/EdgeNode.git
				synced 2025-11-04 07:40:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package iplibrary
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/firewallconfigs"
 | 
						|
	executils "github.com/TeaOSLab/EdgeNode/internal/utils/exec"
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
func TestIPTablesAction_AddItem(t *testing.T) {
 | 
						|
	_, lookupErr := executils.LookPath("iptables")
 | 
						|
	if lookupErr != nil {
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	var action = NewIPTablesAction()
 | 
						|
	action.config = &firewallconfigs.FirewallActionIPTablesConfig{
 | 
						|
		Path: "/usr/bin/iptables",
 | 
						|
	}
 | 
						|
	{
 | 
						|
		err := action.AddItem(IPListTypeWhite, &pb.IPItem{
 | 
						|
			Type:      "ipv4",
 | 
						|
			Id:        1,
 | 
						|
			IpFrom:    "192.168.1.100",
 | 
						|
			ExpiredAt: time.Now().Unix() + 30,
 | 
						|
		})
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		t.Log("ok")
 | 
						|
	}
 | 
						|
 | 
						|
	{
 | 
						|
		err := action.AddItem(IPListTypeBlack, &pb.IPItem{
 | 
						|
			Type:      "ipv4",
 | 
						|
			Id:        1,
 | 
						|
			IpFrom:    "192.168.1.100",
 | 
						|
			ExpiredAt: time.Now().Unix() + 30,
 | 
						|
		})
 | 
						|
		if err != nil {
 | 
						|
			t.Fatal(err)
 | 
						|
		}
 | 
						|
		t.Log("ok")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestIPTablesAction_DeleteItem(t *testing.T) {
 | 
						|
	_, lookupErr := executils.LookPath("firewalld")
 | 
						|
	if lookupErr != nil {
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	var action = NewIPTablesAction()
 | 
						|
	action.config = &firewallconfigs.FirewallActionIPTablesConfig{
 | 
						|
		Path: "/usr/bin/firewalld",
 | 
						|
	}
 | 
						|
	err := action.DeleteItem(IPListTypeWhite, &pb.IPItem{
 | 
						|
		Type:      "ipv4",
 | 
						|
		Id:        1,
 | 
						|
		IpFrom:    "192.168.1.100",
 | 
						|
		ExpiredAt: time.Now().Unix() + 30,
 | 
						|
	})
 | 
						|
	if err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	t.Log("ok")
 | 
						|
}
 |