Moving Trove to contrib

Moving Trove related code to openstack_dashboard/contrib

Change-Id: If3a7da604ca34d0d5a80d56989f1d11955d357df
Partial: blueprint plugin-sanity
This commit is contained in:
lin-hua-cheng 2015-07-28 18:05:46 -07:00
parent 5f0bf07b95
commit 1fb6a8ac5e
51 changed files with 103 additions and 68 deletions

View File

@ -43,7 +43,6 @@ from openstack_dashboard.api import network
from openstack_dashboard.api import neutron from openstack_dashboard.api import neutron
from openstack_dashboard.api import nova from openstack_dashboard.api import nova
from openstack_dashboard.api import swift from openstack_dashboard.api import swift
from openstack_dashboard.api import trove
from openstack_dashboard.api import vpn from openstack_dashboard.api import vpn
@ -60,6 +59,5 @@ __all__ = [
"nova", "nova",
"swift", "swift",
"ceilometer", "ceilometer",
"trove",
"vpn", "vpn",
] ]

View File

@ -0,0 +1,5 @@
from openstack_dashboard.contrib.trove.api import trove
__all__ = [
"trove"
]

View File

@ -21,7 +21,7 @@ from django.utils.translation import ungettext_lazy
from horizon import tables from horizon import tables
from horizon.utils import filters from horizon.utils import filters
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
STATUS_CHOICES = ( STATUS_CHOICES = (

View File

@ -16,7 +16,7 @@ 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
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.test import helpers as test from openstack_dashboard.test import helpers as test
INDEX_URL = reverse('horizon:project:database_backups:index') INDEX_URL = reverse('horizon:project:database_backups:index')

View File

@ -15,7 +15,7 @@
from django.conf.urls import patterns from django.conf.urls import patterns
from django.conf.urls import url from django.conf.urls import url
from openstack_dashboard.dashboards.project.database_backups import views from openstack_dashboard.contrib.trove.content.database_backups import views
urlpatterns = patterns( urlpatterns = patterns(
'', '',

View File

@ -24,9 +24,10 @@ from horizon.utils import filters
from horizon import views as horizon_views from horizon import views as horizon_views
from horizon import workflows as horizon_workflows from horizon import workflows as horizon_workflows
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.database_backups import tables from openstack_dashboard.contrib.trove.content.database_backups import tables
from openstack_dashboard.dashboards.project.database_backups import workflows from openstack_dashboard.contrib.trove.content.database_backups \
import workflows
class IndexView(horizon_tables.DataTableView): class IndexView(horizon_tables.DataTableView):

View File

@ -20,8 +20,8 @@ from horizon import exceptions
from horizon import forms from horizon import forms
from horizon import workflows from horizon import workflows
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.databases \ from openstack_dashboard.contrib.trove.content.databases \
import tables as project_tables import tables as project_tables

View File

@ -19,7 +19,7 @@ from django.utils.translation import ugettext_lazy as _
from horizon import exceptions from horizon import exceptions
from horizon import forms from horizon import forms
from horizon import messages from horizon import messages
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
class ResizeVolumeForm(forms.SelfHandlingForm): class ResizeVolumeForm(forms.SelfHandlingForm):

View File

@ -23,8 +23,8 @@ from horizon import tables
from horizon.templatetags import sizeformat from horizon.templatetags import sizeformat
from horizon.utils import filters from horizon.utils import filters
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.database_backups \ from openstack_dashboard.contrib.trove.content.database_backups \
import tables as backup_tables import tables as backup_tables

View File

@ -18,8 +18,8 @@ from django.utils.translation import ugettext_lazy as _
from horizon import exceptions from horizon import exceptions
from horizon import tabs from horizon import tabs
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.databases import tables from openstack_dashboard.contrib.trove.content.databases import tables
class OverviewTab(tabs.Tab): class OverviewTab(tabs.Tab):

View File

@ -23,7 +23,8 @@ from django.utils import unittest
from mox3.mox import IsA # noqa from mox3.mox import IsA # noqa
from horizon import exceptions from horizon import exceptions
from openstack_dashboard import api from openstack_dashboard import api as dash_api
from openstack_dashboard.contrib.trove import api
from openstack_dashboard.test import helpers as test from openstack_dashboard.test import helpers as test
from troveclient import common from troveclient import common
@ -125,7 +126,7 @@ class DatabaseTests(test.TestCase):
api.trove: ('flavor_list', 'backup_list', api.trove: ('flavor_list', 'backup_list',
'datastore_list', 'datastore_version_list', 'datastore_list', 'datastore_version_list',
'instance_list'), 'instance_list'),
api.neutron: ('network_list',)}) dash_api.neutron: ('network_list',)})
def test_launch_instance(self): def test_launch_instance(self):
api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn( api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn(
self.flavors.list()) self.flavors.list())
@ -140,12 +141,12 @@ class DatabaseTests(test.TestCase):
api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str)).\ api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str)).\
AndReturn(self.datastore_versions.list()) AndReturn(self.datastore_versions.list())
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
tenant_id=self.tenant.id, tenant_id=self.tenant.id,
shared=False).AndReturn( shared=False).AndReturn(
self.networks.list()[:1]) self.networks.list()[:1])
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
shared=True).AndReturn( shared=True).AndReturn(
self.networks.list()[1:]) self.networks.list()[1:])
@ -188,7 +189,7 @@ class DatabaseTests(test.TestCase):
api.trove: ('flavor_list', 'backup_list', 'instance_create', api.trove: ('flavor_list', 'backup_list', 'instance_create',
'datastore_list', 'datastore_version_list', 'datastore_list', 'datastore_version_list',
'instance_list'), 'instance_list'),
api.neutron: ('network_list',)}) dash_api.neutron: ('network_list',)})
def test_create_simple_instance(self): def test_create_simple_instance(self):
api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn( api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn(
self.flavors.list()) self.flavors.list())
@ -207,12 +208,12 @@ class DatabaseTests(test.TestCase):
api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str))\ api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str))\
.AndReturn(self.datastore_versions.list()) .AndReturn(self.datastore_versions.list())
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
tenant_id=self.tenant.id, tenant_id=self.tenant.id,
shared=False).AndReturn( shared=False).AndReturn(
self.networks.list()[:1]) self.networks.list()[:1])
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
shared=True).AndReturn( shared=True).AndReturn(
self.networks.list()[1:]) self.networks.list()[1:])
@ -248,7 +249,7 @@ class DatabaseTests(test.TestCase):
api.trove: ('flavor_list', 'backup_list', 'instance_create', api.trove: ('flavor_list', 'backup_list', 'instance_create',
'datastore_list', 'datastore_version_list', 'datastore_list', 'datastore_version_list',
'instance_list'), 'instance_list'),
api.neutron: ('network_list',)}) dash_api.neutron: ('network_list',)})
def test_create_simple_instance_exception(self): def test_create_simple_instance_exception(self):
trove_exception = self.exceptions.nova trove_exception = self.exceptions.nova
api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn( api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn(
@ -268,12 +269,12 @@ class DatabaseTests(test.TestCase):
api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str))\ api.trove.datastore_version_list(IsA(http.HttpRequest), IsA(str))\
.AndReturn(self.datastore_versions.list()) .AndReturn(self.datastore_versions.list())
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
tenant_id=self.tenant.id, tenant_id=self.tenant.id,
shared=False).AndReturn( shared=False).AndReturn(
self.networks.list()[:1]) self.networks.list()[:1])
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
shared=True).AndReturn( shared=True).AndReturn(
self.networks.list()[1:]) self.networks.list()[1:])
@ -481,7 +482,7 @@ class DatabaseTests(test.TestCase):
api.trove: ('flavor_list', 'backup_list', 'instance_create', api.trove: ('flavor_list', 'backup_list', 'instance_create',
'datastore_list', 'datastore_version_list', 'datastore_list', 'datastore_version_list',
'instance_list', 'instance_get'), 'instance_list', 'instance_get'),
api.neutron: ('network_list',)}) dash_api.neutron: ('network_list',)})
def test_create_replica_instance(self): def test_create_replica_instance(self):
api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn( api.trove.flavor_list(IsA(http.HttpRequest)).AndReturn(
self.flavors.list()) self.flavors.list())
@ -499,12 +500,12 @@ class DatabaseTests(test.TestCase):
IsA(str))\ IsA(str))\
.AndReturn(self.datastore_versions.list()) .AndReturn(self.datastore_versions.list())
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
tenant_id=self.tenant.id, tenant_id=self.tenant.id,
shared=False).\ shared=False).\
AndReturn(self.networks.list()[:1]) AndReturn(self.networks.list()[:1])
api.neutron.network_list(IsA(http.HttpRequest), dash_api.neutron.network_list(IsA(http.HttpRequest),
shared=True).\ shared=True).\
AndReturn(self.networks.list()[1:]) AndReturn(self.networks.list()[1:])

