~ubuntu-branches/ubuntu/vivid/neutron/vivid-updates

« back to all changes in this revision

Viewing changes to neutron/tests/tempest/manager.py

  • Committer: Package Import Robot
  • Author(s): James Page
  • Date: 2015-03-30 11:17:19 UTC
  • mfrom: (1.1.21)
  • Revision ID: package-import@ubuntu.com-20150330111719-h0gx7233p4jkkgfh
Tags: 1:2015.1~b3-0ubuntu1
* New upstream milestone release:
  - d/control: Align version requirements with upstream.
  - d/control: Add new dependency on oslo-log.
  - d/p/*: Rebase.
  - d/control,d/neutron-plugin-hyperv*: Dropped, decomposed into
    separate project upstream.
  - d/control,d/neutron-plugin-openflow*: Dropped, decomposed into
    separate project upstream.
  - d/neutron-common.install: Add neutron-rootwrap-daemon and 
    neutron-keepalived-state-change binaries.
  - d/rules: Ignore neutron-hyperv-agent when installing; only for Windows.
  - d/neutron-plugin-cisco.install: Drop neutron-cisco-cfg-agent as
    decomposed into separate project upstream.
  - d/neutron-plugin-vmware.install: Drop neutron-check-nsx-config and
    neutron-nsx-manage as decomposed into separate project upstream.
  - d/control: Add dependency on python-neutron-fwaas to neutron-l3-agent.
* d/pydist-overrides: Add overrides for oslo packages.
* d/control: Fixup type in package description (LP: #1263539).
* d/p/fixup-driver-test-execution.patch: Cherry pick fix from upstream VCS
  to support unit test exection in out-of-tree vendor drivers.
* d/neutron-common.postinst: Allow general access to /etc/neutron but limit
  access to root/neutron to /etc/neutron/neutron.conf to support execution
  of unit tests in decomposed vendor drivers.
* d/control: Add dependency on python-neutron-fwaas to neutron-l3-agent
  package.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright 2012 OpenStack Foundation
 
2
# All Rights Reserved.
 
3
#
 
4
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
 
5
#    not use this file except in compliance with the License. You may obtain
 
6
#    a copy of the License at
 
7
#
 
8
#         http://www.apache.org/licenses/LICENSE-2.0
 
9
#
 
10
#    Unless required by applicable law or agreed to in writing, software
 
11
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 
12
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 
13
#    License for the specific language governing permissions and limitations
 
14
#    under the License.
 
15
 
 
16
from neutron.tests.tempest import auth
 
17
from neutron.tests.tempest.common import cred_provider
 
18
from neutron.tests.tempest import config
 
19
from neutron.tests.tempest import exceptions
 
20
 
 
21
CONF = config.CONF
 
22
 
 
23
 
 
24
class Manager(object):
 
25
 
 
26
    """
 
27
    Base manager class
 
28
 
 
29
    Manager objects are responsible for providing a configuration object
 
30
    and a client object for a test case to use in performing actions.
 
31
    """
 
32
 
 
33
    def __init__(self, credentials=None):
 
34
        """
 
35
        We allow overriding of the credentials used within the various
 
36
        client classes managed by the Manager object. Left as None, the
 
37
        standard username/password/tenant_name[/domain_name] is used.
 
38
 
 
39
        :param credentials: Override of the credentials
 
40
        """
 
41
        self.auth_version = CONF.identity.auth_version
 
42
        if credentials is None:
 
43
            self.credentials = cred_provider.get_configured_credentials('user')
 
44
        else:
 
45
            self.credentials = credentials
 
46
        # Check if passed or default credentials are valid
 
47
        if not self.credentials.is_valid():
 
48
            raise exceptions.InvalidCredentials()
 
49
        # Creates an auth provider for the credentials
 
50
        self.auth_provider = get_auth_provider(self.credentials)
 
51
        # FIXME(andreaf) unused
 
52
        self.client_attr_names = []
 
53
 
 
54
 
 
55
def get_auth_provider_class(credentials):
 
56
    if isinstance(credentials, auth.KeystoneV3Credentials):
 
57
        return auth.KeystoneV3AuthProvider, CONF.identity.uri_v3
 
58
    else:
 
59
        return auth.KeystoneV2AuthProvider, CONF.identity.uri
 
60
 
 
61
 
 
62
def get_auth_provider(credentials):
 
63
    default_params = {
 
64
        'disable_ssl_certificate_validation':
 
65
            CONF.identity.disable_ssl_certificate_validation,
 
66
        'ca_certs': CONF.identity.ca_certificates_file,
 
67
        'trace_requests': CONF.debug.trace_requests
 
68
    }
 
69
    if credentials is None:
 
70
        raise exceptions.InvalidCredentials(
 
71
            'Credentials must be specified')
 
72
    auth_provider_class, auth_url = get_auth_provider_class(
 
73
        credentials)
 
74
    return auth_provider_class(credentials, auth_url, **default_params)