-
Notifications
You must be signed in to change notification settings - Fork 39
Expand file tree
/
Copy pathcreate_subject_test.py
More file actions
98 lines (85 loc) · 3.36 KB
/
create_subject_test.py
File metadata and controls
98 lines (85 loc) · 3.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# Copyright 2021 Google LLC
#
# 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.
#
"""Unit tests for the "create_subject" module."""
import unittest
import argparse
from unittest import mock
from google.auth.transport import requests
from . import create_subject
class CreateSubjectTest(unittest.TestCase):
def test_initialize_command_line_args(self):
actual = create_subject.initialize_command_line_args(
["--name=test@test.com", "--type=SUBJECT_TYPE_ANALYST", "--roles="])
self.assertEqual(
actual,
argparse.Namespace(
credentials_file=None,
name="test@test.com",
type="SUBJECT_TYPE_ANALYST",
roles="",
region="us"))
def test_initialize_command_line_args_subject_type(self):
actual = create_subject.initialize_command_line_args(
["--name=test@test.com", "--type=SUBJECT_TYPE_INVALID", "--roles="])
self.assertIsNone(actual)
@mock.patch.object(requests, "AuthorizedSession", autospec=True)
@mock.patch.object(requests.requests, "Response", autospec=True)
def test_create_subject_error(self, mock_response, mock_session):
mock_session.request.return_value = mock_response
type(mock_response).status_code = mock.PropertyMock(return_value=400)
mock_response.raise_for_status.side_effect = (
requests.requests.exceptions.HTTPError())
with self.assertRaises(requests.requests.exceptions.HTTPError):
create_subject.create_subject(mock_session, "", "", [])
@mock.patch.object(requests, "AuthorizedSession", autospec=True)
@mock.patch.object(requests.requests, "Response", autospec=True)
def test_create_subject(self, mock_response, mock_session):
mock_session.request.return_value = mock_response
type(mock_response).status_code = mock.PropertyMock(return_value=200)
subject_id = "test@test.com"
subject_type = "SUBJECT_TYPE_ANALYST"
roles = ["Test"]
expected = {
"subject": {
"name":
subject_id,
"type":
subject_type,
"roles": [{
"name":
"Test",
"title":
"Test role",
"description":
"The Test role",
"createTime":
"2020-11-05T00:00:00Z",
"isDefault":
False,
"permissions": [{
"name": "Test",
"title": "Test permission",
"description": "The Test permission",
"createTime": "2020-11-05T00:00:00Z",
},]
},]
},
}
mock_response.json.return_value = expected
actual = create_subject.create_subject(mock_session, subject_id,
subject_type, roles)
self.assertEqual(actual, expected)
if __name__ == "__main__":
unittest.main()