2024-04-10 23:53:17 +00:00
|
|
|
import {MockAgent, setGlobalDispatcher} from 'undici'
|
2024-02-18 03:14:10 +00:00
|
|
|
import {writeAttestation} from '../src/store'
|
|
|
|
|
|
|
|
describe('writeAttestation', () => {
|
|
|
|
const originalEnv = process.env
|
|
|
|
const attestation = {foo: 'bar '}
|
|
|
|
const token = 'token'
|
|
|
|
|
2024-04-10 23:53:17 +00:00
|
|
|
const mockAgent = new MockAgent()
|
|
|
|
setGlobalDispatcher(mockAgent)
|
|
|
|
|
2024-02-18 03:14:10 +00:00
|
|
|
beforeEach(() => {
|
|
|
|
process.env = {
|
|
|
|
...originalEnv,
|
|
|
|
GITHUB_REPOSITORY: 'foo/bar'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
process.env = originalEnv
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('when the api call is successful', () => {
|
|
|
|
beforeEach(() => {
|
2024-04-10 23:53:17 +00:00
|
|
|
mockAgent
|
|
|
|
.get('https://api.github.com')
|
|
|
|
.intercept({
|
|
|
|
path: '/repos/foo/bar/attestations',
|
|
|
|
method: 'POST',
|
|
|
|
headers: {authorization: `token ${token}`},
|
|
|
|
body: JSON.stringify({bundle: attestation})
|
|
|
|
})
|
2024-02-18 03:14:10 +00:00
|
|
|
.reply(201, {id: '123'})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('persists the attestation', async () => {
|
|
|
|
await expect(writeAttestation(attestation, token)).resolves.toEqual('123')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('when the api call fails', () => {
|
|
|
|
beforeEach(() => {
|
2024-04-10 23:53:17 +00:00
|
|
|
mockAgent
|
|
|
|
.get('https://api.github.com')
|
|
|
|
.intercept({
|
|
|
|
path: '/repos/foo/bar/attestations',
|
|
|
|
method: 'POST',
|
|
|
|
headers: {authorization: `token ${token}`},
|
|
|
|
body: JSON.stringify({bundle: attestation})
|
|
|
|
})
|
2024-02-18 03:14:10 +00:00
|
|
|
.reply(500, 'oops')
|
|
|
|
})
|
|
|
|
|
2024-03-22 02:25:36 +00:00
|
|
|
it('throws an error', async () => {
|
2024-02-18 03:14:10 +00:00
|
|
|
await expect(writeAttestation(attestation, token)).rejects.toThrow(/oops/)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|