Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(97)

Side by Side Diff: appengine/monorail/sitewide/test/groupcreate_test.py

Issue 1868553004: Open Source Monorail (Closed) Base URL: https://chromium.googlesource.com/infra/infra.git@master
Patch Set: Rebase Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 # Copyright 2016 The Chromium Authors. All rights reserved.
2 # Use of this source code is govered by a BSD-style
3 # license that can be found in the LICENSE file or at
4 # https://developers.google.com/open-source/licenses/bsd
5
6 """Unit test for User Group creation servlet."""
7
8 import unittest
9
10 import settings
11 from framework import permissions
12 from proto import site_pb2
13 from proto import usergroup_pb2
14 from services import service_manager
15 from sitewide import groupcreate
16 from testing import fake
17 from testing import testing_helpers
18
19
20 class GroupCreateTest(unittest.TestCase):
21 """Tests for the GroupCreate servlet."""
22
23 def setUp(self):
24 self.services = service_manager.Services(
25 user=fake.UserService(),
26 usergroup=fake.UserGroupService(),
27 project=fake.ProjectService())
28 self.servlet = groupcreate.GroupCreate(
29 'req', 'res', services=self.services)
30 self.mr = testing_helpers.MakeMonorailRequest()
31
32 def CheckAssertBasePermissions(
33 self, restriction, expect_admin_ok, expect_nonadmin_ok):
34 old_group_creation_restriction = settings.group_creation_restriction
35 settings.group_creation_restriction = restriction
36
37 # Anon users can never do it
38 mr = testing_helpers.MakeMonorailRequest(
39 perms=permissions.GetPermissions(None, {}, None))
40 self.assertRaises(
41 permissions.PermissionException,
42 self.servlet.AssertBasePermission, mr)
43
44 mr = testing_helpers.MakeMonorailRequest()
45 if expect_admin_ok:
46 self.servlet.AssertBasePermission(mr)
47 else:
48 self.assertRaises(
49 permissions.PermissionException,
50 self.servlet.AssertBasePermission, mr)
51
52 mr = testing_helpers.MakeMonorailRequest(
53 perms=permissions.GetPermissions(mr.auth.user_pb, {111L}, None))
54 if expect_nonadmin_ok:
55 self.servlet.AssertBasePermission(mr)
56 else:
57 self.assertRaises(
58 permissions.PermissionException,
59 self.servlet.AssertBasePermission, mr)
60
61 settings.group_creation_restriction = old_group_creation_restriction
62
63 def testAssertBasePermission(self):
64 self.CheckAssertBasePermissions(
65 site_pb2.UserTypeRestriction.ANYONE, True, True)
66 self.CheckAssertBasePermissions(
67 site_pb2.UserTypeRestriction.ADMIN_ONLY, True, False)
68 self.CheckAssertBasePermissions(
69 site_pb2.UserTypeRestriction.NO_ONE, False, False)
70
71 def testGatherPageData(self):
72 page_data = self.servlet.GatherPageData(self.mr)
73 self.assertEqual('', page_data['initial_name'])
74
75 def testProcessFormData_Normal(self):
76 post_data = fake.PostData(
77 groupname=['group@example.com'], visibility='1')
78 url = self.servlet.ProcessFormData(self.mr, post_data)
79 self.assertIn('/g/3444127190/', url)
80 group_id = self.services.user.LookupUserID('cnxn', 'group@example.com')
81 group_settings = self.services.usergroup.GetGroupSettings('cnxn', group_id)
82 self.assertIsNotNone(group_settings)
83 members_after, owners_after = self.services.usergroup.LookupMembers(
84 'cnxn', [group_id])
85 self.assertEqual(0, len(members_after[group_id] + owners_after[group_id]))
86
87 def testProcessFormData_Import(self):
88 post_data = fake.PostData(
89 groupname=['group@example.com'], group_type='1',
90 import_group=['on'])
91 self.servlet.ProcessFormData(self.mr, post_data)
92 group_id = self.services.user.LookupUserID('cnxn', 'group@example.com')
93 group_settings = self.services.usergroup.GetGroupSettings('cnxn', group_id)
94 self.assertIsNotNone(group_settings)
95 self.assertEqual(usergroup_pb2.MemberVisibility.OWNERS,
96 group_settings.who_can_view_members)
97 self.assertEqual(usergroup_pb2.GroupType.MDB,
98 group_settings.ext_group_type)
99
100
101 if __name__ == '__main__':
102 unittest.main()
OLDNEW
« no previous file with comments | « appengine/monorail/sitewide/test/groupadmin_test.py ('k') | appengine/monorail/sitewide/test/groupdetail_test.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698