~ubuntu-branches/ubuntu/saucy/maas/saucy-updates

« back to all changes in this revision

Viewing changes to src/maasserver/tests/test_views_settings_clusters.py

  • Committer: Package Import Robot
  • Author(s): Andres Rodriguez, Julian Edwards, Raphaël Badin, Jeroen Vermeulen, Andres Rodriguez, Robie Basak, Scott Moser, Diogo Matsubara
  • Date: 2012-10-08 13:10:23 UTC
  • mfrom: (1.1.18)
  • mto: This revision was merged to the branch mainline in revision 21.
  • Revision ID: package-import@ubuntu.com-20121008131023-68glibh0pbqrgtfq
Tags: 0.1+bzr1223+dfsg-0ubuntu1
* New upstream release. (LP: #1062518)

[ Julian Edwards ]
* Split packaging of 'maas' into maas-{region,cluster}-controller
  - debian/control: Update accordingly.
  - debian/*.install: Move files accordingly
  - debian/*.{postinst,postrm,preinst}: Move files accordingly.
* Ensure isc-dhcp-server is disabled when installing maas-dhcp.
* Ensure maas-dns creates the maas user before trying to chown files.
* Make maas-cluster-controller autoconfigure itself when upgrading from the
  old maas package. (LP: #1059416)
* Add missing prerm file for maas-cluster-controller so that .pyc files
  are cleaned up. (LP: #1059973)

[ Raphaël Badin ]
* Install maas_local_celeryconfig.py in /etc/maas and symlink to
  /usr/share/maas.
* debian/maas.postinst: Create rabbitmq celery user/vhost.
* debian/maas.postinst: Update BROKER_URL in maas_local_celeryconfig.py.
* Use maas_local_celeryconfig_cluster.py as the local celery
  configuration file for the cluster worker.
* debian/maas-region-controller.maas-region-celery.upstart: Add region
  worker upstart script.
* Rename cluster worker upstart script into
  maas-cluster-controller.maas-clluster-celery.upstart.
* maas-cluster-controller.maas-celery.upstart: use "celeryconfig_cluster"
  as the Celery config module.
* debian/maas-common.install: Install celeryconfig_common.py.
* debian/maas-cluster-controller.install: Install celeryconfig_cluster.py.
* debian/maas-region-controller.install: Install celeryconfig.py.
* Split celery config into cluster and region configs.
* Add region celeryd upstart config.
* Define CELERY_CONFIG_MODULE in
  maas-cluster-controller.maas-cluster-celery.upstart

[ Jeroen Vermeulen ]
* Make maas_local_celery_config.py non-world readable.
* Make maas_local_celeryconfig_cluster.py non-world readable.
* Set root:maas ownership of local cluster config only *after*
  the maas user/group have been created

[ Andres Rodriguez ]
* debian/maas.postinst:
  - Always restart apache2.
  - Handle upgrades for new upstream release.
  - Handle upgrades for celery rabbitmq worker.
* Add binary package to install client tool.
  - debian/extras/maas-cli: Add binary.
  - debian/maas-cli.install: Add. Install maascli and apiclient.
  - debian/control: Add binary package.
* debian/control:
  - Depends on freeipmi-tools instead of ipmitool.
  - Conflicts/Replaces on maas for python-maas-client.
  - Depends on python-netifaces, python-lxml.
* Add python-maas-client binary package:
  - debian/python-maas-client.install: Add. Install 'apiclient' python module.
  - debian/control: Add package. python-django-maas and maas-cli now
    Depend on it.
* debian/rules: Install maas-dhcp-server upstart job.
* debian/maas.postrm: Remove celery worker rabbitmq user and host.
* debian/extras/99-maas-sudoers: Add for maas-dhcp-server upstart job
  instead of isc-dhcp-server (LP: #1055951)
* debian/maas-region-controller.postinst: Cleanup upgrade rules.
* debian/maas-cluster-controller.postinst: Fix 'local' usage.
* debian/maas-common.install: Install celeryconfig in appropriate location.
* debian/maas-cluster-controller.postrm: Add and delete maas user.
* debian/maas-dhcp.postinst: Stop isc-dhcp-server not isc_dhcp_server.
* debian/maas-region-controller.postinst:
  - Always update passwords on upgrade. No longer check versioning. (LP: #1060094).
  - Add MAAS server to allowed mirror in squid-deb-proxy
  - Source dbconfig conf file for maas-region-controller on upgrade because
    it writes a new config file and no longer preservers the previous password.
* debian/maas-cluster-controller.maas-cluster-celery.upstart: Remove set{uid/gid}.
* debian/maas-region-controller.install: Install maas-import-squashfs
* Handle removal of non existant files (LP: #1059556):
  - debian/maintscript: Added to handle removal of conffiles.
  - debian/control: Add Pre-depends and bump debhelper version.
* update po files for the templates.
* debian/extras/99-maas: Install in usr/share/maas/conf and symlink to the
  appropriate etc dir.
* debian/maas-cluster-controller.config: Source debconf at the beginning of the
  script. (LP: #1063857)
* debian/patches/99-temporary-fix-constraints.patch: Fix constraints maaping
  when deploying with juju. Temporary until it gets merged upstream

[ Robie Basak ]
* Add maas-cluster-controller dependency on uuid-runtime, needed for uuidgen
  by postinst.

[ Scott Moser ]
* debian/maas-dhcp.{install,apparmor,postrm} install apparmor profile into
  /etc/apparmor.d/dhcpd.d (LP: #1049177), and update apparmor profile for
  /usr/sbin/dhcpd on install/remove
* get the ip address for the dhcp server in config

[ Diogo Matsubara ]
* Add initial tests to be run by autotests:
  - debian/control: XS-Testsuite: autopkgtest
  - debian/tests/control: Add
  - debian/tests/maas-package-test: Add
  - tests/maas-integration.py: Add

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright 2012 Canonical Ltd.  This software is licensed under the
 
2
# GNU Affero General Public License version 3 (see the file LICENSE).
 
3
 
 
4
"""Test maasserver clusters views."""
 
5
 
 
6
from __future__ import (
 
7
    absolute_import,
 
8
    print_function,
 
9
    unicode_literals,
 
10
    )
 
11
 
 
12
__metaclass__ = type
 
13
__all__ = []
 
14
 
 
15
import httplib
 
16
 
 
17
from django.core.urlresolvers import reverse
 
18
from maasserver.enum import (
 
19
    NODEGROUP_STATUS,
 
20
    NODEGROUPINTERFACE_MANAGEMENT,
 
21
    )
 
22
from maasserver.models import (
 
23
    NodeGroup,
 
24
    NodeGroupInterface,
 
25
    )
 
26
from maasserver.testing import (
 
27
    extract_redirect,
 
28
    get_content_links,
 
29
    reload_object,
 
30
    )
 
31
from maasserver.testing.factory import factory
 
32
from maasserver.testing.testcase import (
 
33
    AdminLoggedInTestCase,
 
34
    )
 
35
from maastesting.matchers import ContainsAll
 
36
from testtools.matchers import MatchesStructure
 
37
 
 
38
 
 
39
class ClusterListingTest(AdminLoggedInTestCase):
 
40
 
 
41
    def test_settings_contains_links_to_edit_and_delete_clusters(self):
 
42
        nodegroups = {
 
43
            factory.make_node_group(status=NODEGROUP_STATUS.ACCEPTED),
 
44
            factory.make_node_group(status=NODEGROUP_STATUS.PENDING),
 
45
            factory.make_node_group(status=NODEGROUP_STATUS.REJECTED),
 
46
            }
 
47
        links = get_content_links(self.client.get(reverse('settings')))
 
48
        nodegroup_edit_links = [
 
49
            reverse('cluster-edit', args=[nodegroup.uuid])
 
50
            for nodegroup in nodegroups]
 
51
        nodegroup_delete_links = [
 
52
            reverse('cluster-delete', args=[nodegroup.uuid])
 
53
            for nodegroup in nodegroups]
 
54
        self.assertThat(
 
55
            links,
 
56
            ContainsAll(nodegroup_edit_links + nodegroup_delete_links))
 
57
 
 
58
 
 
59
class ClusterDeleteTest(AdminLoggedInTestCase):
 
60
 
 
61
    def test_can_delete_cluster(self):
 
62
        nodegroup = factory.make_node_group()
 
63
        delete_link = reverse('cluster-delete', args=[nodegroup.uuid])
 
64
        response = self.client.post(delete_link, {'post': 'yes'})
 
65
        self.assertEqual(
 
66
            (httplib.FOUND, reverse('settings')),
 
67
            (response.status_code, extract_redirect(response)))
 
68
        self.assertFalse(
 
69
            NodeGroup.objects.filter(uuid=nodegroup.uuid).exists())
 
70
 
 
71
 
 
72
class ClusterEditTest(AdminLoggedInTestCase):
 
73
 
 
74
    def test_cluster_page_contains_links_to_edit_and_delete_interfaces(self):
 
75
        nodegroup = factory.make_node_group()
 
76
        interfaces = set()
 
77
        for i in range(3):
 
78
            interface = factory.make_node_group_interface(
 
79
                nodegroup=nodegroup,
 
80
                management=NODEGROUPINTERFACE_MANAGEMENT.UNMANAGED)
 
81
            interfaces.add(interface)
 
82
        links = get_content_links(
 
83
            self.client.get(reverse('cluster-edit', args=[nodegroup.uuid])))
 
84
        interface_edit_links = [
 
85
            reverse('cluster-interface-edit',
 
86
            args=[nodegroup.uuid, interface.interface])
 
87
            for interface in interfaces]
 
88
        interface_delete_links = [
 
89
            reverse('cluster-interface-delete',
 
90
            args=[nodegroup.uuid, interface.interface])
 
91
            for interface in interfaces]
 
92
        self.assertThat(
 
93
            links,
 
94
            ContainsAll(interface_edit_links + interface_delete_links))
 
95
 
 
96
    def test_can_edit_cluster(self):
 
97
        nodegroup = factory.make_node_group()
 
98
        edit_link = reverse('cluster-edit', args=[nodegroup.uuid])
 
99
        data = {
 
100
            'cluster_name': factory.make_name('cluster_name'),
 
101
            'name': factory.make_name('name'),
 
102
            'status': factory.getRandomEnum(NODEGROUP_STATUS),
 
103
            }
 
104
        response = self.client.post(edit_link, data)
 
105
        self.assertEqual(httplib.FOUND, response.status_code, response.content)
 
106
        self.assertThat(
 
107
            reload_object(nodegroup),
 
108
            MatchesStructure.byEquality(**data))
 
109
 
 
110
 
 
111
class ClusterInterfaceDeleteTest(AdminLoggedInTestCase):
 
112
 
 
113
    def test_can_delete_cluster_interface(self):
 
114
        nodegroup = factory.make_node_group()
 
115
        interface = factory.make_node_group_interface(
 
116
            nodegroup=nodegroup,
 
117
            management=NODEGROUPINTERFACE_MANAGEMENT.UNMANAGED)
 
118
        delete_link = reverse(
 
119
            'cluster-interface-delete',
 
120
            args=[nodegroup.uuid, interface.interface])
 
121
        response = self.client.post(delete_link, {'post': 'yes'})
 
122
        self.assertEqual(
 
123
            (httplib.FOUND, reverse('cluster-edit', args=[nodegroup.uuid])),
 
124
            (response.status_code, extract_redirect(response)))
 
125
        self.assertFalse(
 
126
            NodeGroupInterface.objects.filter(id=interface.id).exists())
 
127
 
 
128
 
 
129
class ClusterInterfaceEditTest(AdminLoggedInTestCase):
 
130
 
 
131
    def test_can_edit_cluster_interface(self):
 
132
        nodegroup = factory.make_node_group(
 
133
            management=NODEGROUPINTERFACE_MANAGEMENT.UNMANAGED)
 
134
        interface = factory.make_node_group_interface(
 
135
            nodegroup=nodegroup)
 
136
        edit_link = reverse(
 
137
            'cluster-interface-edit',
 
138
            args=[nodegroup.uuid, interface.interface])
 
139
        data = factory.get_interface_fields()
 
140
        response = self.client.post(edit_link, data)
 
141
        self.assertEqual(httplib.FOUND, response.status_code, response.content)
 
142
        self.assertThat(
 
143
            reload_object(interface),
 
144
            MatchesStructure.byEquality(**data))