diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 1c7b3a9..8616494 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -1,15 +1,17 @@ Changelog --------- +0.7.6 (2018-09-11) +~~~~~~~~~~~~~~~~~~ +* fix `#36 es_update --start flag broken `_ + 0.7.5 (2018-08-20) ~~~~~~~~~~~~~~~~~~ -* fix `#35 open multiprocessing log in context handler -`_ +* fix `#35 open multiprocessing log in context handler `_ 0.7.4 (2018-08-15) ~~~~~~~~~~~~~~~~~~ -* fix `#33 error when nothing to resume using --resume -`_ +* fix `#33 error when nothing to resume using --resume `_ 0.7.3 (2018-08-14) ~~~~~~~~~~~~~~~~~~ diff --git a/django_elastic_migrations/__init__.py b/django_elastic_migrations/__init__.py index c3717d1..f1aa71a 100644 --- a/django_elastic_migrations/__init__.py +++ b/django_elastic_migrations/__init__.py @@ -10,7 +10,7 @@ from django_elastic_migrations.utils import loading from django_elastic_migrations.utils.django_elastic_migrations_log import get_logger -__version__ = '0.7.5' +__version__ = '0.7.6' default_app_config = 'django_elastic_migrations.apps.DjangoElasticMigrationsConfig' # pylint: disable=invalid-name diff --git a/django_elastic_migrations/management/commands/es_update.py b/django_elastic_migrations/management/commands/es_update.py index 69b6985..56d7ffa 100644 --- a/django_elastic_migrations/management/commands/es_update.py +++ b/django_elastic_migrations/management/commands/es_update.py @@ -47,7 +47,7 @@ def add_arguments(self, parser): "--start", dest="start_date", help="The start date for indexing. Can be any dateutil-parsable string;" - " YYYY-MM-DDTHH:MM:SS is recommended to avoid confusion", + "YYYY-MM-DD or YYYY-MM-DDTHH:MM:SS is recommended to avoid confusion", ) def handle(self, *args, **options): diff --git a/django_elastic_migrations/models.py b/django_elastic_migrations/models.py index 2ec61b2..6cda607 100644 --- a/django_elastic_migrations/models.py +++ b/django_elastic_migrations/models.py @@ -957,7 +957,10 @@ def __init__(self, *args, **kwargs): actual_val = kwargs.pop(kwarg_name, default_val) setattr(self, kwarg_name, actual_val) if actual_val != default_val: - self.self_kwargs[kwarg_name] = actual_val + if kwarg_name == 'start_date': + self.self_kwargs['start_date'] = str(actual_val) + else: + self.self_kwargs[kwarg_name] = actual_val if NewerModeMixin.MODE_NAME in kwargs: self.self_kwargs[NewerModeMixin.MODE_NAME] = True diff --git a/tests/test_management_commands.py b/tests/test_management_commands.py index 97d7430..7f3753b 100644 --- a/tests/test_management_commands.py +++ b/tests/test_management_commands.py @@ -1,6 +1,7 @@ from __future__ import (absolute_import, division, print_function, unicode_literals) import logging +from datetime import datetime, timedelta from unittest import skip from django.contrib.humanize.templatetags.humanize import ordinal @@ -17,6 +18,10 @@ log = logging.getLogger(__file__) +def days_ago(d): + return datetime.now() - timedelta(days=d) + + # noinspection PyUnresolvedReferences class CommonDEMTestUtilsMixin(object): @@ -227,6 +232,26 @@ def test_newer_flag(self): actual_num=actual_num_docs )) + def test_start_flag(self): + self.check_basic_setup_and_get_models() + + num_docs = MovieSearchIndex.get_num_docs() + self.assertEqual(num_docs, 0) + + Movie.objects.all().update(last_modified=days_ago(3)) + call_command('es_update', 'movies', '--start={}'.format(days_ago(2).isoformat())) + num_docs = MovieSearchIndex.get_num_docs() + # we had last modified set to three days ago, and we only updated last two days, + # so we should not have any. + self.assertEqual(num_docs, 0) + + Movie.objects.all().update(last_modified=days_ago(1)) + call_command('es_update', 'movies', '--start={}'.format(days_ago(2).isoformat())) + num_docs = MovieSearchIndex.get_num_docs() + # we had last modified set to one days ago, and we only updated last two days, + # so we should have two + self.assertEqual(num_docs, 2) + @skip("Skipped multiprocessing tests until SQLLite can be integrated into test setup") # @tag('multiprocessing')