horizon/openstack_dashboard/test/integration_tests/pages/identity/projectspage.py

101 lines
3.9 KiB
Python

# 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 openstack_dashboard.test.integration_tests.pages import basepage
from openstack_dashboard.test.integration_tests.regions import forms
from openstack_dashboard.test.integration_tests.regions import menus
from openstack_dashboard.test.integration_tests.regions import tables
class ProjectForm(forms.TabbedFormRegion):
FIELDS = (("name", "description", "enabled"),
{'members': menus.MembershipMenuRegion})
def __init__(self, driver, conf, tab=0):
super(ProjectForm, self).__init__(
driver, conf, field_mappings=self.FIELDS, default_tab=tab)
class ProjectsTable(tables.TableRegion):
name = 'tenants'
@tables.bind_table_action('create')
def create_project(self, create_button):
create_button.click()
return ProjectForm(self.driver, self.conf)
@tables.bind_row_action('update')
def update_members(self, members_button, row):
members_button.click()
return ProjectForm(self.driver, self.conf, tab=1)
@tables.bind_table_action('delete')
def delete_project(self, delete_button):
delete_button.click()
return forms.BaseFormRegion(self.driver, self.conf, None)
class ProjectsPage(basepage.BaseNavigationPage):
DEFAULT_ENABLED = True
PROJECTS_TABLE_NAME_COLUMN = 'name'
PROJECT_ID_TABLE_NAME_COLUMN = 'id'
def __init__(self, driver, conf):
super(ProjectsPage, self).__init__(driver, conf)
self._page_title = "Projects"
@property
def projects_table(self):
return ProjectsTable(self.driver, self.conf)
def _get_row_with_project_name(self, name):
return self.projects_table.get_row(self.PROJECTS_TABLE_NAME_COLUMN,
name)
def create_project(self, project_name, description=None,
is_enabled=DEFAULT_ENABLED):
create_project_form = self.projects_table.create_project()
create_project_form.name.text = project_name
if description is not None:
create_project_form.description.text = description
if not is_enabled:
create_project_form.enabled.unmark()
create_project_form.submit()
def delete_project(self, project_name):
row = self._get_row_with_project_name(project_name)
row.mark()
modal_confirmation_form = self.projects_table.delete_project()
modal_confirmation_form.submit()
def is_project_present(self, project_name):
return bool(self._get_row_with_project_name(project_name))
def get_project_id_from_row(self, name):
row = self._get_row_with_project_name(name)
return row.cells[self.PROJECT_ID_TABLE_NAME_COLUMN].text
def allocate_user_to_project(self, user_name, roles, project_name):
row = self._get_row_with_project_name(project_name)
members_form = self.projects_table.update_members(row)
members_form.members.allocate_member(user_name)
members_form.members.allocate_member_roles(user_name, roles)
members_form.submit()
def get_user_roles_at_project(self, user_name, project_name):
row = self._get_row_with_project_name(project_name)
members_form = self.projects_table.update_members(row)
roles = members_form.members.get_member_allocated_roles(user_name)
members_form.cancel()
return set(roles)