mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-14 11:03:09 +02:00
a4a0873081
* feat(checkmarx): create GitHub issue with findings * add github issue reporting
99 lines
2.9 KiB
Go
99 lines
2.9 KiB
Go
// +build !release
|
|
|
|
package whitesource
|
|
|
|
import (
|
|
"net/http"
|
|
"os"
|
|
|
|
"github.com/SAP/jenkins-library/pkg/mock"
|
|
"github.com/SAP/jenkins-library/pkg/piperutils"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
func newTestScan(config *ScanOptions) *Scan {
|
|
return &Scan{
|
|
AggregateProjectName: config.ProjectName,
|
|
ProductVersion: config.ProductVersion,
|
|
}
|
|
}
|
|
|
|
// NpmInstall records in which directory "npm install" has been invoked and for which package.json files.
|
|
type NpmInstall struct {
|
|
CurrentDir string
|
|
PackageJSON []string
|
|
}
|
|
|
|
// DownloadedFile records what URL has been downloaded to which file.
|
|
type DownloadedFile struct {
|
|
SourceURL string
|
|
FilePath string
|
|
}
|
|
|
|
// ScanUtilsMock is an implementation of the Utils interface that can be used during tests.
|
|
type ScanUtilsMock struct {
|
|
*mock.FilesMock
|
|
*mock.ExecMockRunner
|
|
NpmInstalledModules []NpmInstall
|
|
DownloadedFiles []DownloadedFile
|
|
DownloadError map[string]error
|
|
RemoveAllDirs []string
|
|
RemoveAllError map[string]error
|
|
}
|
|
|
|
// RemoveAll mimics os.RemoveAll().
|
|
func (m *ScanUtilsMock) RemoveAll(dir string) error {
|
|
// Can be removed once implemented in mock.FilesMock.
|
|
m.RemoveAllDirs = append(m.RemoveAllDirs, dir)
|
|
if m.RemoveAllError[dir] != nil {
|
|
return m.RemoveAllError[dir]
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// FindPackageJSONFiles mimics npm.FindPackageJSONFiles() based on the FilesMock setup.
|
|
func (m *ScanUtilsMock) FindPackageJSONFiles(options *ScanOptions) ([]string, error) {
|
|
unfilteredMatches, _ := m.Glob("**/package.json")
|
|
return piperutils.ExcludeFiles(unfilteredMatches, options.BuildDescriptorExcludeList)
|
|
}
|
|
|
|
// InstallAllNPMDependencies mimics npm.InstallAllNPMDependencies() and records the "npm install".
|
|
func (m *ScanUtilsMock) InstallAllNPMDependencies(_ *ScanOptions, packageJSONs []string) error {
|
|
m.NpmInstalledModules = append(m.NpmInstalledModules, NpmInstall{
|
|
CurrentDir: m.CurrentDir,
|
|
PackageJSON: packageJSONs,
|
|
})
|
|
return nil
|
|
}
|
|
|
|
// DownloadFile mimics http.Downloader and records the downloaded file.
|
|
func (m *ScanUtilsMock) DownloadFile(url, filename string, _ http.Header, _ []*http.Cookie) error {
|
|
if url == "errorCopyFile" {
|
|
return errors.New("unable to copy content from url to file")
|
|
}
|
|
if url == "error404NotFound" {
|
|
return errors.New("returned with response 404 Not Found")
|
|
}
|
|
if url == "error403Forbidden" {
|
|
return errors.New("returned with response 403 Forbidden")
|
|
}
|
|
if m.DownloadError[url] != nil {
|
|
return m.DownloadError[url]
|
|
}
|
|
m.DownloadedFiles = append(m.DownloadedFiles, DownloadedFile{SourceURL: url, FilePath: filename})
|
|
return nil
|
|
}
|
|
|
|
// FileOpen mimics os.FileOpen() based on FilesMock OpenFile().
|
|
func (m *ScanUtilsMock) FileOpen(name string, flag int, perm os.FileMode) (File, error) {
|
|
return m.OpenFile(name, flag, perm)
|
|
}
|
|
|
|
// NewScanUtilsMock returns an initialized ScanUtilsMock instance.
|
|
func NewScanUtilsMock() *ScanUtilsMock {
|
|
return &ScanUtilsMock{
|
|
FilesMock: &mock.FilesMock{},
|
|
ExecMockRunner: &mock.ExecMockRunner{},
|
|
}
|
|
}
|