View File

@ -15,7 +15,7 @@
from django.conf.urls import patterns from django.conf.urls import patterns
from django.conf.urls import url from django.conf.urls import url
from openstack_dashboard.dashboards.project.databases import views from openstack_dashboard.contrib.trove.content.databases import views
INSTANCES = r'^(?P<instance_id>[^/]+)/%s$' INSTANCES = r'^(?P<instance_id>[^/]+)/%s$'

View File

@ -29,11 +29,11 @@ from horizon import tabs as horizon_tabs
from horizon.utils import memoized from horizon.utils import memoized
from horizon import workflows as horizon_workflows from horizon import workflows as horizon_workflows
from openstack_dashboard import api from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.databases import forms from openstack_dashboard.contrib.trove.content.databases import forms
from openstack_dashboard.dashboards.project.databases import tables from openstack_dashboard.contrib.trove.content.databases import tables
from openstack_dashboard.dashboards.project.databases import tabs from openstack_dashboard.contrib.trove.content.databases import tabs
from openstack_dashboard.dashboards.project.databases import workflows from openstack_dashboard.contrib.trove.content.databases import workflows
from openstack_dashboard.dashboards.project.instances \ from openstack_dashboard.dashboards.project.instances \
import utils as instance_utils import utils as instance_utils

View File

