1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2024-12-14 11:03:09 +02:00
sap-jenkins-library/pkg/reporting/reporting_test.go
Sven Merk c81e741224
Refinement of SARIF generation for BD and WS (#3942)
* Fix docs and format

* Assessment format added

* Added sample file

* Added parsing

* Added packageurl implementation

* Slight refinement

* Refactored assessment options

* Adapted sample file

* First attempt of ws sbom gen

* Reworked SBOM generation

* Fix test code

* Add assessment handling

* Update dependencies

* Added golden test

* Small fix

* feat(fortify): Added a check for fortify binary in $PATH (#3925)

* added check for fortifyupdate and sourceanalyzer bin

Co-authored-by: sumeet patil <sumeet.patil@sap.com>

* Modify SARIF

* Enhanced SARID contents

* Small refinement for hub detect

* Small adjustments

* Extend SARIF contents

* Consistency to Mend part

* Fix tests

* Fix merge

* Fix test

* Add debug log, enhance output

* Enhance meta info

* Fix libType for node

* Fix log entry

* Fix pointers and test

* Fix test

* Fix library types

* Fix test

* Extend libType mappings

Co-authored-by: Vinayak S <vinayaks439@gmail.com>
Co-authored-by: sumeet patil <sumeet.patil@sap.com>
2022-08-11 13:12:14 +02:00

213 lines
6.9 KiB
Go

package reporting
import (
"io/ioutil"
"path/filepath"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestVulToMarkdown(t *testing.T) {
t.Parallel()
t.Run("success - empty", func(t *testing.T) {
t.Parallel()
vulReport := VulnerabilityReport{}
_, err := vulReport.ToMarkdown()
assert.NoError(t, err)
})
t.Run("success - filled", func(t *testing.T) {
t.Parallel()
vulReport := VulnerabilityReport{
ArtifactID: "theArtifact",
Branch: "main",
CommitID: "acb123",
Description: "This is the test description.",
DirectDependency: "true",
Footer: "This is the test footer",
Group: "the.group",
PipelineName: "thePipelineName",
PipelineLink: "https://the.link.to.the.pipeline",
PublishDate: "2022-06-30",
Resolution: "This is the test resolution.",
Score: 7.8,
Severity: "high",
Version: "1.2.3",
PackageURL: "pkg:generic/the.group/theArtifact@1.2.3",
VulnerabilityLink: "https://the.link/to/the/vulnerability",
VulnerabilityName: "CVE-Test-001",
}
goldenFilePath := filepath.Join("testdata", "markdownVulnerability.golden")
expected, err := ioutil.ReadFile(goldenFilePath)
assert.NoError(t, err)
res, err := vulReport.ToMarkdown()
assert.NoError(t, err)
assert.Equal(t, string(expected), string(res))
})
}
func TestToHTML(t *testing.T) {
t.Run("empty table", func(t *testing.T) {
report := ScanReport{
ReportTitle: "Report Test Title",
Subheaders: []Subheader{{Description: "sub 1", Details: "1"}, {Description: "sub 2", Details: "2"}},
Overview: []OverviewRow{
{"overview 1", "1", Green},
{"overview 2", "2", Green},
},
FurtherInfo: "this is further information",
ReportTime: time.Date(2021, 1, 1, 0, 0, 0, 0, time.UTC),
DetailTable: ScanDetailTable{
Headers: []string{"column 1", "column 2"},
Rows: []ScanRow{},
WithCounter: true,
CounterHeader: "Entry #",
NoRowsMessage: "no rows available",
},
}
expectedSub := `<span>
sub 1: 1<br />
sub 2: 2<br />
</span>
</h2>`
expectedOverview := `<h3>
overview 1: 1<br />
overview 2: 2<br />
</h3>`
res, err := report.ToHTML()
result := string(res)
assert.NoError(t, err)
assert.Contains(t, result, "<h1>Report Test Title</h1>")
assert.Contains(t, result, expectedSub)
assert.Contains(t, result, expectedOverview)
assert.Contains(t, result, `<span>this is further information</span>`)
assert.Contains(t, result, `<th>Entry #</th>`)
assert.Contains(t, result, `<th>column 1</th>`)
assert.Contains(t, result, `<th>column 2</th>`)
assert.Contains(t, result, "Snapshot taken: Jan 01, 2021 - 00:00:00 UTC")
assert.Contains(t, result, `<td colspan="3">no rows available</td>`)
})
t.Run("table with content", func(t *testing.T) {
report := ScanReport{
ReportTitle: "Report Test Title",
ReportTime: time.Date(2021, 1, 1, 0, 0, 0, 0, time.UTC),
DetailTable: ScanDetailTable{
Headers: []string{"column 1", "column 2"},
Rows: []ScanRow{
{Columns: []ScanCell{{Content: "c1 r1"}, {Content: "c2 r1"}}},
{Columns: []ScanCell{{Content: "c1 r2"}, {Content: "c2 r2"}}},
{Columns: []ScanCell{{Content: "c1 r3", Style: Green}, {Content: "c2 r3", Style: Black}}},
},
CounterHeader: "Entry #",
WithCounter: true,
},
}
res, err := report.ToHTML()
result := string(res)
assert.NoError(t, err)
assert.Contains(t, result, `<th>Entry #</th>`)
assert.Contains(t, result, `<td>1</td>`)
assert.Contains(t, result, `<td>c1 r1</td>`)
assert.Contains(t, result, `<td>c2 r1</td>`)
assert.Contains(t, result, `<td>2</td>`)
assert.Contains(t, result, `<td>c1 r2</td>`)
assert.Contains(t, result, `<td>c2 r2</td>`)
assert.Contains(t, result, `<td>3</td>`)
assert.Contains(t, result, `<td class="green-cell">c1 r3</td>`)
assert.Contains(t, result, `<td class="black-cell">c2 r3</td>`)
})
}
func TestToMarkdown(t *testing.T) {
t.Run("table with details", func(t *testing.T) {
report := ScanReport{
ReportTitle: "Report Test Title",
Subheaders: []Subheader{{Description: "sub 1", Details: "1"}, {Description: "sub 2", Details: "2"}},
Overview: []OverviewRow{
{"overview 1", "1", Green},
{"overview 2", "2", Green},
},
FurtherInfo: "this is further information",
SuccessfulScan: true,
ReportTime: time.Date(2021, 1, 1, 0, 0, 0, 0, time.UTC),
DetailTable: ScanDetailTable{
Headers: []string{"column 1", "column 2"},
Rows: []ScanRow{
{Columns: []ScanCell{{Content: "c1 r1"}, {Content: "c2 r1"}}},
{Columns: []ScanCell{{Content: "c1 r2"}, {Content: "c2 r2"}}},
{Columns: []ScanCell{{Content: "c1 r3", Style: Green}, {Content: "c2 r3", Style: Black}}},
},
CounterHeader: "Entry #",
WithCounter: true,
},
}
res, err := report.ToMarkdown()
result := string(res)
assert.NoError(t, err)
assert.Contains(t, result, `## :white_check_mark: Report Test Title`)
assert.Contains(t, result, `<td><b>sub 1:</b></td><td>1</td>`)
assert.Contains(t, result, `<td><b>sub 2:</b></td><td>2</td>`)
assert.Contains(t, result, `<tr><td>overview 1:</td><td>1</td></tr>`)
assert.Contains(t, result, `<tr><td>overview 2:</td><td>2</td></tr>`)
assert.Contains(t, result, `this is further information`)
assert.Contains(t, result, "Snapshot taken: <i>Jan 01, 2021 - 00:00:00 UTC</i>")
assert.Contains(t, result, "<details><summary><i>Report Test Title details:</i></summary>")
})
t.Run("table without details", func(t *testing.T) {
report := ScanReport{
ReportTitle: "Report Test Title",
Subheaders: []Subheader{{Description: "sub 1", Details: "1"}, {Description: "sub 2", Details: "2"}},
Overview: []OverviewRow{
{"overview 1", "1", Green},
{"overview 2", "2", Green},
},
FurtherInfo: "this is further information",
ReportTime: time.Date(2021, 1, 1, 0, 0, 0, 0, time.UTC),
}
res, err := report.ToMarkdown()
result := string(res)
assert.NoError(t, err)
assert.Contains(t, result, `## :x: Report Test Title`)
assert.NotContains(t, result, "<details><summary><i>Report Test Title details:</i></summary>")
})
}
func TestTableColumnCount(t *testing.T) {
t.Run("table without counter", func(t *testing.T) {
details := ScanDetailTable{
Headers: []string{"column 1", "column 1"},
WithCounter: false,
}
assert.Equal(t, 2, tableColumnCount(details))
})
t.Run("table with counter", func(t *testing.T) {
details := ScanDetailTable{
Headers: []string{"column 1", "column 1"},
WithCounter: true,
}
assert.Equal(t, 3, tableColumnCount(details))
})
}
func TestShouldDrawTable(t *testing.T) {
tt := []struct {
table ScanDetailTable
expected bool
}{
{table: ScanDetailTable{}, expected: false},
{table: ScanDetailTable{Headers: []string{"column1", "column2"}}, expected: true},
}
for _, test := range tt {
assert.Equal(t, test.expected, shouldDrawTable(test.table))
}
}