From 43087fbd82f9ad34805b850ccc5564bd018ab18c Mon Sep 17 00:00:00 2001 From: Lucas Yarid Date: Fri, 17 May 2024 11:45:06 +0200 Subject: [PATCH] improve tests --- __tests__/filter.test.ts | 36 +++++++++++++++++++++++++++++++++--- src/main.ts | 7 ++++--- 2 files changed, 37 insertions(+), 6 deletions(-) diff --git a/__tests__/filter.test.ts b/__tests__/filter.test.ts index 6f5a9b4d..b8e42cdb 100644 --- a/__tests__/filter.test.ts +++ b/__tests__/filter.test.ts @@ -11,6 +11,39 @@ jest.mock('@actions/core', () => ({ endGroup: jest.fn() })) +describe('set output post filtering', () => { + test('correctly sets output', () => { + const yaml = ` + backend: + - '!(**/*.tsx|**/*.less)' + ` + const filter = new Filter(yaml) + const files = modified(['config/settings.yml']) + const match = filter.match(files) + exportResults(match, 'none') + + expect(core.setOutput).toHaveBeenCalledWith('changes', '["backend"]') + }) + test('correctly filters out shared from output', () => { + const yaml = ` + shared: &shared + - common/**/* + - config/**/* + src: + - *shared + - src/**/* + backend: + - '!(**/*.tsx|**/*.less)' + ` + const filter = new Filter(yaml) + const files = modified(['config/settings.yml']) + const match = filter.match(files) + exportResults(match, 'none') + + expect(core.setOutput).toHaveBeenCalledWith('changes', '["src","backend"]') + }) +}) + describe('yaml filter parsing tests', () => { test('throws if yaml is not a dictionary', () => { const yaml = 'not a dictionary' @@ -170,9 +203,6 @@ describe('matching tests', () => { const filter = new Filter(yaml) const files = modified(['config/settings.yml']) const match = filter.match(files) - exportResults(match, 'none') - - expect(core.setOutput).toHaveBeenCalledWith('changes', '["src"]') expect(match.src).toEqual(files) }) }) diff --git a/src/main.ts b/src/main.ts index e78b3b23..6e881fd1 100644 --- a/src/main.ts +++ b/src/main.ts @@ -244,17 +244,18 @@ export function exportResults(results: FilterResults, format: ExportFormat): voi core.info('Matching files: none') } - core.setOutput(key, value) - core.setOutput(`${key}_count`, files.length) + // core.setOutput(key, value) + // core.setOutput(`${key}_count`, files.length) if (format !== 'none') { const filesValue = serializeExport(files, format) - core.setOutput(`${key}_files`, filesValue) + // core.setOutput(`${key}_files`, filesValue) } core.endGroup() } if (results['changes'] === undefined) { const filteredShared = changes.filter(change => change !== 'shared') + console.log({changes, filteredShared}) const changesJson = JSON.stringify(filteredShared) core.info(`Changes output set to ${changesJson}`) core.setOutput('changes', changesJson)