* chore: updated todo with translation ideas * feat: first take at the implementation of translations * fix: small addition for the translation feature * feat: support language switching in the editor and preview * feat: better handling of long bodies by not running them through a json envelope * fix: unknown macros have better fallback * feat: api for python to get translations * fix: strip dumb prefix of content in translation * feat: extend meta diff for translations * feat: hook up translations to rebuild-from-disk * feat: generation of the website prefers project language, falling back to canonical language * fix: crashes during rendering * feat: translation validation report * fix: made the translation validation actually work * chore: reorganization of menu * fix: some topics cleanup * chore: updated doc * feat: translations for media * feat: more aligned in UI/UX * feat: edit translations possible * chore: added full multi-language todo * chore: updated todo for clarity * feat: implementation of full multi-linguality * fix: page creation creates pages * fix: flags on every page * fix: better prompt * feat: made MCP server aware of language content * feat: python tools for translations * fix: better fill-in-translations * fix: better prompt for translation. maybe. * fix: losing posts from search due to translation process * fix: translation validation handles in-db content and fill-in of missing translations fixed to flush * fix: faster scanning for infilling of missing translations * chore: updated agent instructions * feat: calendar and tag cloud respect current language now * fix: retries going up * fix: got metadata-diff and rebuild into sync * fix: extended meta-diff for timestamps * fix: made website validation look at translated content, too * fix: multi-lingual search * chore: refactor Editor.tsx into two separate editors * feat: do language detection when no explicit language given --------- Co-authored-by: hugo <hugoms@me.com>
77 lines
2.1 KiB
TypeScript
77 lines
2.1 KiB
TypeScript
import { describe, expect, it, vi } from 'vitest';
|
|
import { createAndFocusPost } from '../../../src/renderer/navigation/postCreation';
|
|
|
|
describe('postCreation', () => {
|
|
it('creates a post, focuses it, and optionally ensures posts sidebar', async () => {
|
|
const createPost = vi.fn().mockResolvedValue({ id: 'post-1' });
|
|
const setSelectedPost = vi.fn();
|
|
const ensurePostsSidebar = vi.fn();
|
|
|
|
const result = await createAndFocusPost({
|
|
createPost,
|
|
setSelectedPost,
|
|
ensurePostsSidebar,
|
|
});
|
|
|
|
expect(createPost).toHaveBeenCalledWith({
|
|
title: '',
|
|
content: '',
|
|
tags: [],
|
|
categories: [],
|
|
});
|
|
expect(setSelectedPost).toHaveBeenCalledWith('post-1');
|
|
expect(ensurePostsSidebar).toHaveBeenCalledTimes(1);
|
|
expect(result).toBe('post-1');
|
|
});
|
|
|
|
it('returns null and does not focus when create returns nullish', async () => {
|
|
const createPost = vi.fn().mockResolvedValue(null);
|
|
const setSelectedPost = vi.fn();
|
|
const ensurePostsSidebar = vi.fn();
|
|
|
|
const result = await createAndFocusPost({
|
|
createPost,
|
|
setSelectedPost,
|
|
ensurePostsSidebar,
|
|
});
|
|
|
|
expect(setSelectedPost).not.toHaveBeenCalled();
|
|
expect(ensurePostsSidebar).not.toHaveBeenCalled();
|
|
expect(result).toBeNull();
|
|
});
|
|
|
|
it('passes provided categories to createPost', async () => {
|
|
const createPost = vi.fn().mockResolvedValue({ id: 'page-1' });
|
|
const setSelectedPost = vi.fn();
|
|
|
|
await createAndFocusPost({
|
|
createPost,
|
|
setSelectedPost,
|
|
categories: ['page'],
|
|
});
|
|
|
|
expect(createPost).toHaveBeenCalledWith({
|
|
title: '',
|
|
content: '',
|
|
tags: [],
|
|
categories: ['page'],
|
|
});
|
|
});
|
|
|
|
it('returns null and reports errors', async () => {
|
|
const createPost = vi.fn().mockRejectedValue(new Error('fail'));
|
|
const setSelectedPost = vi.fn();
|
|
const onError = vi.fn();
|
|
|
|
const result = await createAndFocusPost({
|
|
createPost,
|
|
setSelectedPost,
|
|
onError,
|
|
});
|
|
|
|
expect(setSelectedPost).not.toHaveBeenCalled();
|
|
expect(onError).toHaveBeenCalledTimes(1);
|
|
expect(result).toBeNull();
|
|
});
|
|
});
|