@ -22,7 +22,8 @@ from horizon import exceptions
from horizon import forms from horizon import forms
from horizon.utils import memoized from horizon.utils import memoized
from horizon import workflows from horizon import workflows
from openstack_dashboard import api from openstack_dashboard import api as dash_api
from openstack_dashboard.contrib.trove import api
from openstack_dashboard.dashboards.project.instances \ from openstack_dashboard.dashboards.project.instances \
import utils as instance_utils import utils as instance_utils
@ -151,7 +152,8 @@ class SetNetworkAction(workflows.Action):
def populate_network_choices(self, request, context): def populate_network_choices(self, request, context):
try: try:
tenant_id = self.request.user.tenant_id tenant_id = self.request.user.tenant_id
networks = api.neutron.network_list_for_tenant(request, tenant_id) networks = dash_api.neutron.network_list_for_tenant(request,
tenant_id)
network_list = [(network.id, network.name_or_id) network_list = [(network.id, network.name_or_id)
for network in networks] for network in networks]
except Exception: except Exception:

View File

@ -0,0 +1,38 @@
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from troveclient import client as trove_client
from openstack_dashboard.test import helpers
from openstack_dashboard.contrib.trove import api
class TroveAPITestCase(helpers.APITestCase):
def setUp(self):
super(TroveAPITestCase, self).setUp()
self._original_troveclient = api.trove.client
api.trove.client = lambda request: self.stub_troveclient()
def tearDown(self):
super(TroveAPITestCase, self).tearDown()
api.trove.client = self._original_troveclient
def stub_troveclient(self):
if not hasattr(self, "troveclient"):
self.mox.StubOutWithMock(trove_client, 'Client')
self.troveclient = self.mox.CreateMock(trove_client.Client)
return self.troveclient

