mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-04-27 05:24:34 -07:00
fix(core): cache CLI version to ensure consistency during sessions (#18793)
This commit is contained in:
@@ -18,6 +18,7 @@ import { LoggingContentGenerator } from './loggingContentGenerator.js';
|
|||||||
import { loadApiKey } from './apiKeyCredentialStorage.js';
|
import { loadApiKey } from './apiKeyCredentialStorage.js';
|
||||||
import { FakeContentGenerator } from './fakeContentGenerator.js';
|
import { FakeContentGenerator } from './fakeContentGenerator.js';
|
||||||
import { RecordingContentGenerator } from './recordingContentGenerator.js';
|
import { RecordingContentGenerator } from './recordingContentGenerator.js';
|
||||||
|
import { resetVersionCache } from '../utils/version.js';
|
||||||
|
|
||||||
vi.mock('../code_assist/codeAssist.js');
|
vi.mock('../code_assist/codeAssist.js');
|
||||||
vi.mock('@google/genai');
|
vi.mock('@google/genai');
|
||||||
@@ -35,6 +36,7 @@ const mockConfig = {
|
|||||||
|
|
||||||
describe('createContentGenerator', () => {
|
describe('createContentGenerator', () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
|
resetVersionCache();
|
||||||
vi.clearAllMocks();
|
vi.clearAllMocks();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
||||||
import { getVersion } from './version.js';
|
import { getVersion, resetVersionCache } from './version.js';
|
||||||
import { getPackageJson } from './package.js';
|
import { getPackageJson } from './package.js';
|
||||||
|
|
||||||
vi.mock('./package.js', () => ({
|
vi.mock('./package.js', () => ({
|
||||||
@@ -17,6 +17,8 @@ describe('version', () => {
|
|||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
vi.resetModules();
|
vi.resetModules();
|
||||||
|
vi.clearAllMocks();
|
||||||
|
resetVersionCache();
|
||||||
process.env = { ...originalEnv };
|
process.env = { ...originalEnv };
|
||||||
vi.mocked(getPackageJson).mockResolvedValue({ version: '1.0.0' });
|
vi.mocked(getPackageJson).mockResolvedValue({ version: '1.0.0' });
|
||||||
});
|
});
|
||||||
@@ -43,4 +45,20 @@ describe('version', () => {
|
|||||||
const version = await getVersion();
|
const version = await getVersion();
|
||||||
expect(version).toBe('unknown');
|
expect(version).toBe('unknown');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should cache the version and only call getPackageJson once', async () => {
|
||||||
|
delete process.env['CLI_VERSION'];
|
||||||
|
vi.mocked(getPackageJson).mockResolvedValue({ version: '1.2.3' });
|
||||||
|
|
||||||
|
const version1 = await getVersion();
|
||||||
|
expect(version1).toBe('1.2.3');
|
||||||
|
expect(getPackageJson).toHaveBeenCalledTimes(1);
|
||||||
|
|
||||||
|
// Change the mock value to simulate an update on disk
|
||||||
|
vi.mocked(getPackageJson).mockResolvedValue({ version: '2.0.0' });
|
||||||
|
|
||||||
|
const version2 = await getVersion();
|
||||||
|
expect(version2).toBe('1.2.3'); // Should still be the cached version
|
||||||
|
expect(getPackageJson).toHaveBeenCalledTimes(1); // Should not have been called again
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -11,7 +11,20 @@ import path from 'node:path';
|
|||||||
const __filename = fileURLToPath(import.meta.url);
|
const __filename = fileURLToPath(import.meta.url);
|
||||||
const __dirname = path.dirname(__filename);
|
const __dirname = path.dirname(__filename);
|
||||||
|
|
||||||
export async function getVersion(): Promise<string> {
|
let versionPromise: Promise<string> | undefined;
|
||||||
const pkgJson = await getPackageJson(__dirname);
|
|
||||||
return process.env['CLI_VERSION'] || pkgJson?.version || 'unknown';
|
export function getVersion(): Promise<string> {
|
||||||
|
if (versionPromise) {
|
||||||
|
return versionPromise;
|
||||||
|
}
|
||||||
|
versionPromise = (async () => {
|
||||||
|
const pkgJson = await getPackageJson(__dirname);
|
||||||
|
return process.env['CLI_VERSION'] || pkgJson?.version || 'unknown';
|
||||||
|
})();
|
||||||
|
return versionPromise;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** For testing purposes only */
|
||||||
|
export function resetVersionCache(): void {
|
||||||
|
versionPromise = undefined;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user