Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wagtail/wagtail-factories
Factory boy classes for wagtail
https://github.com/wagtail/wagtail-factories
factory-boy wagtail
Last synced: 2 months ago
JSON representation
Factory boy classes for wagtail
- Host: GitHub
- URL: https://github.com/wagtail/wagtail-factories
- Owner: wagtail
- License: mit
- Created: 2016-12-08T18:54:13.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2024-05-26T11:22:38.000Z (8 months ago)
- Last Synced: 2024-06-22T05:03:51.164Z (7 months ago)
- Topics: factory-boy, wagtail
- Language: Python
- Homepage: http://wagtail-factories.readthedocs.io/en/latest/
- Size: 166 KB
- Stars: 99
- Watchers: 20
- Forks: 40
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES
- License: LICENSE
Awesome Lists containing this project
- awesome-wagtail - Wagtail Factories - Factory boy classes for Wagtail. (Apps / Testing)
README
# wagtail-factories
Factory boy classes for Wagtail CMS
## Join the Community at Wagtail Space!
Join us at Wagtail Space US this year! The Call for Participation and Registration for both Wagtail Space 2024 events is open. We would love to have you give a talk, or just us as an attendee in June.
* [Wagtail Space NL](https://nl.wagtail.space/), Arnhem, The Netherlands. 2024-06-14
* [Wagtail Space US](https://us.wagtail.space/), Philadelphia, PA. 2024-06-20 to 2024-06-22## Status
[![image](https://readthedocs.org/projects/wagtail-factories/badge/?version=latest)](https://readthedocs.org/projects/wagtail-factories/)
[![image](https://github.com/wagtail/wagtail-factories/workflows/Python%20Tests/badge.svg)](https://github.com/wagtail/wagtail-factories/actions?query=workflow%3A%22Python+Tests%22)
[![image](https://img.shields.io/pypi/v/wagtail-factories.svg)](https://pypi.python.org/pypi/wagtail-factories/)## Installation
``` shell
pip install wagtail-factories
```## Usage
Documentation is still in progress, but see the
[tests](https://github.com/wagtail/wagtail-factories/tree/main/tests)
for more examples.``` python
import wagtail_factories
from . import modelsclass MyCarouselItemFactory(wagtail_factories.StructBlockFactory):
label = 'my-label'
image = factory.SubFactory(
wagtail_factories.ImageChooserBlockFactory)class Meta:
model = models.MyBlockItemclass MyCarouselFactory(wagtail_factories.StructBlockFactory):
title = "Carousel title"
items = wagtail_factories.ListBlockFactory(
MyCarouselItemFactory)class Meta:
model = models.MyCarouselclass MyNewsPageFactory(wagtail_factories.PageFactory):
class Meta:
model = models.MyNewsPageclass MyNewsPageChooserBlockFactory(wagtail_factories.PageChooserBlockFactory):
page = factory.SubFactory(MyNewsPageFactory)class MyTestPageFactory(wagtail_factories.PageFactory):
body = wagtail_factories.StreamFieldFactory({
'carousel': factory.SubFactory(MyCarouselFactory),
'news_page': factory.SubFactory(MyNewsPageChooserBlockFactory),
})class Meta:
model = models.MyTestPagedef test_my_page():
root_page = wagtail_factories.PageFactory(parent=None)
my_page = MyTestPageFactory(
parent=root_page,
body__0__carousel__items__0__label='Slide 1',
body__0__carousel__items__0__image__image__title='Image Slide 1',
body__0__carousel__items__1__label='Slide 2',
body__0__carousel__items__1__image__image__title='Image Slide 2',
body__0__carousel__items__2__label='Slide 3',
body__0__carousel__items__2__image__image__title='Image Slide 3',
body__1__news_page__page__title="News",
)
```### Using StreamBlockFactory
`StreamBlockFactory` can be used in conjunction with the other block
factory types to create complex, nested `StreamValues`, much like how
`StreamBlock` can be used to declare the blocks for a complex
`StreamField`.First, define your `StreamBlockFactory` subclass, using
`factory.SubFactory` to wrap child block declarations. Be sure to
include your `StreamBlock` subclass as the model attribute on the inner
`Meta` class.``` python
class MyStreamBlockFactory(wagtail_factories.StreamBlockFactory):
my_struct_block = factory.SubFactory(MyStructBlockFactory)class Meta:
model = MyStreamBlock
```Then include your `StreamBlockFactory` subclass on a model factory as
the argument to a `StreamFieldFactory`.``` python
class MyPageFactory(wagtail_factories.PageFactory):
body = wagtail_factories.StreamFieldFactory(MyStreamBlockFactory)class Meta:
model = MyPage
```You can then use a modified version of factory\_boy\'s deep object
declaration syntax to build up `StreamValues` on the fly.``` python
MyPageFactory(
body__0__my_struct_block__some_field="some value",
body__0__my_struct_block__some_other_field="some other value",
)
```To generate the default value for a block factory, terminate your
declaration at the index and provide the block name as the value.``` python
MyPageFactory(body__0="my_struct_block")
```### Alternative StreamFieldFactory declaration syntax
Prior to version 3.0, `StreamFieldFactory` could only be used by
providing a dict mapping block names to block factory classes as the
single argument, for example:``` python
class MyTestPageWithStreamFieldFactory(wagtail_factories.PageFactory):
body = wagtail_factories.StreamFieldFactory(
{
"char_array": wagtail_factories.ListBlockFactory(
wagtail_factories.CharBlockFactory
),
"int_array": wagtail_factories.ListBlockFactory(
wagtail_factories.IntegerBlockFactory
),
"struct": MyBlockFactory,
"image": wagtail_factories.ImageChooserBlockFactory,
}
)class Meta:
model = models.MyTestPage
```This style of declaration is still supported, with the caveat that
nested stream blocks are not supported for this approach. From version
3.0, all `BlockFactory` values in a `StreamFieldFactory` definition of
this style *must* be wrapped in factory\_boy `SubFactories`. For
example, the above example must be updated to the following for 3.0
compatibility.``` python
class MyTestPageWithStreamFieldFactory(wagtail_factories.PageFactory):
body = wagtail_factories.StreamFieldFactory(
{
"char_array": wagtail_factories.ListBlockFactory(
wagtail_factories.CharBlockFactory
),
"int_array": wagtail_factories.ListBlockFactory(
wagtail_factories.IntegerBlockFactory
),
"struct": factory.SubFactory(MyBlockFactory),
"image": factory.SubFactory(wagtail_factories.ImageChooserBlockFactory),
}
)class Meta:
model = models.MyTestPage
```This requirement does *not* apply to `ListBlockFactory`, which is a
subclass of `SubFactory`.