Fix Django 1.10 Compatibility
Fixes a number of django 1.9 and 1.10 issues. Also adds test environments for both. Change-Id: Ic76ed18880170b8eaf25b4e183a5bc92bbbb82d9 Co-Authored-By: Duk Loi <duk@tesora.com>
This commit is contained in:
parent
98f05cb203
commit
0c9dab4e6b
10
tox.ini
10
tox.ini
@ -33,6 +33,16 @@ basepython = python2.7
|
|||||||
commands = pip install django>=1.8,<1.9
|
commands = pip install django>=1.8,<1.9
|
||||||
/bin/bash run_tests.sh -N --no-pep8 {posargs}
|
/bin/bash run_tests.sh -N --no-pep8 {posargs}
|
||||||
|
|
||||||
|
[testenv:py27dj19]
|
||||||
|
basepython = python2.7
|
||||||
|
commands = pip install django>=1.9,<1.10
|
||||||
|
/bin/bash run_tests.sh -N --no-pep8 {posargs}
|
||||||
|
|
||||||
|
[testenv:py27dj110]
|
||||||
|
basepython = python2.7
|
||||||
|
commands = pip install django>=1.10,<1.11
|
||||||
|
/bin/bash run_tests.sh -N --no-pep8 {posargs}
|
||||||
|
|
||||||
[testenv:py27integration]
|
[testenv:py27integration]
|
||||||
basepython = python2.7
|
basepython = python2.7
|
||||||
commands = /bin/bash run_tests.sh -N --integration --selenium-headless {posargs}
|
commands = /bin/bash run_tests.sh -N --integration --selenium-headless {posargs}
|
||||||
|
@ -12,15 +12,13 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django.conf.urls import patterns
|
|
||||||
from django.conf.urls import url
|
from django.conf.urls import url
|
||||||
|
|
||||||
from trove_dashboard.content.database_backups import views
|
from trove_dashboard.content.database_backups import views
|
||||||
|
|
||||||
urlpatterns = patterns(
|
urlpatterns = [
|
||||||
'',
|
|
||||||
url(r'^$', views.IndexView.as_view(), name='index'),
|
url(r'^$', views.IndexView.as_view(), name='index'),
|
||||||
url(r'^create$', views.BackupView.as_view(), name='create'),
|
url(r'^create$', views.BackupView.as_view(), name='create'),
|
||||||
url(r'^(?P<backup_id>[^/]+)/$', views.DetailView.as_view(),
|
url(r'^(?P<backup_id>[^/]+)/$', views.DetailView.as_view(),
|
||||||
name='detail'),
|
name='detail'),
|
||||||
)
|
]
|
||||||
|
@ -14,15 +14,13 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django.conf.urls import patterns # noqa
|
|
||||||
from django.conf.urls import url # noqa
|
from django.conf.urls import url # noqa
|
||||||
|
|
||||||
from trove_dashboard.content.database_clusters import views
|
from trove_dashboard.content.database_clusters import views
|
||||||
|
|
||||||
CLUSTERS = r'^(?P<cluster_id>[^/]+)/%s$'
|
CLUSTERS = r'^(?P<cluster_id>[^/]+)/%s$'
|
||||||
|
|
||||||
urlpatterns = patterns(
|
urlpatterns = [
|
||||||
'',
|
|
||||||
url(r'^$', views.IndexView.as_view(), name='index'),
|
url(r'^$', views.IndexView.as_view(), name='index'),
|
||||||
url(r'^launch$', views.LaunchClusterView.as_view(), name='launch'),
|
url(r'^launch$', views.LaunchClusterView.as_view(), name='launch'),
|
||||||
url(r'^(?P<cluster_id>[^/]+)/$', views.DetailView.as_view(),
|
url(r'^(?P<cluster_id>[^/]+)/$', views.DetailView.as_view(),
|
||||||
@ -39,4 +37,4 @@ urlpatterns = patterns(
|
|||||||
url(CLUSTERS % 'reset_password',
|
url(CLUSTERS % 'reset_password',
|
||||||
views.ResetPasswordView.as_view(),
|
views.ResetPasswordView.as_view(),
|
||||||
name='reset_password'),
|
name='reset_password'),
|
||||||
)
|
]
|
||||||
|
@ -14,7 +14,10 @@
|
|||||||
|
|
||||||
import copy
|
import copy
|
||||||
import logging
|
import logging
|
||||||
|
import six
|
||||||
|
|
||||||
|
import django
|
||||||
|
from django.conf import settings
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
from django import http
|
from django import http
|
||||||
from mox3.mox import IsA # noqa
|
from mox3.mox import IsA # noqa
|
||||||
@ -313,16 +316,15 @@ class DatabaseConfigurationsTests(test.TestCase):
|
|||||||
config_param_mgr.original_configuration_values = \
|
config_param_mgr.original_configuration_values = \
|
||||||
dict.copy(config.values)
|
dict.copy(config.values)
|
||||||
|
|
||||||
config_param_manager.get(IsA(http.HttpRequest), config.id) \
|
(config_param_manager.get(IsA(http.HttpRequest),
|
||||||
.MultipleTimes().AndReturn(config_param_mgr)
|
IsA(six.string_types))
|
||||||
|
.MultipleTimes()
|
||||||
ds = self._get_test_datastore('mysql')
|
.AndReturn(config_param_mgr))
|
||||||
dsv = self._get_test_datastore_version(ds.id, '5.5')
|
(api.trove.configuration_parameters_list(IsA(http.HttpRequest),
|
||||||
api.trove.configuration_parameters_list(
|
IsA(six.string_types),
|
||||||
IsA(http.HttpRequest),
|
IsA(six.string_types))
|
||||||
ds.name,
|
.MultipleTimes()
|
||||||
dsv.name) \
|
.AndReturn(self.configuration_parameters.list()))
|
||||||
.AndReturn(self.configuration_parameters.list())
|
|
||||||
|
|
||||||
name = self.configuration_parameters.first().name
|
name = self.configuration_parameters.first().name
|
||||||
value = "non-numeric"
|
value = "non-numeric"
|
||||||
@ -360,6 +362,8 @@ class DatabaseConfigurationsTests(test.TestCase):
|
|||||||
.get_configuration().values)
|
.get_configuration().values)
|
||||||
|
|
||||||
res = self.client.post(url, {'action': u"values__discard_changes"})
|
res = self.client.post(url, {'action': u"values__discard_changes"})
|
||||||
|
if django.VERSION >= (1, 9):
|
||||||
|
url = settings.TESTSERVER + url
|
||||||
self.assertRedirectsNoFollow(res, url)
|
self.assertRedirectsNoFollow(res, url)
|
||||||
|
|
||||||
# get the state of the configuration after discard action
|
# get the state of the configuration after discard action
|
||||||
@ -400,6 +404,8 @@ class DatabaseConfigurationsTests(test.TestCase):
|
|||||||
|
|
||||||
# apply changes
|
# apply changes
|
||||||
res = self.client.post(url, {'action': u"values__apply_changes"})
|
res = self.client.post(url, {'action': u"values__apply_changes"})
|
||||||
|
if django.VERSION >= (1, 9):
|
||||||
|
url = settings.TESTSERVER + url
|
||||||
self.assertRedirectsNoFollow(res, url)
|
self.assertRedirectsNoFollow(res, url)
|
||||||
|
|
||||||
@test.create_stubs({api.trove: ('configuration_instances',
|
@test.create_stubs({api.trove: ('configuration_instances',
|
||||||
@ -432,6 +438,8 @@ class DatabaseConfigurationsTests(test.TestCase):
|
|||||||
|
|
||||||
# apply changes
|
# apply changes
|
||||||
res = self.client.post(url, {'action': u"values__apply_changes"})
|
res = self.client.post(url, {'action': u"values__apply_changes"})
|
||||||
|
if django.VERSION >= (1, 9):
|
||||||
|
url = settings.TESTSERVER + url
|
||||||
self.assertRedirectsNoFollow(res, url)
|
self.assertRedirectsNoFollow(res, url)
|
||||||
self.assertEqual(res.status_code, 302)
|
self.assertEqual(res.status_code, 302)
|
||||||
|
|
||||||
|
@ -12,7 +12,6 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django.conf.urls import patterns # noqa
|
|
||||||
from django.conf.urls import url # noqa
|
from django.conf.urls import url # noqa
|
||||||
|
|
||||||
from trove_dashboard.content.database_configurations \
|
from trove_dashboard.content.database_configurations \
|
||||||
@ -22,8 +21,7 @@ from trove_dashboard.content.database_configurations \
|
|||||||
CONFIGS = r'^(?P<configuration_id>[^/]+)/%s$'
|
CONFIGS = r'^(?P<configuration_id>[^/]+)/%s$'
|
||||||
|
|
||||||
|
|
||||||
urlpatterns = patterns(
|
urlpatterns = [
|
||||||
'',
|
|
||||||
url(r'^$',
|
url(r'^$',
|
||||||
views.IndexView.as_view(),
|
views.IndexView.as_view(),
|
||||||
name='index'),
|
name='index'),
|
||||||
@ -36,4 +34,4 @@ urlpatterns = patterns(
|
|||||||
url(CONFIGS % 'add',
|
url(CONFIGS % 'add',
|
||||||
views.AddParameterView.as_view(),
|
views.AddParameterView.as_view(),
|
||||||
name='add')
|
name='add')
|
||||||
)
|
]
|
||||||
|
@ -12,21 +12,16 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django.conf.urls import patterns
|
|
||||||
from django.conf.urls import url
|
from django.conf.urls import url
|
||||||
|
|
||||||
from trove_dashboard.content.databases.logs import views
|
from trove_dashboard.content.databases.logs import views
|
||||||
|
|
||||||
|
|
||||||
VIEWS_MOD = ('trove_dashboard.content.databases.logs.views')
|
|
||||||
|
|
||||||
LOGS = r'^(?P<filename>[^/]+)/%s$'
|
LOGS = r'^(?P<filename>[^/]+)/%s$'
|
||||||
|
|
||||||
urlpatterns = patterns(
|
urlpatterns = [
|
||||||
VIEWS_MOD,
|
url(LOGS % 'console', views.console, name='console'),
|
||||||
url(LOGS % 'console', 'console', name='console'),
|
url(LOGS % 'download_log', views.download_log, name='download_log'),
|
||||||
url(LOGS % 'download_log', 'download_log', name='download_log'),
|
url(LOGS % 'full_log', views.full_log, name='full_log'),
|
||||||
url(LOGS % 'full_log', 'full_log', name='full_log'),
|
|
||||||
url(LOGS % 'log_contents',
|
url(LOGS % 'log_contents',
|
||||||
views.LogContentsView.as_view(), name='log_contents'),
|
views.LogContentsView.as_view(), name='log_contents'),
|
||||||
)
|
]
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
{% load i18n %}
|
{% load i18n %}
|
||||||
{% load url from future %}
|
|
||||||
|
|
||||||
<div class="col-sm-12">
|
<div class="col-sm-12">
|
||||||
<div class="clearfix">
|
<div class="clearfix">
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
{% extends "horizon/common/_modal.html" %}
|
{% extends "horizon/common/_modal.html" %}
|
||||||
{% load i18n %}
|
{% load i18n %}
|
||||||
{% load url from future %}
|
|
||||||
|
|
||||||
{% block modal-header %}{% trans "Log Contents" %}{% endblock %}
|
{% block modal-header %}{% trans "Log Contents" %}{% endblock %}
|
||||||
|
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django.conf.urls import include
|
from django.conf.urls import include
|
||||||
from django.conf.urls import patterns
|
|
||||||
from django.conf.urls import url
|
from django.conf.urls import url
|
||||||
|
|
||||||
from trove_dashboard.content.databases.logs import urls as logs_urls
|
from trove_dashboard.content.databases.logs import urls as logs_urls
|
||||||
@ -24,8 +23,7 @@ INSTANCES = BASEINSTANCES + '$'
|
|||||||
USERS = r'^(?P<instance_id>[^/]+)/(?P<user_name>[^/]+)/%s$'
|
USERS = r'^(?P<instance_id>[^/]+)/(?P<user_name>[^/]+)/%s$'
|
||||||
|
|
||||||
|
|
||||||
urlpatterns = patterns(
|
urlpatterns = [
|
||||||
'',
|
|
||||||
url(r'^$', views.IndexView.as_view(), name='index'),
|
url(r'^$', views.IndexView.as_view(), name='index'),
|
||||||
url(r'^launch$', views.LaunchInstanceView.as_view(), name='launch'),
|
url(r'^launch$', views.LaunchInstanceView.as_view(), name='launch'),
|
||||||
url(INSTANCES % '', views.DetailView.as_view(), name='detail'),
|
url(INSTANCES % '', views.DetailView.as_view(), name='detail'),
|
||||||
@ -49,4 +47,4 @@ urlpatterns = patterns(
|
|||||||
url(INSTANCES % 'manage_root', views.ManageRootView.as_view(),
|
url(INSTANCES % 'manage_root', views.ManageRootView.as_view(),
|
||||||
name='manage_root'),
|
name='manage_root'),
|
||||||
url(BASEINSTANCES % 'logs/', include(logs_urls, namespace='logs')),
|
url(BASEINSTANCES % 'logs/', include(logs_urls, namespace='logs')),
|
||||||
)
|
]
|
||||||
|
@ -14,7 +14,6 @@
|
|||||||
from django.conf import urls
|
from django.conf import urls
|
||||||
import openstack_dashboard.urls
|
import openstack_dashboard.urls
|
||||||
|
|
||||||
urlpatterns = urls.patterns(
|
urlpatterns = [
|
||||||
'',
|
|
||||||
urls.url(r'', urls.include(openstack_dashboard.urls))
|
urls.url(r'', urls.include(openstack_dashboard.urls))
|
||||||
)
|
]
|
||||||
|
Loading…
Reference in New Issue
Block a user