fix: fixed the language thing and handling of project settings
This commit is contained in:
@@ -359,6 +359,34 @@ describe('PreviewServer', () => {
|
||||
expect(html).toContain('<html lang="de">');
|
||||
});
|
||||
|
||||
it('initializes metadata before reading language when supported by settings engine', async () => {
|
||||
let initialized = false;
|
||||
|
||||
server = new PreviewServer({
|
||||
postEngine: makeEngine([makePost()]),
|
||||
settingsEngine: {
|
||||
setProjectContext: vi.fn(),
|
||||
isInitialized: vi.fn(() => initialized),
|
||||
syncOnStartup: vi.fn(async () => {
|
||||
initialized = true;
|
||||
}),
|
||||
async getProjectMetadata() {
|
||||
return initialized
|
||||
? { name: 'My Great Blog', mainLanguage: 'fr', maxPostsPerPage: 50 }
|
||||
: null;
|
||||
},
|
||||
} as any,
|
||||
getActiveProjectContext: async () => ({ projectId: 'default' }),
|
||||
});
|
||||
|
||||
await server.start(0);
|
||||
|
||||
const response = await fetch(`${server.getBaseUrl()}/`);
|
||||
expect(response.status).toBe(200);
|
||||
const html = await response.text();
|
||||
expect(html).toContain('<html lang="fr">');
|
||||
});
|
||||
|
||||
it('falls back to active project name in page title when metadata is unavailable', async () => {
|
||||
server = new PreviewServer({
|
||||
postEngine: makeEngine([makePost()]),
|
||||
|
||||
@@ -106,6 +106,7 @@ const mockProjectEngine = {
|
||||
const mockMetaEngine = {
|
||||
on: vi.fn(),
|
||||
setProjectContext: vi.fn(),
|
||||
isInitialized: vi.fn(),
|
||||
syncOnStartup: vi.fn(),
|
||||
getTags: vi.fn(),
|
||||
getCategories: vi.fn(),
|
||||
@@ -1166,6 +1167,7 @@ describe('IPC Handlers', () => {
|
||||
describe('meta:getProjectMetadata', () => {
|
||||
it('should return project metadata', async () => {
|
||||
const metadata = { name: 'Test Blog', description: 'A test blog', mainLanguage: 'de' };
|
||||
mockMetaEngine.isInitialized.mockReturnValue(true);
|
||||
mockMetaEngine.getProjectMetadata.mockResolvedValue(metadata);
|
||||
|
||||
const result = await invokeHandler('meta:getProjectMetadata');
|
||||
@@ -1173,6 +1175,19 @@ describe('IPC Handlers', () => {
|
||||
expect(mockMetaEngine.getProjectMetadata).toHaveBeenCalled();
|
||||
expect(result).toEqual(metadata);
|
||||
});
|
||||
|
||||
it('should sync metadata before reading when engine is not initialized', async () => {
|
||||
const metadata = { name: 'Test Blog', mainLanguage: 'de', defaultAuthor: 'Max' };
|
||||
mockMetaEngine.isInitialized.mockReturnValue(false);
|
||||
mockMetaEngine.syncOnStartup.mockResolvedValue(undefined);
|
||||
mockMetaEngine.getProjectMetadata.mockResolvedValue(metadata);
|
||||
|
||||
const result = await invokeHandler('meta:getProjectMetadata');
|
||||
|
||||
expect(mockMetaEngine.syncOnStartup).toHaveBeenCalled();
|
||||
expect(mockMetaEngine.getProjectMetadata).toHaveBeenCalled();
|
||||
expect(result).toEqual(metadata);
|
||||
});
|
||||
});
|
||||
|
||||
describe('meta:setProjectMetadata', () => {
|
||||
|
||||
Reference in New Issue
Block a user