4ded9f057d
We can use H302 rule but ignore it now. This commit prepares for enabling H302 rule. But this commit modifies tempest/scenario only and excludes some violations[1] because if we fix all of them at one time, it's hard to merge this commit. [1] tempest.test.attr tempest.common.rest_client.RestClient tempest.common.rest_client.RestClientXML tempest.services.compute.xml.common.xml_to_json tempest.services.compute.xml.common.Element tempest.services.compute.xml.common.Document tempest.services.compute.xml.common.Text tempest.services.compute.xml.common.XMLNS_11 tempest.services.compute.xml.common.XMLNS_V3 tempest/clients.py Change-Id: I57c26ef681120a9ee826b9cef26d1aaa734d69e5
77 lines
2.6 KiB
Python
77 lines
2.6 KiB
Python
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
|
|
import urllib
|
|
import urllib2
|
|
|
|
from lxml import html
|
|
|
|
from tempest import config
|
|
from tempest.scenario import manager
|
|
from tempest import test
|
|
|
|
CONF = config.CONF
|
|
|
|
|
|
class TestDashboardBasicOps(manager.OfficialClientTest):
|
|
|
|
"""
|
|
This is a basic scenario test:
|
|
* checks that the login page is available
|
|
* logs in as a regular user
|
|
* checks that the user home page loads without error
|
|
"""
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
cls.set_network_resources()
|
|
super(TestDashboardBasicOps, cls).setUpClass()
|
|
|
|
if not CONF.service_available.horizon:
|
|
raise cls.skipException("Horizon support is required")
|
|
|
|
def check_login_page(self):
|
|
response = urllib2.urlopen(CONF.dashboard.dashboard_url)
|
|
self.assertIn("<h3>Log In</h3>", response.read())
|
|
|
|
def user_login(self):
|
|
self.opener = urllib2.build_opener(urllib2.HTTPCookieProcessor())
|
|
response = self.opener.open(CONF.dashboard.dashboard_url).read()
|
|
|
|
# Grab the CSRF token and default region
|
|
csrf_token = html.fromstring(response).xpath(
|
|
'//input[@name="csrfmiddlewaretoken"]/@value')[0]
|
|
region = html.fromstring(response).xpath(
|
|
'//input[@name="region"]/@value')[0]
|
|
|
|
# Prepare login form request
|
|
req = urllib2.Request(CONF.dashboard.login_url)
|
|
req.add_header('Content-type', 'application/x-www-form-urlencoded')
|
|
req.add_header('Referer', CONF.dashboard.dashboard_url)
|
|
params = {'username': CONF.identity.username,
|
|
'password': CONF.identity.password,
|
|
'region': region,
|
|
'csrfmiddlewaretoken': csrf_token}
|
|
self.opener.open(req, urllib.urlencode(params))
|
|
|
|
def check_home_page(self):
|
|
response = self.opener.open(CONF.dashboard.dashboard_url)
|
|
self.assertIn('Overview', response.read())
|
|
|
|
@test.services('dashboard')
|
|
def test_basic_scenario(self):
|
|
self.check_login_page()
|
|
self.user_login()
|
|
self.check_home_page()
|