From 89baebf97aaa0b3147f9a3e9f034e7165bd09d24 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adrian=20Roma=C5=84ski?= Date: Thu, 12 Dec 2024 10:27:27 +0100 Subject: [PATCH] tests: read target cache - mock read json file --- projects/nx-verdaccio/src/plugin/caching.ts | 4 +- .../src/plugin/caching.unit-test.ts | 76 ++++++++++++++++++- 2 files changed, 74 insertions(+), 6 deletions(-) diff --git a/projects/nx-verdaccio/src/plugin/caching.ts b/projects/nx-verdaccio/src/plugin/caching.ts index d8e8c05..54b9c20 100644 --- a/projects/nx-verdaccio/src/plugin/caching.ts +++ b/projects/nx-verdaccio/src/plugin/caching.ts @@ -33,10 +33,8 @@ export function setCacheRecord( export function readTargetsCache( cachePath: string ): Record> { - // that part is ready - const mockedExistsSync = existsSync(cachePath); return process.env.NX_CACHE_PROJECT_GRAPH !== 'false' && existsSync(cachePath) - ? readJsonFile(cachePath) + ? readJsonFile(cachePath) : {}; } diff --git a/projects/nx-verdaccio/src/plugin/caching.unit-test.ts b/projects/nx-verdaccio/src/plugin/caching.unit-test.ts index b47ed38..1e676d0 100644 --- a/projects/nx-verdaccio/src/plugin/caching.unit-test.ts +++ b/projects/nx-verdaccio/src/plugin/caching.unit-test.ts @@ -2,8 +2,10 @@ import { afterEach, beforeEach, describe, expect } from 'vitest'; import * as moduleUnderTest from './caching'; import * as cachingUtils from './utils/caching.utils'; import * as nodeFs from 'node:fs'; +import * as nxDevKit from '@nx/devkit'; import { readTargetsCache, setCacheRecord } from './caching'; import { cacheKey } from './utils/caching.utils'; +import { ProjectConfiguration } from '@nx/devkit'; describe('caching', () => { const prefix = 'warcraft'; @@ -87,10 +89,76 @@ describe('caching', () => { // : {}; // } describe('readTargetsCache', (): void => { + afterEach(() => { + existsSyncSpy.mockRestore(); + delete process.env.NX_CACHE_PROJECT_GRAPH; + }); const existsSyncSpy = vi .spyOn(nodeFs, 'existsSync') .mockImplementation((): boolean => true); + const readJsonFileSpy = vi + .spyOn(nxDevKit, 'readJsonFile') + .mockImplementation((): Record> => { + return {'mockKey': mockProjectConfiguration} + }); + + + const mockProjectConfiguration: ProjectConfiguration = { + name: 'mock-project', + root: 'apps/mock-project', + sourceRoot: 'apps/mock-project/src', + projectType: 'application', + tags: ['e2e', 'unit-test'], + implicitDependencies: ['shared-library'], + targets: { + build: { + executor: '@nx/web:build', + options: { + outputPath: 'dist/apps/mock-project', + index: 'apps/mock-project/src/index.html', + main: 'apps/mock-project/src/main.ts', + tsConfig: 'apps/mock-project/tsconfig.app.json', + }, + configurations: { + production: { + fileReplacements: [ + { + replace: 'apps/mock-project/src/environments/environment.ts', + with: 'apps/mock-project/src/environments/environment.prod.ts', + }, + ], + optimization: true, + sourceMap: false, + }, + }, + }, + }, + generators: { + '@nx/react': { + library: { + style: 'scss', + }, + }, + }, + namedInputs: { + default: ['{projectRoot}/**/*', '!{projectRoot}/**/*.spec.ts'], + production: ['default', '!{projectRoot}/**/*.test.ts'], + }, + release: { + version: { + generator: '@nx/version', + generatorOptions: { + increment: 'minor', + }, + }, + }, + metadata: { + description: 'This is a mock project for testing.', + }, + }; + + // beforeEach((): void => { // existsSyncSpy = vi.spyOn(cachingUtils, 'cacheKey'); // }); @@ -99,11 +167,13 @@ describe('caching', () => { existsSyncSpy.mockRestore(); }); - it('should call cacheKey with the correct arguments', (): void => { - readTargetsCache('test'); - + it('should call cacheKey with the correct arguments and return from json file', (): void => { + process.env.NX_CACHE_PROJECT_GRAPH = 'true'; + const targetsCacheResult = readTargetsCache('test'); expect(existsSyncSpy).toHaveBeenCalledWith('test'); expect(existsSyncSpy).toHaveBeenCalledTimes(1); + expect(readJsonFileSpy).toHaveBeenCalledTimes(1); + expect(targetsCacheResult).toStrictEqual({'mockKey': mockProjectConfiguration}); }); }); })