| # 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 HTMLParser |
| import urllib |
| import urllib2 |
| |
| from tempest import config |
| from tempest.scenario import manager |
| from tempest import test |
| |
| CONF = config.CONF |
| |
| |
| class HorizonHTMLParser(HTMLParser.HTMLParser): |
| csrf_token = None |
| region = None |
| |
| def _find_name(self, attrs, name): |
| for attrpair in attrs: |
| if attrpair[0] == 'name' and attrpair[1] == name: |
| return True |
| return False |
| |
| def _find_value(self, attrs): |
| for attrpair in attrs: |
| if attrpair[0] == 'value': |
| return attrpair[1] |
| return None |
| |
| def handle_starttag(self, tag, attrs): |
| if tag == 'input': |
| if self._find_name(attrs, 'csrfmiddlewaretoken'): |
| self.csrf_token = self._find_value(attrs) |
| if self._find_name(attrs, 'region'): |
| self.region = self._find_value(attrs) |
| |
| |
| class TestDashboardBasicOps(manager.ScenarioTest): |
| |
| """ |
| 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 resource_setup(cls): |
| if not CONF.service_available.horizon: |
| raise cls.skipException("Horizon support is required") |
| cls.set_network_resources() |
| super(TestDashboardBasicOps, cls).resource_setup() |
| |
| 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 |
| parser = HorizonHTMLParser() |
| parser.feed(response) |
| |
| # 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': parser.region, |
| 'csrfmiddlewaretoken': parser.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() |