nuclei/pkg/protocols/dns/request_test.go

72 lines
2.7 KiB
Go
Raw Normal View History

2021-02-03 02:09:45 +05:30
package dns
import (
"context"
2021-02-03 02:09:45 +05:30
"testing"
"github.com/stretchr/testify/require"
"github.com/projectdiscovery/nuclei/v3/pkg/model"
"github.com/projectdiscovery/nuclei/v3/pkg/model/types/severity"
"github.com/projectdiscovery/nuclei/v3/pkg/operators"
"github.com/projectdiscovery/nuclei/v3/pkg/operators/extractors"
"github.com/projectdiscovery/nuclei/v3/pkg/operators/matchers"
"github.com/projectdiscovery/nuclei/v3/pkg/output"
"github.com/projectdiscovery/nuclei/v3/pkg/protocols/common/contextargs"
"github.com/projectdiscovery/nuclei/v3/pkg/testutils"
2021-02-03 02:09:45 +05:30
)
func TestDNSExecuteWithResults(t *testing.T) {
options := testutils.DefaultOptions
2021-11-23 13:09:22 +05:30
recursion := false
2021-02-03 02:09:45 +05:30
testutils.Init(options)
templateID := "testing-dns"
executerOpts := testutils.NewMockExecuterOptions(options, &testutils.TemplateInfo{
ID: templateID,
Info: model.Info{SeverityHolder: severity.Holder{Severity: severity.Low}, Name: "test"},
})
2021-02-03 02:09:45 +05:30
request := &Request{
RequestType: DNSRequestTypeHolder{DNSRequestType: A},
Class: "INET",
Retries: 5,
ID: templateID,
2021-11-23 13:09:22 +05:30
Recursion: &recursion,
Name: "{{FQDN}}",
2021-02-03 02:09:45 +05:30
Operators: operators.Operators{
2021-02-03 17:49:10 +05:30
Matchers: []*matchers.Matcher{{
Name: "test",
Part: "raw",
Type: matchers.MatcherTypeHolder{MatcherType: matchers.WordsMatcher},
2024-04-24 16:19:39 +03:00
Words: []string{"93.184.215.14"},
2021-02-03 17:49:10 +05:30
}},
Extractors: []*extractors.Extractor{{
Part: "raw",
Type: extractors.ExtractorTypeHolder{ExtractorType: extractors.RegexExtractor},
2021-02-03 17:49:10 +05:30
Regex: []string{"[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+"},
}},
2021-02-03 02:09:45 +05:30
},
options: executerOpts,
2021-02-03 02:09:45 +05:30
}
err := request.Compile(executerOpts)
require.Nil(t, err, "could not compile dns request")
var finalEvent *output.InternalWrappedEvent
t.Run("domain-valid", func(t *testing.T) {
metadata := make(output.InternalEvent)
previous := make(output.InternalEvent)
ctxArgs := contextargs.NewWithInput(context.Background(), "example.com")
err := request.ExecuteWithResults(ctxArgs, metadata, previous, func(event *output.InternalWrappedEvent) {
2021-02-03 02:09:45 +05:30
finalEvent = event
})
require.Nil(t, err, "could not execute dns request")
})
require.NotNil(t, finalEvent, "could not get event output from request")
require.Equal(t, 1, len(finalEvent.Results), "could not get correct number of results")
require.Equal(t, "test", finalEvent.Results[0].MatcherName, "could not get correct matcher name of results")
require.Equal(t, 1, len(finalEvent.Results[0].ExtractedResults), "could not get correct number of extracted results")
2024-04-24 16:19:39 +03:00
require.Equal(t, "93.184.215.14", finalEvent.Results[0].ExtractedResults[0], "could not get correct extracted results")
2021-02-03 02:09:45 +05:30
finalEvent = nil
// Note: changing url to domain is responsible at tmplexec package and is implemented there
2021-02-03 02:09:45 +05:30
}