add unit test and cleanup (#28)

* remove unnessary import

* use mock for child_process.spawnSync()

* document useful resources

* use v1.1.0 for daily scan
This commit is contained in:
Naoki Oketani
2019-12-13 16:09:10 +09:00
committed by GitHub
parent 3e659c8c99
commit a0a6093710
5 changed files with 63 additions and 6 deletions

View File

@@ -1,15 +1,57 @@
import * as child_process from 'child_process'
import * as fs from 'fs'
import * as path from 'path'
import {mocked} from 'ts-jest/utils'
import {Audit} from '../src/audit'
jest.mock('child_process')
const audit = new Audit()
describe('npm audit', () => {
describe('run', () => {
beforeEach(() => {
mocked(child_process).spawnSync.mockClear()
})
test('finds vulnerabilities', () => {
audit.status = 1
mocked(child_process).spawnSync.mockImplementation((): any => {
const stdout = fs.readFileSync(
path.join(__dirname, 'testdata/audit/error.txt')
)
return {
pid: 100,
output: [stdout],
stdout,
stderr: '',
status: 1,
signal: null,
error: null
}
})
audit.run()
expect(audit.foundVulnerability()).toBeTruthy()
})
test('does not find vulnerabilities', () => {
audit.status = 0
mocked(child_process).spawnSync.mockImplementation((): any => {
const stdout = fs.readFileSync(
path.join(__dirname, 'testdata/audit/success.txt')
)
return {
pid: 100,
output: [stdout],
stdout,
stderr: '',
status: 0,
signal: null,
error: null
}
})
audit.run()
expect(audit.foundVulnerability()).toBeFalsy()
})
})

View File

@@ -1,7 +1,6 @@
import * as fs from 'fs'
import * as path from 'path'
import {mocked} from 'ts-jest/utils'
import axios, {AxiosResponse} from 'axios'
import {Audit} from '../src/audit'
import {run} from '../src/main'
import * as pr from '../src/pr'