From 9596bf045d527e27608ac4b7b2990a4e6846fdeb Mon Sep 17 00:00:00 2001 From: Riccardo Cipolleschi Date: Tue, 24 May 2022 01:41:08 -0700 Subject: [PATCH] Fix tests for Windows (#33893) Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/33893 The previous diff was breaking the external CI tests on Windows because of the file separators. The fix was to use UNIX separator but to apply `path.normalize` to make sure that the path is platform agnostic. ## Changelog [General][Fixed] - Make tests pass for windows Reviewed By: cortinico Differential Revision: D36597593 fbshipit-source-id: 47731f34a08c778268a6cc9674257403985d4599 --- .../generate-artifacts-executor-test.js | 62 ++++++++++--------- 1 file changed, 32 insertions(+), 30 deletions(-) diff --git a/scripts/codegen/__tests__/generate-artifacts-executor-test.js b/scripts/codegen/__tests__/generate-artifacts-executor-test.js index 17a78e9d542186..c59592201c981e 100644 --- a/scripts/codegen/__tests__/generate-artifacts-executor-test.js +++ b/scripts/codegen/__tests__/generate-artifacts-executor-test.js @@ -272,7 +272,7 @@ describe('delete empty files and folders', () => { }); it("when path is folder and it's empty, removes it", () => { - const targetFolder = 'build/'; + const targetFolder = 'build'; const content = []; let statSyncInvocationCount = 0; @@ -311,16 +311,18 @@ describe('delete empty files and folders', () => { }); it("when path is folder and it's not empty, removes only empty folders and files", () => { - const targetFolder = 'build/'; + const targetFolder = 'build'; const content = ['emptyFolder', 'emptyFile', 'notEmptyFile']; - const files = ['build/emptyFile', 'build/notEmptyFile']; + const files = [ + path.normalize('build/emptyFile'), + path.normalize('build/notEmptyFile'), + ]; const emptyContent = []; - const fileSizes = { - 'build/emptyFile': 0, - 'build/notEmptyFile': 32, - }; + let fileSizes = {}; + fileSizes[path.normalize('build/emptyFile')] = 0; + fileSizes[path.normalize('build/notEmptyFile')] = 32; let statSyncInvocation = []; let rmSyncInvocation = []; @@ -352,23 +354,23 @@ describe('delete empty files and folders', () => { underTest._cleanupEmptyFilesAndFolders(targetFolder); expect(statSyncInvocation).toEqual([ - 'build/', - 'build/emptyFolder', - 'build/emptyFile', - 'build/notEmptyFile', + path.normalize('build'), + path.normalize('build/emptyFolder'), + path.normalize('build/emptyFile'), + path.normalize('build/notEmptyFile'), ]); expect(readdirInvocation).toEqual([ - 'build/', - 'build/emptyFolder', - 'build/emptyFolder', - 'build/', + path.normalize('build'), + path.normalize('build/emptyFolder'), + path.normalize('build/emptyFolder'), + path.normalize('build'), ]); - expect(rmSyncInvocation).toEqual(['build/emptyFile']); - expect(rmdirSyncInvocation).toEqual(['build/emptyFolder']); + expect(rmSyncInvocation).toEqual([path.normalize('build/emptyFile')]); + expect(rmdirSyncInvocation).toEqual([path.normalize('build/emptyFolder')]); }); it('when path is folder and it contains only empty folders, removes everything', () => { - const targetFolder = 'build/'; + const targetFolder = 'build'; const content = ['emptyFolder1', 'emptyFolder2']; const emptyContent = []; @@ -406,23 +408,23 @@ describe('delete empty files and folders', () => { underTest._cleanupEmptyFilesAndFolders(targetFolder); expect(statSyncInvocation).toEqual([ - 'build/', - 'build/emptyFolder1', - 'build/emptyFolder2', + path.normalize('build'), + path.normalize('build/emptyFolder1'), + path.normalize('build/emptyFolder2'), ]); expect(readdirInvocation).toEqual([ - 'build/', - 'build/emptyFolder1', - 'build/emptyFolder1', - 'build/emptyFolder2', - 'build/emptyFolder2', - 'build/', + path.normalize('build'), + path.normalize('build/emptyFolder1'), + path.normalize('build/emptyFolder1'), + path.normalize('build/emptyFolder2'), + path.normalize('build/emptyFolder2'), + path.normalize('build'), ]); expect(rmSyncInvocation).toEqual([]); expect(rmdirSyncInvocation).toEqual([ - 'build/emptyFolder1', - 'build/emptyFolder2', - 'build/', + path.normalize('build/emptyFolder1'), + path.normalize('build/emptyFolder2'), + path.normalize('build'), ]); }); });