Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
2e2f63755e |
161
.github/workflows/python-test.yml
vendored
161
.github/workflows/python-test.yml
vendored
@@ -1,161 +0,0 @@
|
|||||||
---
|
|
||||||
name: Python Tests
|
|
||||||
|
|
||||||
on: [push, pull_request]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
format:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Set up Python 3.8
|
|
||||||
uses: actions/setup-python@v1
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- name: Install dependencies
|
|
||||||
run: pip install tox
|
|
||||||
- name: Validate formatting
|
|
||||||
run: tox -e format
|
|
||||||
|
|
||||||
test:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
strategy:
|
|
||||||
max-parallel: 4
|
|
||||||
matrix:
|
|
||||||
tox_env:
|
|
||||||
- py36-dj22-wt25
|
|
||||||
- py36-dj22-wt26
|
|
||||||
- py36-dj22-wt27
|
|
||||||
- py36-dj22-wt28
|
|
||||||
- py36-dj22-wt29
|
|
||||||
- py36-dj22-wt210
|
|
||||||
- py36-dj22-wt211
|
|
||||||
- py36-dj22-wt212
|
|
||||||
- py36-dj22-wt213
|
|
||||||
- py37-dj22-wt25
|
|
||||||
- py37-dj22-wt26
|
|
||||||
- py37-dj22-wt27
|
|
||||||
- py37-dj22-wt28
|
|
||||||
- py37-dj22-wt29
|
|
||||||
- py37-dj22-wt210
|
|
||||||
- py37-dj22-wt211
|
|
||||||
- py37-dj22-wt212
|
|
||||||
- py37-dj22-wt213
|
|
||||||
- py38-dj22-wt25
|
|
||||||
- py38-dj22-wt26
|
|
||||||
- py38-dj22-wt27
|
|
||||||
- py38-dj22-wt28
|
|
||||||
- py38-dj22-wt29
|
|
||||||
- py38-dj22-wt210
|
|
||||||
- py38-dj22-wt211
|
|
||||||
- py38-dj22-wt212
|
|
||||||
- py38-dj22-wt213
|
|
||||||
- py37-dj30-wt28
|
|
||||||
- py37-dj30-wt29
|
|
||||||
- py37-dj30-wt210
|
|
||||||
- py37-dj30-wt211
|
|
||||||
- py37-dj30-wt212
|
|
||||||
- py37-dj30-wt213
|
|
||||||
- py38-dj30-wt28
|
|
||||||
- py38-dj30-wt29
|
|
||||||
- py38-dj30-wt210
|
|
||||||
- py38-dj30-wt211
|
|
||||||
- py38-dj30-wt212
|
|
||||||
- py38-dj30-wt213
|
|
||||||
include:
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt25
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt26
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt27
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt28
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt29
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt210
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt211
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt212
|
|
||||||
- python-version: 3.6
|
|
||||||
tox_env: py36-dj22-wt213
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt25
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt26
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt27
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt28
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt29
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt210
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt211
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt212
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj22-wt213
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt25
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt26
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt27
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt28
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt29
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt210
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt211
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt212
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj22-wt213
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt28
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt29
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt210
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt211
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt212
|
|
||||||
- python-version: 3.7
|
|
||||||
tox_env: py37-dj30-wt213
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt28
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt29
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt210
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt211
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt212
|
|
||||||
- python-version: 3.8
|
|
||||||
tox_env: py38-dj30-wt213
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Set up Python ${{ matrix.python-version }}
|
|
||||||
uses: actions/setup-python@v1
|
|
||||||
with:
|
|
||||||
python-version: ${{ matrix.python-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
python -m pip install --upgrade pip
|
|
||||||
pip install tox tox-gh-actions
|
|
||||||
- name: Test with tox
|
|
||||||
run: tox -e ${{ matrix.tox_env }} --index-url=https://pypi.python.org/simple/
|
|
||||||
- name: Prepare artifacts
|
|
||||||
run: mkdir -p .coverage-data && mv .coverage.* .coverage-data/
|
|
||||||
- uses: actions/upload-artifact@master
|
|
||||||
with:
|
|
||||||
name: coverage-data
|
|
||||||
path: .coverage-data/
|
|
@@ -36,8 +36,6 @@ matrix:
|
|||||||
env: TOXENV=py36-django22-wagtail26-geoip2
|
env: TOXENV=py36-django22-wagtail26-geoip2
|
||||||
- python: 3.6
|
- python: 3.6
|
||||||
env: TOXENV=py36-django111-wagtail22
|
env: TOXENV=py36-django111-wagtail22
|
||||||
- python: 3.6
|
|
||||||
env: TOXENV=py36-django22-wagtail211-geoip2
|
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- pip install tox codecov
|
- pip install tox codecov
|
||||||
|
@@ -62,10 +62,10 @@ author = 'Lab Digital BV'
|
|||||||
# built documents.
|
# built documents.
|
||||||
#
|
#
|
||||||
# The short X.Y version.
|
# The short X.Y version.
|
||||||
version = '0.15.0'
|
version = '0.14.0'
|
||||||
|
|
||||||
# The full version, including alpha/beta/rc tags.
|
# The full version, including alpha/beta/rc tags.
|
||||||
release = '0.15.0'
|
release = '0.14.0'
|
||||||
|
|
||||||
# The language for content autogenerated by Sphinx. Refer to documentation
|
# The language for content autogenerated by Sphinx. Refer to documentation
|
||||||
# for a list of supported languages.
|
# for a list of supported languages.
|
||||||
|
@@ -14,7 +14,6 @@ from __future__ import absolute_import, unicode_literals
|
|||||||
|
|
||||||
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
||||||
import os
|
import os
|
||||||
from importlib.util import find_spec
|
|
||||||
|
|
||||||
PROJECT_DIR = os.path.dirname(os.path.abspath(__file__))
|
PROJECT_DIR = os.path.dirname(os.path.abspath(__file__))
|
||||||
BASE_DIR = os.path.dirname(PROJECT_DIR)
|
BASE_DIR = os.path.dirname(PROJECT_DIR)
|
||||||
@@ -79,14 +78,11 @@ MIDDLEWARE = [
|
|||||||
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||||
'django.contrib.messages.middleware.MessageMiddleware',
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
|
|
||||||
|
'wagtail.core.middleware.SiteMiddleware',
|
||||||
'wagtail.contrib.redirects.middleware.RedirectMiddleware',
|
'wagtail.contrib.redirects.middleware.RedirectMiddleware',
|
||||||
]
|
]
|
||||||
|
|
||||||
if find_spec('wagtail.contrib.legacy'):
|
|
||||||
MIDDLEWARE += ('wagtail.contrib.legacy.sitemiddleware.SiteMiddleware',)
|
|
||||||
else:
|
|
||||||
MIDDLEWARE += ('wagtail.core.middleware.SiteMiddleware', )
|
|
||||||
|
|
||||||
ROOT_URLCONF = 'sandbox.urls'
|
ROOT_URLCONF = 'sandbox.urls'
|
||||||
|
|
||||||
TEMPLATES = [
|
TEMPLATES = [
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
[bumpversion]
|
[bumpversion]
|
||||||
current_version = 0.15.0
|
current_version = 0.14.0
|
||||||
commit = true
|
commit = true
|
||||||
tag = true
|
tag = true
|
||||||
tag_name = {new_version}
|
tag_name = {new_version}
|
||||||
@@ -28,3 +28,4 @@ omit = src/**/migrations/*.py
|
|||||||
[bumpversion:file:setup.py]
|
[bumpversion:file:setup.py]
|
||||||
|
|
||||||
[bumpversion:file:docs/conf.py]
|
[bumpversion:file:docs/conf.py]
|
||||||
|
|
||||||
|
8
setup.py
8
setup.py
@@ -12,14 +12,14 @@ tests_require = [
|
|||||||
'factory_boy==2.8.1',
|
'factory_boy==2.8.1',
|
||||||
'flake8-blind-except',
|
'flake8-blind-except',
|
||||||
'flake8-debugger',
|
'flake8-debugger',
|
||||||
'flake8-isort',
|
'flake8-imports',
|
||||||
'flake8',
|
'flake8',
|
||||||
'freezegun==0.3.8',
|
'freezegun==0.3.8',
|
||||||
'pytest-cov==2.5.1',
|
'pytest-cov==2.5.1',
|
||||||
'pytest-django==4.1.0',
|
'pytest-django==3.1.2',
|
||||||
'pytest-pythonpath==0.7.2',
|
'pytest-pythonpath==0.7.2',
|
||||||
'pytest-sugar==0.9.1',
|
'pytest-sugar==0.9.1',
|
||||||
'pytest==6.1.2',
|
'pytest==3.4.2',
|
||||||
'wagtail_factories==1.1.0',
|
'wagtail_factories==1.1.0',
|
||||||
'pytest-mock==1.6.3',
|
'pytest-mock==1.6.3',
|
||||||
]
|
]
|
||||||
@@ -35,7 +35,7 @@ with open('README.rst') as fh:
|
|||||||
|
|
||||||
setup(
|
setup(
|
||||||
name='wagtail-personalisation',
|
name='wagtail-personalisation',
|
||||||
version='0.15.0',
|
version='0.14.0',
|
||||||
description='A Wagtail add-on for showing personalized content',
|
description='A Wagtail add-on for showing personalized content',
|
||||||
author='Lab Digital BV and others',
|
author='Lab Digital BV and others',
|
||||||
author_email='opensource@labdigital.nl',
|
author_email='opensource@labdigital.nl',
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
import functools
|
|
||||||
from importlib import import_module
|
from importlib import import_module
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.contrib.auth import get_user_model
|
from django.contrib.auth import get_user_model
|
||||||
from django.contrib.auth.models import AnonymousUser
|
from django.contrib.auth.models import AnonymousUser
|
||||||
from django.templatetags.static import static
|
from django.contrib.staticfiles.templatetags.staticfiles import static
|
||||||
from django.test.client import RequestFactory
|
from django.test.client import RequestFactory
|
||||||
|
from django.utils.lru_cache import lru_cache
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from wagtail.admin.forms import WagtailAdminModelForm
|
from wagtail.admin.forms import WagtailAdminModelForm
|
||||||
|
|
||||||
SessionStore = import_module(settings.SESSION_ENGINE).SessionStore
|
SessionStore = import_module(settings.SESSION_ENGINE).SessionStore
|
||||||
|
|
||||||
|
|
||||||
@functools.lru_cache(maxsize=1000)
|
@lru_cache(maxsize=1000)
|
||||||
def user_from_data(user_id):
|
def user_from_data(user_id):
|
||||||
User = get_user_model()
|
User = get_user_model()
|
||||||
try:
|
try:
|
||||||
|
@@ -419,7 +419,7 @@ class UserIsLoggedInRule(AbstractBaseRule):
|
|||||||
verbose_name = _('Logged in Rule')
|
verbose_name = _('Logged in Rule')
|
||||||
|
|
||||||
def test_user(self, request=None):
|
def test_user(self, request=None):
|
||||||
return request.user.is_authenticated == self.is_logged_in
|
return request.user.is_authenticated() == self.is_logged_in
|
||||||
|
|
||||||
def description(self):
|
def description(self):
|
||||||
return {
|
return {
|
||||||
|
@@ -11,12 +11,7 @@ from django.utils.safestring import mark_safe
|
|||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from wagtail.admin import messages
|
from wagtail.admin import messages
|
||||||
from wagtail.admin.site_summary import PagesSummaryItem, SummaryItem
|
from wagtail.admin.site_summary import PagesSummaryItem, SummaryItem
|
||||||
|
from wagtail.admin.views.pages import get_valid_next_url_from_request
|
||||||
try:
|
|
||||||
from wagtail.admin.views.pages.utils import get_valid_next_url_from_request
|
|
||||||
except ModuleNotFoundError:
|
|
||||||
from wagtail.admin.views.pages import get_valid_next_url_from_request # noqa
|
|
||||||
|
|
||||||
from wagtail.admin.widgets import Button, ButtonWithDropdownFromHook
|
from wagtail.admin.widgets import Button, ButtonWithDropdownFromHook
|
||||||
from wagtail.core import hooks
|
from wagtail.core import hooks
|
||||||
from wagtail.core.models import Page
|
from wagtail.core.models import Page
|
||||||
@@ -28,8 +23,6 @@ from wagtail_personalisation.models import PersonalisablePageMetadata
|
|||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@hooks.register('register_admin_urls')
|
@hooks.register('register_admin_urls')
|
||||||
def register_admin_urls():
|
def register_admin_urls():
|
||||||
"""Adds the administration urls for the personalisation apps."""
|
"""Adds the administration urls for the personalisation apps."""
|
||||||
|
@@ -7,16 +7,6 @@ from wagtail_factories.factories import PageFactory
|
|||||||
from tests.site.pages import models
|
from tests.site.pages import models
|
||||||
from wagtail_personalisation.models import PersonalisablePageMetadata
|
from wagtail_personalisation.models import PersonalisablePageMetadata
|
||||||
|
|
||||||
try:
|
|
||||||
from wagtail.core.models import Locale
|
|
||||||
|
|
||||||
class LocaleFactory(factory.DjangoModelFactory):
|
|
||||||
language_code = "en"
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = Locale
|
|
||||||
except ImportError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
class ContentPageFactory(PageFactory):
|
class ContentPageFactory(PageFactory):
|
||||||
parent = None
|
parent = None
|
||||||
|
@@ -23,7 +23,7 @@ def site():
|
|||||||
return site
|
return site
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
@pytest.fixture
|
||||||
def segmented_page(site):
|
def segmented_page(site):
|
||||||
page = ContentPageFactory(parent=site.root_page, slug='personalised')
|
page = ContentPageFactory(parent=site.root_page, slug='personalised')
|
||||||
segment = SegmentFactory()
|
segment = SegmentFactory()
|
||||||
@@ -46,6 +46,6 @@ class RequestFactory(BaseRequestFactory):
|
|||||||
return request
|
return request
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
@pytest.fixture
|
||||||
def user(django_user_model):
|
def user(django_user_model):
|
||||||
return django_user_model.objects.create(username='user')
|
return django_user_model.objects.create(username='user')
|
||||||
|
@@ -1,5 +1,4 @@
|
|||||||
import os
|
import os
|
||||||
from importlib.util import find_spec
|
|
||||||
|
|
||||||
DATABASES = {
|
DATABASES = {
|
||||||
'default': {
|
'default': {
|
||||||
@@ -59,14 +58,10 @@ MIDDLEWARE = (
|
|||||||
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||||
'django.contrib.messages.middleware.MessageMiddleware',
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
|
|
||||||
|
'wagtail.core.middleware.SiteMiddleware',
|
||||||
)
|
)
|
||||||
|
|
||||||
if find_spec('wagtail.contrib.legacy'):
|
|
||||||
MIDDLEWARE += ('wagtail.contrib.legacy.sitemiddleware.SiteMiddleware',)
|
|
||||||
else:
|
|
||||||
MIDDLEWARE += ('wagtail.core.middleware.SiteMiddleware', )
|
|
||||||
|
|
||||||
|
|
||||||
INSTALLED_APPS = (
|
INSTALLED_APPS = (
|
||||||
'wagtail_personalisation',
|
'wagtail_personalisation',
|
||||||
|
|
||||||
|
@@ -76,8 +76,5 @@ def test_sitemap_generation_for_variants_is_disabled(segmented_page):
|
|||||||
@pytest.mark.django_db
|
@pytest.mark.django_db
|
||||||
def test_segment_edit_view(site, client, django_user_model):
|
def test_segment_edit_view(site, client, django_user_model):
|
||||||
test_segment = SegmentFactory()
|
test_segment = SegmentFactory()
|
||||||
try:
|
new_panel = test_segment.panels[1].children[0].bind_to_model(Segment)
|
||||||
new_panel = test_segment.panels[1].children[0].bind_to(model=Segment)
|
|
||||||
except AttributeError:
|
|
||||||
new_panel = test_segment.panels[1].children[0].bind_to_model(Segment)
|
|
||||||
assert new_panel.related.name == "wagtail_personalisation_timerules"
|
assert new_panel.related.name == "wagtail_personalisation_timerules"
|
||||||
|
@@ -2,20 +2,12 @@ import pytest
|
|||||||
from django.test import override_settings
|
from django.test import override_settings
|
||||||
from wagtail.core.models import Page as WagtailPage
|
from wagtail.core.models import Page as WagtailPage
|
||||||
|
|
||||||
from tests.factories.page import (ContentPageFactory, PersonalisablePageMetadataFactory)
|
from tests.factories.page import (
|
||||||
|
ContentPageFactory, PersonalisablePageMetadataFactory)
|
||||||
from wagtail_personalisation.utils import (
|
from wagtail_personalisation.utils import (
|
||||||
can_delete_pages, exclude_variants, get_client_ip, impersonate_other_page)
|
can_delete_pages, exclude_variants, get_client_ip, impersonate_other_page)
|
||||||
|
|
||||||
|
|
||||||
locale_factory = False
|
|
||||||
|
|
||||||
try:
|
|
||||||
from tests.factories.page import LocaleFactory
|
|
||||||
locale_factory = True
|
|
||||||
except ImportError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def rootpage():
|
def rootpage():
|
||||||
return ContentPageFactory(parent=None, path='/', depth=0, title='root')
|
return ContentPageFactory(parent=None, path='/', depth=0, title='root')
|
||||||
|
@@ -106,5 +106,5 @@ def test_segment_delete_view_raises_permission_denied(rf, segmented_page, user):
|
|||||||
)
|
)
|
||||||
view.request = request
|
view.request = request
|
||||||
message = 'User have no permission to delete variant page objects.'
|
message = 'User have no permission to delete variant page objects.'
|
||||||
with pytest.raises(PermissionDenied):
|
with pytest.raises(PermissionDenied, message=message):
|
||||||
view.delete_instance()
|
view.delete_instance()
|
||||||
|
49
tox.ini
49
tox.ini
@@ -1,37 +1,21 @@
|
|||||||
[tox]
|
[tox]
|
||||||
envlist =
|
envlist = py{36}-django{111,20,21,22}-wagtail{20,21,22,23,24,25,26}{,-geoip2},lint
|
||||||
flake8
|
|
||||||
py{36,37,38}-dj{22}-wt{25,26,27,28,29,210,211,212,213}
|
|
||||||
py{37,38}-dj{30,31}-wt{28,29,210,211,212,213}
|
|
||||||
|
|
||||||
[gh-actions]
|
|
||||||
python =
|
|
||||||
3.6: py36
|
|
||||||
3.7: py37
|
|
||||||
3.8: py38
|
|
||||||
|
|
||||||
[testenv]
|
[testenv]
|
||||||
basepython =
|
basepython = python3.6
|
||||||
py36: python3.6
|
|
||||||
py37: python3.7
|
|
||||||
py38: python3.8
|
|
||||||
commands = coverage run --parallel -m pytest -rs {posargs}
|
commands = coverage run --parallel -m pytest -rs {posargs}
|
||||||
extras = test
|
extras = test
|
||||||
deps =
|
deps =
|
||||||
dj22: Django>=2.2.8,<2.3
|
django20: django>=2.0,<2.1
|
||||||
dj30: Django>=3.0,<3.1
|
django21: django>=2.1,<2.2
|
||||||
dj31: Django>=3.1,<3.2
|
django22: django>=2.2,<2.3
|
||||||
wt23: wagtail>=2.3,<2.4
|
wagtail20: wagtail>=2.0,<2.1
|
||||||
wt24: wagtail>=2.4,<2.5
|
wagtail21: wagtail>=2.1,<2.2
|
||||||
wt25: wagtail>=2.5,<2.6
|
wagtail22: wagtail>=2.2,<2.3
|
||||||
wt26: wagtail>=2.6,<2.7
|
wagtail23: wagtail>=2.3,<2.4
|
||||||
wt27: wagtail>=2.7,<2.8
|
wagtail24: wagtail>=2.4,<2.5
|
||||||
wt28: wagtail>=2.8,<2.9
|
wagtail25: wagtail>=2.5,<2.6
|
||||||
wt29: wagtail>=2.9,<2.10
|
wagtail26: wagtail>=2.6,<2.7
|
||||||
wt210: wagtail>=2.10,<2.11
|
|
||||||
wt211: wagtail>=2.11,<2.12
|
|
||||||
wt212: wagtail>=2.12,<2.13
|
|
||||||
wt213: wagtail>=2.13,<2.14
|
|
||||||
geoip2: geoip2
|
geoip2: geoip2
|
||||||
django111: django>=1.11,<1.12
|
django111: django>=1.11,<1.12
|
||||||
|
|
||||||
@@ -49,12 +33,3 @@ deps = flake8==3.5.0
|
|||||||
commands =
|
commands =
|
||||||
flake8 src tests setup.py
|
flake8 src tests setup.py
|
||||||
isort -q --recursive --diff src/ tests/
|
isort -q --recursive --diff src/ tests/
|
||||||
|
|
||||||
[testenv:format]
|
|
||||||
basepython = python3.8
|
|
||||||
deps =
|
|
||||||
isort
|
|
||||||
black
|
|
||||||
skip_install = true
|
|
||||||
commands =
|
|
||||||
black --check setup.py src/wagtail_personalisation/ tests/
|
|
||||||
|
Reference in New Issue
Block a user