* fix tests for Actions AllowList * add more allowed actions * Update tests/unit/actions-workflows.js Co-authored-by: Tom Jenkinson <tjenkinson@users.noreply.github.com> * Update allowed-actions.js Co-authored-by: Tom Jenkinson <tjenkinson@users.noreply.github.com>
42 lines
1.4 KiB
JavaScript
42 lines
1.4 KiB
JavaScript
const fs = require('fs')
|
|
const path = require('path')
|
|
const yaml = require('js-yaml')
|
|
const flat = require('flat')
|
|
const { chain, difference, get } = require('lodash')
|
|
const workflowsDir = path.join(__dirname, '../../.github/workflows')
|
|
const workflows = fs.readdirSync(workflowsDir)
|
|
.filter(filename => filename.endsWith('.yml') || filename.endsWith('.yaml'))
|
|
.map(filename => {
|
|
const fullpath = path.join(workflowsDir, filename)
|
|
const data = yaml.load(fs.readFileSync(fullpath, 'utf8'), { fullpath })
|
|
return { filename, fullpath, data }
|
|
})
|
|
const allowedActions = require('../../.github/allowed-actions')
|
|
|
|
function actionsUsedInWorkflow (workflow) {
|
|
return Object.keys(flat(workflow))
|
|
.filter(key => key.endsWith('.uses'))
|
|
.map(key => get(workflow, key))
|
|
}
|
|
|
|
const allUsedActions = chain(workflows)
|
|
.map(actionsUsedInWorkflow)
|
|
.flatten()
|
|
.uniq()
|
|
.sort()
|
|
.value()
|
|
|
|
describe('GitHub Actions workflows', () => {
|
|
test('all used actions are allowed in .github/allowed-actions.js', () => {
|
|
expect(allUsedActions.length).toBeGreaterThan(0)
|
|
const unusedActions = difference(allowedActions, allUsedActions)
|
|
expect(unusedActions).toEqual([])
|
|
})
|
|
|
|
test('all allowed actions by .github/allowed-actions.js are used by at least one workflow', () => {
|
|
expect(allowedActions.length).toBeGreaterThan(0)
|
|
const disallowedActions = difference(allUsedActions, allowedActions)
|
|
expect(disallowedActions).toEqual([])
|
|
})
|
|
})
|