View File

@ -21,5 +21,4 @@ class Project(horizon.Dashboard):
name = _("Project") name = _("Project")
slug = "project" slug = "project"
horizon.register(Project) horizon.register(Project)

View File

@ -6,4 +6,5 @@ PANEL_DASHBOARD = 'project'
PANEL_GROUP = 'database' PANEL_GROUP = 'database'
# Python panel class of the PANEL to be added. # Python panel class of the PANEL to be added.
ADD_PANEL = 'openstack_dashboard.dashboards.project.databases.panel.Databases' ADD_PANEL = ('openstack_dashboard.contrib.trove.'
'content.databases.panel.Databases')

View File

@ -6,5 +6,5 @@ PANEL_DASHBOARD = 'project'
PANEL_GROUP = 'database' PANEL_GROUP = 'database'
# Python panel class of the PANEL to be added. # Python panel class of the PANEL to be added.
ADD_PANEL = ('openstack_dashboard.dashboards.project.' ADD_PANEL = ('openstack_dashboard.contrib.trove.'
'database_backups.panel.Backups') 'content.database_backups.panel.Backups')

View File

@ -44,7 +44,6 @@ from novaclient.v2 import client as nova_client
from openstack_auth import user from openstack_auth import user
from openstack_auth import utils from openstack_auth import utils
from swiftclient import client as swift_client from swiftclient import client as swift_client
from troveclient import client as trove_client
from horizon import base from horizon import base
from horizon import conf from horizon import conf
@ -343,7 +342,6 @@ class APITestCase(TestCase):
self._original_cinderclient = api.cinder.cinderclient self._original_cinderclient = api.cinder.cinderclient
self._original_heatclient = api.heat.heatclient self._original_heatclient = api.heat.heatclient
self._original_ceilometerclient = api.ceilometer.ceilometerclient self._original_ceilometerclient = api.ceilometer.ceilometerclient
self._original_troveclient = api.trove.troveclient
# Replace the clients with our stubs. # Replace the clients with our stubs.
api.glance.glanceclient = lambda request: self.stub_glanceclient() api.glance.glanceclient = lambda request: self.stub_glanceclient()
@ -355,7 +353,6 @@ class APITestCase(TestCase):
self.stub_heatclient()) self.stub_heatclient())
api.ceilometer.ceilometerclient = (lambda request: api.ceilometer.ceilometerclient = (lambda request:
self.stub_ceilometerclient()) self.stub_ceilometerclient())
api.trove.troveclient = lambda request: self.stub_troveclient()
def tearDown(self): def tearDown(self):
super(APITestCase, self).tearDown() super(APITestCase, self).tearDown()
@ -366,7 +363,6 @@ class APITestCase(TestCase):
api.cinder.cinderclient = self._original_cinderclient api.cinder.cinderclient = self._original_cinderclient
api.heat.heatclient = self._original_heatclient api.heat.heatclient = self._original_heatclient
api.ceilometer.ceilometerclient = self._original_ceilometerclient api.ceilometer.ceilometerclient = self._original_ceilometerclient
api.trove.troveclient = self._original_troveclient
def stub_novaclient(self): def stub_novaclient(self):
if not hasattr(self, "novaclient"): if not hasattr(self, "novaclient"):
@ -435,12 +431,6 @@ class APITestCase(TestCase):
CreateMock(ceilometer_client.Client) CreateMock(ceilometer_client.Client)
return self.ceilometerclient return self.ceilometerclient
def stub_troveclient(self):
if not hasattr(self, "troveclient"):
self.mox.StubOutWithMock(trove_client, 'Client')
self.troveclient = self.mox.CreateMock(trove_client.Client)
return self.troveclient
@unittest.skipUnless(os.environ.get('WITH_SELENIUM', False), @unittest.skipUnless(os.environ.get('WITH_SELENIUM', False),
"The WITH_SELENIUM env variable is not set.") "The WITH_SELENIUM env variable is not set.")