|
3 | 3 | import pytest
|
4 | 4 |
|
5 | 5 | from satosa.context import Context
|
6 |
| -from satosa.exception import SATOSAError, SATOSAConfigurationError |
| 6 | +from satosa.exception import SATOSAError, SATOSAConfigurationError, SATOSAStateError |
7 | 7 | from satosa.internal import InternalData
|
8 | 8 | from satosa.micro_services.custom_routing import DecideIfRequesterIsAllowed
|
| 9 | +from satosa.micro_services.custom_routing import DecideBackendByTarget |
| 10 | +from satosa.micro_services.custom_routing import CustomRoutingError |
9 | 11 |
|
10 | 12 | TARGET_ENTITY = "entity1"
|
11 | 13 |
|
@@ -156,3 +158,77 @@ def test_missing_target_entity_id_from_context(self, context):
|
156 | 158 | req = InternalData(requester="test_requester")
|
157 | 159 | with pytest.raises(SATOSAError):
|
158 | 160 | decide_service.process(context, req)
|
| 161 | + |
| 162 | + |
| 163 | +class TestDecideBackendByTarget: |
| 164 | + rules = { |
| 165 | + 'default_backend': 'Saml2', |
| 166 | + 'endpoint_paths': ['.*/disco'], |
| 167 | + 'target_mapping': {'http://idpspid.testunical.it:8088': 'spidSaml2'} |
| 168 | + } |
| 169 | + |
| 170 | + def create_decide_service(self, rules): |
| 171 | + decide_service = DecideBackendByTarget( |
| 172 | + config=rules, |
| 173 | + name="test_decide_service", |
| 174 | + base_url="https://satosa.example.com" |
| 175 | + ) |
| 176 | + decide_service.next = lambda ctx, data: data |
| 177 | + return decide_service |
| 178 | + |
| 179 | + |
| 180 | + def test_missing_state(self, target_context): |
| 181 | + decide_service = self.create_decide_service(self.rules) |
| 182 | + target_context.request = { |
| 183 | + 'entityID': 'http://idpspid.testunical.it:8088', |
| 184 | + } |
| 185 | + req = InternalData(requester="test_requester") |
| 186 | + req.requester = "somebody else" |
| 187 | + assert decide_service.process(target_context, req) |
| 188 | + |
| 189 | + with pytest.raises(SATOSAStateError): |
| 190 | + decide_service.backend_by_entityid(target_context) |
| 191 | + |
| 192 | + |
| 193 | + def test_missing_entityid(self, target_context): |
| 194 | + decide_service = self.create_decide_service(self.rules) |
| 195 | + target_context.request = { |
| 196 | + # 'entityID': None, |
| 197 | + } |
| 198 | + target_context.state['ROUTER'] = 'Saml2' |
| 199 | + |
| 200 | + req = InternalData(requester="test_requester") |
| 201 | + assert decide_service.process(target_context, req) |
| 202 | + |
| 203 | + with pytest.raises(CustomRoutingError): |
| 204 | + decide_service.backend_by_entityid(target_context) |
| 205 | + |
| 206 | + |
| 207 | + def test_unmatching_target(self, target_context): |
| 208 | + """ |
| 209 | + It would rely on the default backend |
| 210 | + """ |
| 211 | + decide_service = self.create_decide_service(self.rules) |
| 212 | + target_context.request = { |
| 213 | + 'entityID': 'unknow-entity-id', |
| 214 | + } |
| 215 | + target_context.state['ROUTER'] = 'Saml2' |
| 216 | + |
| 217 | + req = InternalData(requester="test_requester") |
| 218 | + assert decide_service.process(target_context, req) |
| 219 | + |
| 220 | + res = decide_service.backend_by_entityid(target_context) |
| 221 | + assert isinstance(res, InternalData) |
| 222 | + |
| 223 | + def test_matching_target(self, target_context): |
| 224 | + decide_service = self.create_decide_service(self.rules) |
| 225 | + target_context.request = { |
| 226 | + 'entityID': 'http://idpspid.testunical.it:8088-entity-id' |
| 227 | + } |
| 228 | + target_context.state['ROUTER'] = 'Saml2' |
| 229 | + |
| 230 | + req = InternalData(requester="test_requester") |
| 231 | + req.requester = "somebody else" |
| 232 | + assert decide_service.process(target_context, req) |
| 233 | + res = decide_service.backend_by_entityid(target_context) |
| 234 | + assert isinstance(res, InternalData) |
0 commit comments