Add unit tests for DetectAuthType function
This commit is contained in:
committed by
Brendan Le Glaunec
parent
260a9645be
commit
862e9f3de9
@@ -101,13 +101,7 @@ func DetectAuthMethods(c Curler, targets []Stream, timeout time.Duration, log bo
|
|||||||
attacks := make(chan Stream)
|
attacks := make(chan Stream)
|
||||||
defer close(attacks)
|
defer close(attacks)
|
||||||
|
|
||||||
validate := v.New()
|
|
||||||
for i := range targets {
|
for i := range targets {
|
||||||
err := validate.Struct(targets[i])
|
|
||||||
if err != nil {
|
|
||||||
return targets, errors.Wrap(err, "invalid targets")
|
|
||||||
}
|
|
||||||
|
|
||||||
targets[i].AuthenticationType = detectAuthMethod(c, targets[i], timeout, log)
|
targets[i].AuthenticationType = detectAuthMethod(c, targets[i], timeout, log)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
+124
-15
@@ -2,14 +2,12 @@ package cmrdr
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
curl "github.com/ullaakut/go-curl"
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/stretchr/testify/mock"
|
"github.com/stretchr/testify/mock"
|
||||||
|
curl "github.com/ullaakut/go-curl"
|
||||||
)
|
)
|
||||||
|
|
||||||
type CurlerMock struct {
|
type CurlerMock struct {
|
||||||
@@ -163,14 +161,12 @@ func TestAttackCredentials(t *testing.T) {
|
|||||||
|
|
||||||
if len(test.expectedErrMsg) > 0 {
|
if len(test.expectedErrMsg) > 0 {
|
||||||
if err == nil {
|
if err == nil {
|
||||||
fmt.Printf("unexpected success in AttackCredentials test, iteration %d. expected error: %s\n", i, test.expectedErrMsg)
|
t.Errorf("unexpected success in AttackCredentials test, iteration %d. expected error: %s\n", i, test.expectedErrMsg)
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
assert.Contains(t, err.Error(), test.expectedErrMsg, "wrong error message")
|
assert.Contains(t, err.Error(), test.expectedErrMsg, "wrong error message")
|
||||||
} else {
|
} else {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("unexpected error in AttackCredentials test, iteration %d: %v\n", i, err)
|
t.Errorf("unexpected error in AttackCredentials test, iteration %d: %v\n", i, err)
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
for _, stream := range test.expectedStreams {
|
for _, stream := range test.expectedStreams {
|
||||||
foundStream := false
|
foundStream := false
|
||||||
@@ -318,15 +314,13 @@ func TestAttackRoute(t *testing.T) {
|
|||||||
|
|
||||||
if len(test.expectedErrMsg) > 0 {
|
if len(test.expectedErrMsg) > 0 {
|
||||||
if err == nil {
|
if err == nil {
|
||||||
fmt.Printf("unexpected success in AttackRoute test, iteration %d. expected error: %s\n", i, test.expectedErrMsg)
|
t.Errorf("unexpected success in AttackRoute test, iteration %d. expected error: %s\n", i, test.expectedErrMsg)
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
assert.Contains(t, err.Error(), test.expectedErrMsg, "wrong error message")
|
assert.Contains(t, err.Error(), test.expectedErrMsg, "wrong error message")
|
||||||
} else {
|
} else {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("unexpected error in AttackRoute test, iteration %d: %v\n", i, err)
|
t.Errorf("unexpected error in AttackRoute test, iteration %d: %v\n", i, err)
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, stream := range test.expectedStreams {
|
for _, stream := range test.expectedStreams {
|
||||||
@@ -486,15 +480,130 @@ func TestValidateStreams(t *testing.T) {
|
|||||||
|
|
||||||
if len(tC.expectedErrMsg) > 0 {
|
if len(tC.expectedErrMsg) > 0 {
|
||||||
if err == nil {
|
if err == nil {
|
||||||
fmt.Printf("unexpected success in ValidateStream test, iteration %d. expected error: %s\n", i, tC.expectedErrMsg)
|
t.Errorf("unexpected success in ValidateStream test, iteration %d. expected error: %s\n", i, tC.expectedErrMsg)
|
||||||
os.Exit(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
assert.Contains(t, err.Error(), tC.expectedErrMsg, "wrong error message")
|
assert.Contains(t, err.Error(), tC.expectedErrMsg, "wrong error message")
|
||||||
} else {
|
} else {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("unexpected error in ValidateStream test, iteration %d: %v\n", i, err)
|
t.Errorf("unexpected error in ValidateStream test, iteration %d: %v\n", i, err)
|
||||||
os.Exit(1)
|
}
|
||||||
|
|
||||||
|
for _, stream := range tC.expectedStreams {
|
||||||
|
foundStream := false
|
||||||
|
for _, result := range results {
|
||||||
|
if result.Address == stream.Address && result.Device == stream.Device && result.Port == stream.Port {
|
||||||
|
foundStream = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Equal(t, true, foundStream, "wrong streams parsed")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Equal(t, len(tC.expectedStreams), len(results), "wrong streams parsed")
|
||||||
|
|
||||||
|
curlerMock.AssertExpectations(t)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDetectAuthenticationType(t *testing.T) {
|
||||||
|
validStream1 := Stream{
|
||||||
|
Device: "fakeDevice",
|
||||||
|
Address: "fakeAddress",
|
||||||
|
Port: 1337,
|
||||||
|
Available: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
validStream2 := Stream{
|
||||||
|
Device: "fakeDevice",
|
||||||
|
Address: "differentFakeAddress",
|
||||||
|
Port: 1337,
|
||||||
|
Available: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
fakeTargets := []Stream{validStream1, validStream2}
|
||||||
|
|
||||||
|
testCases := []struct {
|
||||||
|
desc string
|
||||||
|
|
||||||
|
targets []Stream
|
||||||
|
timeout time.Duration
|
||||||
|
log bool
|
||||||
|
|
||||||
|
status int
|
||||||
|
|
||||||
|
performErr error
|
||||||
|
getInfoErr error
|
||||||
|
|
||||||
|
expectedStreams []Stream
|
||||||
|
expectedErrMsg string
|
||||||
|
}{
|
||||||
|
// curl getinfo fails
|
||||||
|
{
|
||||||
|
desc: "curl getinfo fails",
|
||||||
|
|
||||||
|
targets: fakeTargets,
|
||||||
|
timeout: 1 * time.Millisecond,
|
||||||
|
|
||||||
|
getInfoErr: errors.New("dummy error"),
|
||||||
|
|
||||||
|
expectedStreams: fakeTargets,
|
||||||
|
},
|
||||||
|
// curl perform fails
|
||||||
|
{
|
||||||
|
desc: "curl perform fails",
|
||||||
|
|
||||||
|
targets: fakeTargets,
|
||||||
|
timeout: 1 * time.Millisecond,
|
||||||
|
|
||||||
|
performErr: errors.New("dummy error"),
|
||||||
|
|
||||||
|
expectedStreams: fakeTargets,
|
||||||
|
},
|
||||||
|
// Logs disabled
|
||||||
|
{
|
||||||
|
desc: "logs disabled",
|
||||||
|
|
||||||
|
targets: fakeTargets,
|
||||||
|
timeout: 1 * time.Millisecond,
|
||||||
|
log: false,
|
||||||
|
|
||||||
|
expectedStreams: fakeTargets,
|
||||||
|
},
|
||||||
|
// Logs enabled
|
||||||
|
{
|
||||||
|
desc: "logs enabled",
|
||||||
|
|
||||||
|
targets: fakeTargets,
|
||||||
|
timeout: 1 * time.Millisecond,
|
||||||
|
log: true,
|
||||||
|
|
||||||
|
expectedStreams: fakeTargets,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for i, tC := range testCases {
|
||||||
|
t.Run(tC.desc, func(t *testing.T) {
|
||||||
|
curlerMock := &CurlerMock{}
|
||||||
|
|
||||||
|
curlerMock.On("Setopt", mock.Anything, mock.Anything).Return(nil)
|
||||||
|
curlerMock.On("Perform").Return(tC.performErr)
|
||||||
|
if tC.performErr == nil {
|
||||||
|
curlerMock.On("Getinfo", mock.Anything).Return(tC.status, tC.getInfoErr)
|
||||||
|
}
|
||||||
|
|
||||||
|
results, err := DetectAuthMethods(curlerMock, tC.targets, tC.timeout, tC.log)
|
||||||
|
|
||||||
|
if len(tC.expectedErrMsg) > 0 {
|
||||||
|
if err == nil {
|
||||||
|
t.Errorf("unexpected success in DetectAuthMethods test, iteration %d. expected error: %s\n", i, tC.expectedErrMsg)
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Contains(t, err.Error(), tC.expectedErrMsg, "wrong error message")
|
||||||
|
} else {
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("unexpected error in DetectAuthMethods test, iteration %d: %v\n", i, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, stream := range tC.expectedStreams {
|
for _, stream := range tC.expectedStreams {
|
||||||
|
|||||||
Reference in New Issue
Block a user