mirror of
https://github.com/samanhappy/mcphub.git
synced 2025-12-23 18:29:21 -05:00
98 lines
2.6 KiB
TypeScript
98 lines
2.6 KiB
TypeScript
import fs from 'fs';
|
|
import os from 'os';
|
|
import path from 'path';
|
|
|
|
import { BearerKeyDaoImpl } from '../../src/dao/BearerKeyDao.js';
|
|
|
|
const writeSettings = (settingsPath: string, settings: unknown): void => {
|
|
fs.writeFileSync(settingsPath, JSON.stringify(settings, null, 2), 'utf8');
|
|
};
|
|
|
|
describe('BearerKeyDaoImpl migration + settings caching behavior', () => {
|
|
let tmpDir: string;
|
|
let settingsPath: string;
|
|
let originalSettingsEnv: string | undefined;
|
|
|
|
beforeEach(() => {
|
|
tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), 'mcphub-bearer-keys-'));
|
|
settingsPath = path.join(tmpDir, 'mcp_settings.json');
|
|
|
|
originalSettingsEnv = process.env.MCPHUB_SETTING_PATH;
|
|
process.env.MCPHUB_SETTING_PATH = settingsPath;
|
|
});
|
|
|
|
afterEach(() => {
|
|
if (originalSettingsEnv === undefined) {
|
|
delete process.env.MCPHUB_SETTING_PATH;
|
|
} else {
|
|
process.env.MCPHUB_SETTING_PATH = originalSettingsEnv;
|
|
}
|
|
|
|
try {
|
|
fs.rmSync(tmpDir, { recursive: true, force: true });
|
|
} catch {
|
|
// ignore cleanup errors
|
|
}
|
|
});
|
|
|
|
it('does not rewrite settings when bearerKeys exists as an empty array', async () => {
|
|
writeSettings(settingsPath, {
|
|
mcpServers: {},
|
|
users: [],
|
|
systemConfig: {
|
|
routing: {
|
|
enableBearerAuth: false,
|
|
bearerAuthKey: '',
|
|
},
|
|
},
|
|
bearerKeys: [],
|
|
});
|
|
|
|
const writeSpy = jest.spyOn(fs, 'writeFileSync');
|
|
|
|
const dao = new BearerKeyDaoImpl();
|
|
const enabled1 = await dao.findEnabled();
|
|
const enabled2 = await dao.findEnabled();
|
|
|
|
expect(enabled1).toEqual([]);
|
|
expect(enabled2).toEqual([]);
|
|
|
|
// The DAO should NOT persist anything because bearerKeys already exists.
|
|
expect(writeSpy).not.toHaveBeenCalled();
|
|
|
|
writeSpy.mockRestore();
|
|
});
|
|
|
|
it('migrates legacy bearerAuthKey only once', async () => {
|
|
writeSettings(settingsPath, {
|
|
mcpServers: {},
|
|
users: [],
|
|
systemConfig: {
|
|
routing: {
|
|
enableBearerAuth: true,
|
|
bearerAuthKey: 'legacy-token',
|
|
},
|
|
},
|
|
// bearerKeys is intentionally missing to trigger migration
|
|
});
|
|
|
|
const writeSpy = jest.spyOn(fs, 'writeFileSync');
|
|
|
|
const dao = new BearerKeyDaoImpl();
|
|
|
|
const enabled1 = await dao.findEnabled();
|
|
expect(enabled1).toHaveLength(1);
|
|
expect(enabled1[0].token).toBe('legacy-token');
|
|
expect(enabled1[0].enabled).toBe(true);
|
|
|
|
const enabled2 = await dao.findEnabled();
|
|
expect(enabled2).toHaveLength(1);
|
|
expect(enabled2[0].token).toBe('legacy-token');
|
|
|
|
// One write for the migration, no further writes on subsequent reads.
|
|
expect(writeSpy).toHaveBeenCalledTimes(1);
|
|
|
|
writeSpy.mockRestore();
|
|
});
|
|
});
|