mirror of
https://github.com/trufflesecurity/trufflehog.git
synced 2024-11-10 07:04:24 +00:00
d6375ba921
* verify response body with expected keywords * remove debug log * add extra test case * migrate from ioutil to io * close body and only check for one keyword * cleanup
135 lines
2.8 KiB
Go
135 lines
2.8 KiB
Go
package common
|
|
|
|
import (
|
|
"io"
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
func TestAddItem(t *testing.T) {
|
|
type Case struct {
|
|
Slice []string
|
|
Modifier []string
|
|
Expected []string
|
|
}
|
|
tests := map[string]Case{
|
|
"newItem": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"d"},
|
|
Expected: []string{"a", "b", "c", "d"},
|
|
},
|
|
"newDuplicate": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"c"},
|
|
Expected: []string{"a", "b", "c"},
|
|
},
|
|
}
|
|
|
|
for name, test := range tests {
|
|
for _, item := range test.Modifier {
|
|
AddStringSliceItem(item, &test.Slice)
|
|
}
|
|
|
|
if !reflect.DeepEqual(test.Slice, test.Expected) {
|
|
t.Errorf("%s: expected:%v, got:%v", name, test.Expected, test.Slice)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestRemoveItem(t *testing.T) {
|
|
type Case struct {
|
|
Slice []string
|
|
Modifier []string
|
|
Expected []string
|
|
}
|
|
tests := map[string]Case{
|
|
"existingItemEnd": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"c"},
|
|
Expected: []string{"a", "b"},
|
|
},
|
|
"existingItemMiddle": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"b"},
|
|
Expected: []string{"a", "c"},
|
|
},
|
|
"existingItemBeginning": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"a"},
|
|
Expected: []string{"c", "b"},
|
|
},
|
|
"nonExistingItem": {
|
|
Slice: []string{"a", "b", "c"},
|
|
Modifier: []string{"d"},
|
|
Expected: []string{"a", "b", "c"},
|
|
},
|
|
}
|
|
|
|
for name, test := range tests {
|
|
for _, item := range test.Modifier {
|
|
RemoveStringSliceItem(item, &test.Slice)
|
|
}
|
|
|
|
if !reflect.DeepEqual(test.Slice, test.Expected) {
|
|
t.Errorf("%s: expected:%v, got:%v", name, test.Expected, test.Slice)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Test ParseResponseForKeywords with a reader that contains the keyword and a reader that doesn't.
|
|
func TestParseResponseForKeywords(t *testing.T) {
|
|
testCases := []struct {
|
|
name string
|
|
input string
|
|
keyword string
|
|
expected bool
|
|
}{
|
|
{
|
|
name: "Should find keyword",
|
|
input: "ey: abc",
|
|
keyword: "ey",
|
|
expected: true,
|
|
},
|
|
{
|
|
name: "Should not find keyword",
|
|
input: "fake response",
|
|
keyword: "ey",
|
|
expected: false,
|
|
},
|
|
{
|
|
name: "Empty string",
|
|
input: "",
|
|
keyword: "ey",
|
|
expected: false,
|
|
},
|
|
{
|
|
name: "Keyword at end",
|
|
input: "abc ey",
|
|
keyword: "ey",
|
|
expected: true,
|
|
},
|
|
{
|
|
name: "Keyword at start",
|
|
input: "ey abc",
|
|
keyword: "ey",
|
|
expected: true,
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
testReader := strings.NewReader(tc.input)
|
|
testReadCloser := io.NopCloser(testReader)
|
|
found, err := ResponseContainsSubstring(testReadCloser, tc.keyword)
|
|
|
|
if err != nil {
|
|
t.Errorf("Error: %v", err)
|
|
}
|
|
|
|
if found != tc.expected {
|
|
t.Errorf("Expected %v, got %v", tc.expected, found)
|
|
}
|
|
})
|
|
}
|
|
}
|