149 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package processor_test
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	lua "github.com/yuin/gopher-lua"
 | |
| 
 | |
| 	"cook/processor"
 | |
| )
 | |
| 
 | |
| // Happy Path: Function correctly returns all regex capture groups as Lua table when given valid pattern and input.
 | |
| func TestEvalRegex_CaptureGroupsReturned(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	pattern := `(\w+)-(\d+)`
 | |
| 	input := "test-42"
 | |
| 	L.Push(lua.LString(pattern))
 | |
| 	L.Push(lua.LString(input))
 | |
| 
 | |
| 	result := processor.EvalRegex(L)
 | |
| 
 | |
| 	assert.Equal(t, 1, result, "Expected return value to be 1 (one value pushed to Lua stack)")
 | |
| 
 | |
| 	out := L.Get(-1)
 | |
| 	tbl, ok := out.(*lua.LTable)
 | |
| 	if !ok {
 | |
| 		t.Fatalf("Expected Lua table, got %T", out)
 | |
| 	}
 | |
| 	expected := []string{"test-42", "test", "42"}
 | |
| 	for i, v := range expected {
 | |
| 		val := tbl.RawGetString(fmt.Sprintf("%d", i))
 | |
| 		assert.Equal(t, lua.LString(v), val, "Expected index %d to be %q", i, v)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Happy Path: Function returns nil when regex pattern does not match input string.
 | |
| func TestEvalRegex_NoMatchReturnsNil(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	L.Push(lua.LString(`(foo)(bar)`))
 | |
| 	L.Push(lua.LString("no-match-here"))
 | |
| 
 | |
| 	result := processor.EvalRegex(L)
 | |
| 	assert.Equal(t, 1, result, "Expected return value to be 1 (one value pushed to Lua stack)")
 | |
| 
 | |
| 	out := L.Get(-1)
 | |
| 	// Should be nil when no matches found
 | |
| 	assert.Equal(t, lua.LNil, out, "Expected nil when no matches found")
 | |
| }
 | |
| 
 | |
| // Happy Path: Function handles patterns with no capture groups by returning the full match in the Lua table.
 | |
| func TestEvalRegex_NoCaptureGroups(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	pattern := `foo\d+`
 | |
| 	input := "foo123"
 | |
| 	L.Push(lua.LString(pattern))
 | |
| 	L.Push(lua.LString(input))
 | |
| 
 | |
| 	result := processor.EvalRegex(L)
 | |
| 	assert.Equal(t, 1, result, "Expected return value to be 1 (one value pushed to Lua stack)")
 | |
| 
 | |
| 	out := L.Get(-1)
 | |
| 	tbl, ok := out.(*lua.LTable)
 | |
| 	if !ok {
 | |
| 		t.Fatalf("Expected Lua table, got %T", out)
 | |
| 	}
 | |
| 	fullMatch := tbl.RawGetString("0")
 | |
| 	assert.Equal(t, lua.LString("foo123"), fullMatch)
 | |
| 	// There should be only the full match (index 0)
 | |
| 	count := 0
 | |
| 	tbl.ForEach(func(k, v lua.LValue) {
 | |
| 		count++
 | |
| 	})
 | |
| 	assert.Equal(t, 1, count)
 | |
| }
 | |
| 
 | |
| // Edge Case: Function handles invalid regex pattern by letting regexp.MustCompile panic (which is expected behavior)
 | |
| func TestEvalRegex_InvalidPattern(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	pattern := `([a-z` // invalid regex
 | |
| 	L.Push(lua.LString(pattern))
 | |
| 	L.Push(lua.LString("someinput"))
 | |
| 
 | |
| 	// This should panic due to invalid regex pattern
 | |
| 	assert.Panics(t, func() {
 | |
| 		processor.EvalRegex(L)
 | |
| 	}, "Expected panic for invalid regex pattern")
 | |
| }
 | |
| 
 | |
| // Edge Case: Function returns nil when input string is empty and pattern doesn't match.
 | |
| func TestEvalRegex_EmptyInputString(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	L.Push(lua.LString(`(foo)`))
 | |
| 	L.Push(lua.LString(""))
 | |
| 
 | |
| 	result := processor.EvalRegex(L)
 | |
| 	assert.Equal(t, 1, result, "Expected return value to be 1 (one value pushed to Lua stack)")
 | |
| 
 | |
| 	out := L.Get(-1)
 | |
| 	// Should be nil when no matches found
 | |
| 	assert.Equal(t, lua.LNil, out, "Expected nil when input is empty and pattern doesn't match")
 | |
| }
 | |
| 
 | |
| // Edge Case: Function handles nil or missing arguments gracefully without causing a runtime panic.
 | |
| func TestEvalRegex_MissingArguments(t *testing.T) {
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	defer func() {
 | |
| 		if r := recover(); r != nil {
 | |
| 			t.Errorf("Did not expect panic when arguments are missing, got: %v", r)
 | |
| 		}
 | |
| 	}()
 | |
| 	// No arguments pushed at all
 | |
| 	processor.EvalRegex(L)
 | |
| 	// Should just not match anything or produce empty table, but must not panic
 | |
| }
 | |
| 
 | |
| func TestEvalComplexRegex(t *testing.T) {
 | |
| 	// Test complex regex pattern with multiple capture groups
 | |
| 	L := lua.NewState()
 | |
| 	defer L.Close()
 | |
| 	pattern := `^((Bulk_)?(Pistol|Rifle).*?Round.*?)$`
 | |
| 	input := "Pistol_Round"
 | |
| 	L.Push(lua.LString(pattern))
 | |
| 	L.Push(lua.LString(input))
 | |
| 
 | |
| 	processor.EvalRegex(L)
 | |
| 
 | |
| 	out := L.Get(-1)
 | |
| 	tbl, ok := out.(*lua.LTable)
 | |
| 	if !ok {
 | |
| 		t.Fatalf("Expected Lua table, got %T", out)
 | |
| 	}
 | |
| 
 | |
| 	// Pattern should match: ["Pistol_Round", "Pistol_Round", "", "Pistol"]
 | |
| 	// This creates 4 elements in the matches array, not 1
 | |
| 	expectedCount := 4
 | |
| 	actualCount := 0
 | |
| 	tbl.ForEach(func(k, v lua.LValue) {
 | |
| 		actualCount++
 | |
| 	})
 | |
| 	assert.Equal(t, expectedCount, actualCount, "Expected %d matches for pattern %q with input %q", expectedCount, pattern, input)
 | |
| }
 |