Fix the instances pagination integration tests
Looks like the popup that comes up after creating instances is no longer a SUCCESS, but instead it's INFO. This patch fixes integration tests which were using the incorrect message class and revisits all other tests skipped with the same bug number reason. Change-Id: I0e2976b56513df3cb45ea00e0f9f05603a8743a8 Closes-bug: #1774697
This commit is contained in:
parent
310a24d054
commit
e53c4d8ca0
@ -239,8 +239,7 @@ class VolumesPage(basepage.BaseNavigationPage):
|
||||
def is_volume_attached_to_instance(self, volume, instance):
|
||||
row = self._get_row_with_volume_name(volume)
|
||||
return row.cells[
|
||||
self.VOLUMES_TABLE_ATTACHED_COLUMN].text.startswith(
|
||||
"Attached to {0}".format(instance))
|
||||
self.VOLUMES_TABLE_ATTACHED_COLUMN].text.endswith(instance)
|
||||
|
||||
def detach_volume_from_instance(self, volume, instance):
|
||||
row = self._get_row_with_volume_name(volume)
|
||||
|
@ -42,14 +42,14 @@ class TestFloatingip(helpers.TestCase):
|
||||
class TestFloatingipAssociateDisassociate(helpers.TestCase):
|
||||
"""Checks that the user is able to Associate/Disassociate floatingip."""
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
@pytest.mark.skip(reason="Bug 1920010 fix")
|
||||
def test_floatingip_associate_disassociate(self):
|
||||
instance_name = helpers.gen_random_resource_name('instance',
|
||||
timestamp=False)
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(instance_name)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertFalse(
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_name))
|
||||
@ -92,7 +92,7 @@ class TestFloatingipAssociateDisassociate(helpers.TestCase):
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.delete_instance(instance_name)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertFalse(
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_deleted(instance_name))
|
||||
|
@ -334,7 +334,6 @@ class TestImagesAdmin(helpers.AdminTestCase, TestImagesLegacy):
|
||||
def images_page(self):
|
||||
return self.home_pg.go_to_admin_compute_imagespage()
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_image_create_delete(self):
|
||||
super().test_image_create_delete()
|
||||
|
||||
|
@ -9,7 +9,6 @@
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
import pytest
|
||||
|
||||
from openstack_dashboard.test.integration_tests import helpers
|
||||
from openstack_dashboard.test.integration_tests.regions import messages
|
||||
@ -50,7 +49,6 @@ class TestInstances(helpers.TestCase):
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_deleted(self.INSTANCE_NAME))
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_instances_pagination(self):
|
||||
"""This test checks instance pagination
|
||||
|
||||
@ -87,20 +85,20 @@ class TestInstances(helpers.TestCase):
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[1]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.assert_definition(
|
||||
first_page_definition, sorting=True)
|
||||
first_page_definition, sorting=True, name_column="Instance Name")
|
||||
|
||||
instances_page.instances_table.turn_next_page()
|
||||
instances_page.instances_table.assert_definition(
|
||||
second_page_definition, sorting=True)
|
||||
second_page_definition, sorting=True, name_column="Instance Name")
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.assert_definition(
|
||||
first_page_definition, sorting=True)
|
||||
first_page_definition, sorting=True, name_column="Instance Name")
|
||||
|
||||
settings_page = self.home_pg.go_to_settings_usersettingspage()
|
||||
settings_page.change_pagesize()
|
||||
@ -110,10 +108,9 @@ class TestInstances(helpers.TestCase):
|
||||
instances_page = self.instances_page
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_instances_pagination_and_filtration(self):
|
||||
"""This test checks instance pagination and filtration
|
||||
|
||||
@ -157,7 +154,207 @@ class TestInstances(helpers.TestCase):
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[1]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.set_filter_value('name')
|
||||
instances_page.instances_table.filter(instance_list[1])
|
||||
instances_page.instances_table.assert_definition(
|
||||
filter_first_page_definition, sorting=True,
|
||||
name_column="Instance Name")
|
||||
|
||||
instances_page.instances_table.filter(instance_list[0])
|
||||
instances_page.instances_table.assert_definition(
|
||||
second_page_definition, sorting=True,
|
||||
name_column="Instance Name")
|
||||
|
||||
instances_page.instances_table.filter(self.INSTANCE_NAME)
|
||||
instances_page.instances_table.assert_definition(
|
||||
first_page_definition, sorting=True,
|
||||
name_column="Instance Name")
|
||||
instances_page.instances_table.filter('')
|
||||
|
||||
settings_page = self.home_pg.go_to_settings_usersettingspage()
|
||||
settings_page.change_pagesize()
|
||||
self.assertTrue(
|
||||
settings_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
def test_filter_instances(self):
|
||||
"""This test checks filtering of instances by Instance Name
|
||||
|
||||
Steps:
|
||||
1) Login to Horizon dashboard as regular user
|
||||
2) Go to Project > Compute > Instances
|
||||
3) Create 2 instances
|
||||
4) Go to appropriate page (depends on user)
|
||||
5) Use filter by Instance Name
|
||||
6) Check that filtered table has one instance only (which name is equal
|
||||
to filter value) and no other instances in the table
|
||||
7) Check that filtered table has both instances (search by common part
|
||||
of instance names)
|
||||
8) Set nonexistent instance name. Check that 0 rows are displayed
|
||||
9) Clear filter and delete instances via proper page (depends on user)
|
||||
"""
|
||||
instance_count = 2
|
||||
instance_list = ["{0}-{1}".format(self.INSTANCE_NAME, item)
|
||||
for item in range(1, instance_count + 1)]
|
||||
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[0]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.set_filter_value('name')
|
||||
|
||||
instances_page.instances_table.filter(instance_list[0])
|
||||
self.assertTrue(instances_page.is_instance_present(instance_list[0]))
|
||||
for instance in instance_list[1:]:
|
||||
self.assertFalse(instances_page.is_instance_present(instance))
|
||||
|
||||
instances_page.instances_table.filter(self.INSTANCE_NAME)
|
||||
for instance in instance_list:
|
||||
self.assertTrue(instances_page.is_instance_present(instance))
|
||||
|
||||
nonexistent_instance_name = "{0}_test".format(self.INSTANCE_NAME)
|
||||
instances_page.instances_table.filter(nonexistent_instance_name)
|
||||
self.assertEqual(instances_page.instances_table.rows, [])
|
||||
instances_page.instances_table.filter('')
|
||||
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
|
||||
class TestAdminInstances(helpers.AdminTestCase, TestInstances):
|
||||
INSTANCE_NAME = helpers.gen_random_resource_name('instance',
|
||||
timestamp=False)
|
||||
|
||||
@property
|
||||
def instances_page(self):
|
||||
self.home_pg.go_to_admin_overviewpage()
|
||||
return self.home_pg.go_to_admin_compute_instancespage()
|
||||
|
||||
@property
|
||||
def instance_table_name_column(self):
|
||||
return 'Name'
|
||||
|
||||
def test_instances_pagination(self):
|
||||
"""This test checks instance pagination
|
||||
|
||||
Steps:
|
||||
1) Login to Horizon Dashboard as admin
|
||||
2) Navigate to user settings page
|
||||
3) Change 'Items Per Page' value to 1
|
||||
4) Go to Project > Compute > Instances page
|
||||
5) Create 2 instances
|
||||
6) Go to Admin > Compute > Instances page
|
||||
7) Check that only 'Next' link is available, only one instance is
|
||||
available (and it has correct name) on the first page
|
||||
8) Click 'Next' and check that on the second page only one instance is
|
||||
available (and it has correct name), there is no 'Next' link on page
|
||||
9) Go to user settings page and restore 'Items Per Page'
|
||||
10) Delete created instances via proper page
|
||||
"""
|
||||
items_per_page = 1
|
||||
instance_count = 2
|
||||
instance_list = ["{0}-{1}".format(self.INSTANCE_NAME, item)
|
||||
for item in range(1, instance_count + 1)]
|
||||
first_page_definition = {'Next': True, 'Prev': False,
|
||||
'Count': items_per_page,
|
||||
'Names': [instance_list[1]]}
|
||||
second_page_definition = {'Next': False, 'Prev': True,
|
||||
'Count': items_per_page,
|
||||
'Names': [instance_list[0]]}
|
||||
settings_page = self.home_pg.go_to_settings_usersettingspage()
|
||||
settings_page.change_pagesize(items_per_page)
|
||||
self.assertTrue(
|
||||
settings_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[1]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.assert_definition(
|
||||
first_page_definition, sorting=True)
|
||||
|
||||
instances_page.instances_table.turn_next_page()
|
||||
instances_page.instances_table.assert_definition(
|
||||
second_page_definition, sorting=True)
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.assert_definition(
|
||||
first_page_definition, sorting=True)
|
||||
|
||||
settings_page = self.home_pg.go_to_settings_usersettingspage()
|
||||
settings_page.change_pagesize()
|
||||
self.assertTrue(
|
||||
settings_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
def test_instances_pagination_and_filtration(self):
|
||||
"""This test checks instance pagination and filtration
|
||||
|
||||
Steps:
|
||||
1) Login to Horizon Dashboard as admin
|
||||
2) Go to to user settings page
|
||||
3) Change 'Items Per Page' value to 1
|
||||
4) Go to Project > Compute > Instances page
|
||||
5) Create 2 instances
|
||||
6) Go to Admin > Compute > Instances page
|
||||
7) Check filter by Name of the first and the second instance in order
|
||||
to have one instance in the list (and it should have correct name)
|
||||
and no 'Next' link is available
|
||||
8) Check filter by common part of Name of in order to have one instance
|
||||
in the list (and it should have correct name) and 'Next' link is
|
||||
available on the first page and is not available on the second page
|
||||
9) Go to user settings page and restore 'Items Per Page'
|
||||
10) Delete created instances via proper page
|
||||
|
||||
"""
|
||||
items_per_page = 1
|
||||
instance_count = 2
|
||||
instance_list = ["{0}-{1}".format(self.INSTANCE_NAME, item)
|
||||
for item in range(1, instance_count + 1)]
|
||||
first_page_definition = {'Next': True, 'Prev': False,
|
||||
'Count': items_per_page,
|
||||
'Names': [instance_list[1]]}
|
||||
second_page_definition = {'Next': False, 'Prev': False,
|
||||
'Count': items_per_page,
|
||||
'Names': [instance_list[0]]}
|
||||
filter_first_page_definition = {'Next': False, 'Prev': False,
|
||||
'Count': items_per_page,
|
||||
'Names': [instance_list[1]]}
|
||||
|
||||
settings_page = self.home_pg.go_to_settings_usersettingspage()
|
||||
settings_page.change_pagesize(items_per_page)
|
||||
self.assertTrue(
|
||||
settings_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[1]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
@ -183,73 +380,5 @@ class TestInstances(helpers.TestCase):
|
||||
instances_page = self.instances_page
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_filter_instances(self):
|
||||
"""This test checks filtering of instances by Instance Name
|
||||
|
||||
Steps:
|
||||
1) Login to Horizon dashboard as regular user
|
||||
2) Go to Project > Compute > Instances
|
||||
3) Create 2 instances
|
||||
4) Go to appropriate page (depends on user)
|
||||
5) Use filter by Instance Name
|
||||
6) Check that filtered table has one instance only (which name is equal
|
||||
to filter value) and no other instances in the table
|
||||
7) Check that filtered table has both instances (search by common part
|
||||
of instance names)
|
||||
8) Set nonexistent instance name. Check that 0 rows are displayed
|
||||
9) Clear filter and delete instances via proper page (depends on user)
|
||||
"""
|
||||
instance_count = 2
|
||||
instance_list = ["{0}-{1}".format(self.INSTANCE_NAME, item)
|
||||
for item in range(1, instance_count + 1)]
|
||||
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(self.INSTANCE_NAME,
|
||||
instance_count=instance_count)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_list[0]))
|
||||
|
||||
instances_page = self.instances_page
|
||||
instances_page.instances_table.set_filter_value('name')
|
||||
|
||||
instances_page.instances_table.filter(instance_list[0])
|
||||
self.assertTrue(instances_page.is_instance_present(instance_list[0]))
|
||||
for instance in instance_list[1:]:
|
||||
self.assertFalse(instances_page.is_instance_present(instance))
|
||||
|
||||
instances_page.instances_table.filter(self.INSTANCE_NAME)
|
||||
for instance in instance_list:
|
||||
self.assertTrue(instances_page.is_instance_present(instance))
|
||||
|
||||
nonexistent_instance_name = "{0}_test".format(self.INSTANCE_NAME)
|
||||
instances_page.instances_table.filter(nonexistent_instance_name)
|
||||
self.assertEqual(instances_page.instances_table.rows, [])
|
||||
instances_page.instances_table.filter('')
|
||||
|
||||
instances_page.delete_instances(instance_list)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
self.assertTrue(instances_page.are_instances_deleted(instance_list))
|
||||
|
||||
|
||||
class TestAdminInstances(helpers.AdminTestCase, TestInstances):
|
||||
INSTANCE_NAME = helpers.gen_random_resource_name('instance',
|
||||
timestamp=False)
|
||||
|
||||
@property
|
||||
def instances_page(self):
|
||||
self.home_pg.go_to_admin_overviewpage()
|
||||
return self.home_pg.go_to_admin_compute_instancespage()
|
||||
|
||||
@property
|
||||
def instance_table_name_column(self):
|
||||
return 'Name'
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_instances_pagination_and_filtration(self):
|
||||
super().test_instances_pagination_and_filtration()
|
||||
|
@ -22,7 +22,7 @@ class TestKeypair(helpers.TestCase):
|
||||
"""Checks that the user is able to create/delete keypair."""
|
||||
KEYPAIR_NAME = helpers.gen_random_resource_name("keypair")
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
@pytest.mark.skip(reason="Legacy Panel not tested")
|
||||
def test_keypair(self):
|
||||
keypair_page = self.home_pg.\
|
||||
go_to_project_compute_keypairspage()
|
||||
|
@ -175,7 +175,6 @@ class TestVolumesAdvanced(helpers.TestCase):
|
||||
def volumes_page(self):
|
||||
return self.home_pg.go_to_project_volumes_volumespage()
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
def test_manage_volume_attachments(self):
|
||||
"""This test case checks attach/detach actions for volume
|
||||
|
||||
@ -192,7 +191,7 @@ class TestVolumesAdvanced(helpers.TestCase):
|
||||
instance_name = helpers.gen_random_resource_name('instance')
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.create_instance(instance_name)
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS)
|
||||
instances_page.find_message_and_dismiss(messages.INFO)
|
||||
self.assertFalse(
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_active(instance_name))
|
||||
@ -227,7 +226,7 @@ class TestVolumesAdvanced(helpers.TestCase):
|
||||
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.delete_instance(instance_name)
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS)
|
||||
instances_page.find_message_and_dismiss(messages.INFO)
|
||||
self.assertFalse(
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_deleted(instance_name))
|
||||
@ -324,7 +323,7 @@ class TestVolumesActions(helpers.TestCase):
|
||||
self.volumes_page = \
|
||||
self.home_pg.go_to_project_volumes_volumespage()
|
||||
|
||||
@pytest.mark.skip(reason="Bug 1774697")
|
||||
@pytest.mark.skip(reason="Bug 1930420")
|
||||
def test_volume_launch_as_instance(self):
|
||||
"""This test case checks launch volume as instance functionality:
|
||||
|
||||
@ -351,7 +350,7 @@ class TestVolumesActions(helpers.TestCase):
|
||||
instances_page = self.home_pg.go_to_project_compute_instancespage()
|
||||
instances_page.delete_instance(self.INSTANCE_NAME)
|
||||
self.assertTrue(
|
||||
instances_page.find_message_and_dismiss(messages.SUCCESS))
|
||||
instances_page.find_message_and_dismiss(messages.INFO))
|
||||
self.assertFalse(
|
||||
instances_page.find_message_and_dismiss(messages.ERROR))
|
||||
self.assertTrue(instances_page.is_instance_deleted(self.INSTANCE_NAME))
|
||||
|
Loading…
x
Reference in New Issue
Block a user