Mercurial > piecrust2
view tests/test_data_provider.py @ 338:938be93215cb
bake: Improve render context and bake record, fix incremental bake bugs.
* Used sources and taxonomies are now stored on a per-render-pass basis.
This fixes bugs where sources/taxonomies were used for one pass, but that
pass is skipped on a later bake because its result is cached.
* Bake records are now created for all pages even when they're not baked.
Record collapsing is gone except for taxonomy index pages.
* Bake records now also have sub-entries in order to store information about
each sub-page, since some sub-pages could use sources/taxonomies differently
than others, or be missing from the output. This lets PieCrust handle
clean/dirty states on a sub-page level.
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Mon, 06 Apr 2015 19:59:54 -0700 |
parents | 59d65654184e |
children | 4b1019bb2533 |
line wrap: on
line source
from piecrust.rendering import PageRenderingContext, render_page from .mockutil import mock_fs, mock_fs_scope def test_blog_provider(): fs = (mock_fs() .withPage('posts/2015-03-01_one.md', {'title': 'One', 'category': 'Foo'}) .withPage('posts/2015-03-02_two.md', {'title': 'Two', 'category': 'Foo'}) .withPage('posts/2015-03-03_three.md', {'title': 'Three', 'category': 'Bar'}) .withPage('pages/categories.md', {'format': 'none', 'layout': 'none'}, "{%for c in blog.categories%}\n" "{{c.name}} ({{c.post_count}})\n" "{%endfor%}\n")) with mock_fs_scope(fs): app = fs.getApp() page = app.getSource('pages').getPage({'slug': 'categories'}) ctx = PageRenderingContext(page, '/categories') rp = render_page(ctx) expected = "\nBar (1)\n\nFoo (2)\n" assert rp.content == expected