mirror of
https://github.com/projectdiscovery/nuclei.git
synced 2025-12-17 21:45:26 +00:00
* feat: added fuzzing output enhancements * changes as requested * misc * feat: added dfp flag to display fuzz points + misc additions * feat: added support for fuzzing nested path segments * feat: added parts to fuzzing requests * feat: added tracking for parameter occurence frequency in fuzzing * added cli flag for fuzz frequency * fixed broken tests * fixed path based sqli integration test * feat: added configurable fuzzing aggression level for payloads * fixed failing test
40 lines
1.2 KiB
Go
40 lines
1.2 KiB
Go
package fuzz
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestRuleMatchKeyOrValue(t *testing.T) {
|
|
rule := &Rule{
|
|
Part: "query",
|
|
}
|
|
err := rule.Compile(nil, nil)
|
|
require.NoError(t, err, "could not compile rule")
|
|
|
|
result := rule.matchKeyOrValue("url", "")
|
|
require.True(t, result, "could not get correct result")
|
|
|
|
t.Run("key", func(t *testing.T) {
|
|
rule := &Rule{Keys: []string{"url"}, Part: "query"}
|
|
err := rule.Compile(nil, nil)
|
|
require.NoError(t, err, "could not compile rule")
|
|
|
|
result := rule.matchKeyOrValue("url", "")
|
|
require.True(t, result, "could not get correct result")
|
|
result = rule.matchKeyOrValue("test", "")
|
|
require.False(t, result, "could not get correct result")
|
|
})
|
|
t.Run("value", func(t *testing.T) {
|
|
rule := &Rule{ValuesRegex: []string{`https?:\/\/?([-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,6}\b)*(\/[\/\d\w\.-]*)*(?:[\?])*(.+)*`}, Part: "query"}
|
|
err := rule.Compile(nil, nil)
|
|
require.NoError(t, err, "could not compile rule")
|
|
|
|
result := rule.matchKeyOrValue("", "http://localhost:80")
|
|
require.True(t, result, "could not get correct result")
|
|
result = rule.matchKeyOrValue("test", "random")
|
|
require.False(t, result, "could not get correct result")
|
|
})
|
|
}
|