2018-07-19 18:42:25 +02:00
|
|
|
package gosec_test
|
2016-11-18 19:57:34 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"go/ast"
|
2017-07-19 23:17:00 +02:00
|
|
|
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
2018-07-19 18:42:25 +02:00
|
|
|
"github.com/securego/gosec"
|
|
|
|
"github.com/securego/gosec/testutils"
|
2016-11-18 19:57:34 +02:00
|
|
|
)
|
|
|
|
|
2019-04-29 18:32:39 +02:00
|
|
|
var _ = Describe("Call List", func() {
|
2017-07-19 23:17:00 +02:00
|
|
|
var (
|
2018-07-19 18:42:25 +02:00
|
|
|
calls gosec.CallList
|
2016-11-18 19:57:34 +02:00
|
|
|
)
|
2017-07-19 23:17:00 +02:00
|
|
|
BeforeEach(func() {
|
2018-07-19 18:42:25 +02:00
|
|
|
calls = gosec.NewCallList()
|
2017-07-19 23:17:00 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
It("should not return any matches when empty", func() {
|
|
|
|
Expect(calls.Contains("foo", "bar")).Should(BeFalse())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("should be possible to add a single call", func() {
|
|
|
|
Expect(calls).Should(HaveLen(0))
|
|
|
|
calls.Add("foo", "bar")
|
|
|
|
Expect(calls).Should(HaveLen(1))
|
|
|
|
|
|
|
|
expected := make(map[string]bool)
|
|
|
|
expected["bar"] = true
|
|
|
|
actual := map[string]bool(calls["foo"])
|
|
|
|
Expect(actual).Should(Equal(expected))
|
|
|
|
})
|
|
|
|
|
|
|
|
It("should be possible to add multiple calls at once", func() {
|
|
|
|
Expect(calls).Should(HaveLen(0))
|
|
|
|
calls.AddAll("fmt", "Sprint", "Sprintf", "Printf", "Println")
|
|
|
|
|
|
|
|
expected := map[string]bool{
|
|
|
|
"Sprint": true,
|
|
|
|
"Sprintf": true,
|
|
|
|
"Printf": true,
|
|
|
|
"Println": true,
|
|
|
|
}
|
|
|
|
actual := map[string]bool(calls["fmt"])
|
|
|
|
Expect(actual).Should(Equal(expected))
|
|
|
|
})
|
|
|
|
|
|
|
|
It("should not return a match if none are present", func() {
|
|
|
|
calls.Add("ioutil", "Copy")
|
|
|
|
Expect(calls.Contains("fmt", "Println")).Should(BeFalse())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("should match a call based on selector and ident", func() {
|
|
|
|
calls.Add("ioutil", "Copy")
|
|
|
|
Expect(calls.Contains("ioutil", "Copy")).Should(BeTrue())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("should match a call expression", func() {
|
|
|
|
|
|
|
|
// Create file to be scanned
|
|
|
|
pkg := testutils.NewTestPackage()
|
|
|
|
defer pkg.Close()
|
2018-09-28 10:42:25 +02:00
|
|
|
pkg.AddFile("md5.go", testutils.SampleCodeG401[0].Code[0])
|
2017-07-19 23:17:00 +02:00
|
|
|
|
|
|
|
ctx := pkg.CreateContext("md5.go")
|
|
|
|
|
|
|
|
// Search for md5.New()
|
2018-01-05 15:05:53 +02:00
|
|
|
calls.Add("crypto/md5", "New")
|
2017-07-19 23:17:00 +02:00
|
|
|
|
|
|
|
// Stub out visitor and count number of matched call expr
|
|
|
|
matched := 0
|
|
|
|
v := testutils.NewMockVisitor()
|
|
|
|
v.Context = ctx
|
2018-07-19 18:42:25 +02:00
|
|
|
v.Callback = func(n ast.Node, ctx *gosec.Context) bool {
|
2018-09-25 09:40:05 +02:00
|
|
|
if _, ok := n.(*ast.CallExpr); ok && calls.ContainsCallExpr(n, ctx, false) != nil {
|
2017-07-19 23:17:00 +02:00
|
|
|
matched++
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
ast.Walk(v, ctx.Root)
|
|
|
|
Expect(matched).Should(Equal(1))
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
})
|