nuclei/v2/pkg/workflows/execute_test.go

189 lines
7.4 KiB
Go
Raw Normal View History

package workflows
import (
"testing"
"github.com/projectdiscovery/nuclei/v2/pkg/operators"
"github.com/projectdiscovery/nuclei/v2/pkg/output"
"github.com/projectdiscovery/nuclei/v2/pkg/progress"
"github.com/projectdiscovery/nuclei/v2/pkg/protocols"
2021-02-22 12:19:02 +00:00
"github.com/projectdiscovery/nuclei/v2/pkg/types"
"github.com/stretchr/testify/require"
)
func TestWorkflowsSimple(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
2021-02-26 07:43:11 +00:00
Executer: &mockExecuter{result: true}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.True(t, matched, "could not get correct match value")
}
func TestWorkflowsSimpleMultiple(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
var firstInput, secondInput string
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
firstInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}},
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
secondInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.True(t, matched, "could not get correct match value")
require.Equal(t, "https://test.com", firstInput, "could not get correct first input")
require.Equal(t, "https://test.com", secondInput, "could not get correct second input")
}
func TestWorkflowsSubtemplates(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
var firstInput, secondInput string
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
firstInput = input
}, outputs: []*output.InternalWrappedEvent{
{OperatorsResult: &operators.Result{}, Results: []*output.ResultEvent{{}}},
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}, Subtemplates: []*WorkflowTemplate{{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
secondInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}}}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.True(t, matched, "could not get correct match value")
require.Equal(t, "https://test.com", firstInput, "could not get correct first input")
require.Equal(t, "https://test.com", secondInput, "could not get correct second input")
}
func TestWorkflowsSubtemplatesNoMatch(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
var firstInput, secondInput string
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: false, executeHook: func(input string) {
firstInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}, Subtemplates: []*WorkflowTemplate{{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
secondInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}}}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.False(t, matched, "could not get correct match value")
require.Equal(t, "https://test.com", firstInput, "could not get correct first input")
require.Equal(t, "", secondInput, "could not get correct second input")
}
func TestWorkflowsSubtemplatesWithMatcher(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
var firstInput, secondInput string
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
firstInput = input
}, outputs: []*output.InternalWrappedEvent{
{OperatorsResult: &operators.Result{
Matches: map[string]struct{}{"tomcat": {}},
Extracts: map[string][]string{},
}},
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}, Matchers: []*Matcher{{Name: "tomcat", Subtemplates: []*WorkflowTemplate{{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
secondInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}}}}}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.True(t, matched, "could not get correct match value")
require.Equal(t, "https://test.com", firstInput, "could not get correct first input")
require.Equal(t, "https://test.com", secondInput, "could not get correct second input")
}
func TestWorkflowsSubtemplatesWithMatcherNoMatch(t *testing.T) {
progressBar, _ := progress.NewStatsTicker(0, false, false, false, 0)
2021-01-16 06:56:38 +00:00
var firstInput, secondInput string
2021-02-23 17:25:29 +00:00
workflow := &Workflow{Options: &protocols.ExecuterOptions{Options: &types.Options{TemplateThreads: 10}}, Workflows: []*WorkflowTemplate{
2021-02-04 16:30:09 +00:00
{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
firstInput = input
}, outputs: []*output.InternalWrappedEvent{
{OperatorsResult: &operators.Result{
Matches: map[string]struct{}{"tomcat": {}},
Extracts: map[string][]string{},
}},
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}, Matchers: []*Matcher{{Name: "apache", Subtemplates: []*WorkflowTemplate{{Executers: []*ProtocolExecuterPair{{
Executer: &mockExecuter{result: true, executeHook: func(input string) {
secondInput = input
2021-02-26 07:43:11 +00:00
}}, Options: &protocols.ExecuterOptions{Progress: progressBar}},
2021-02-04 16:30:09 +00:00
}}}}}},
}}
2021-02-22 12:19:02 +00:00
matched := workflow.RunWorkflow("https://test.com")
require.False(t, matched, "could not get correct match value")
require.Equal(t, "https://test.com", firstInput, "could not get correct first input")
require.Equal(t, "", secondInput, "could not get correct second input")
}
type mockExecuter struct {
result bool
executeHook func(input string)
outputs []*output.InternalWrappedEvent
}
// Compile compiles the execution generators preparing any requests possible.
func (m *mockExecuter) Compile() error {
return nil
}
// Requests returns the total number of requests the rule will perform
func (m *mockExecuter) Requests() int {
return 1
}
// Execute executes the protocol group and returns true or false if results were found.
func (m *mockExecuter) Execute(input string) (bool, error) {
if m.executeHook != nil {
m.executeHook(input)
}
return m.result, nil
}
// ExecuteWithResults executes the protocol requests and returns results instead of writing them.
func (m *mockExecuter) ExecuteWithResults(input string, callback protocols.OutputEventCallback) error {
if m.executeHook != nil {
m.executeHook(input)
}
for _, output := range m.outputs {
callback(output)
}
return nil
}