2 * Copyright (c) 2019 AT&T Intellectual Property.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 * This source code is part of the near-RT RIC (RAN Intelligent Controller)
19 * platform project (RICP).
27 "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities"
34 Test permutations of x2 setup response to protobuf enb
37 func TestUnpackX2SetupFailureResponseAndExtract(t *testing.T) {
39 logger, _ := logger.InitLogger(InfoLevel)
41 var testCases = []struct {
47 response: "CONNECTED_SETUP_FAILED network_layer_cause:HANDOVER_DESIRABLE_FOR_RADIO_REASONS time_to_wait:V1S criticality_diagnostics:{procedure_code:33 triggering_message:UNSUCCESSFUL_OUTCOME procedure_criticality:NOTIFY information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING}}",
55 ProtocolIE_Container_elm
60 ProtocolIE_Container_elm
64 ProtocolIE_Container_elm
67 CriticalityDiagnostics
68 procedureCode_t = 0x21
69 triggeringMessage_t = 0x2
70 procedureCriticality_t = 0x2
71 iEsCriticalityDiagnostics_t:
72 CriticalityDiagnostics_IE_List_elm
77 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040"},
79 response: "CONNECTED_SETUP_FAILED transport_layer_cause:TRANSPORT_RESOURCE_UNAVAILABLE criticality_diagnostics:{procedure_code:33 triggering_message:UNSUCCESSFUL_OUTCOME procedure_criticality:NOTIFY information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING}}",
87 ProtocolIE_Container_elm
92 ProtocolIE_Container_elm
95 CriticalityDiagnostics
96 procedureCode_t = 0x21
97 triggeringMessage_t = 0x2
98 procedureCriticality_t = 0x2
99 iEsCriticalityDiagnostics_t:
100 CriticalityDiagnostics_IE_List_elm
105 packedPdu: "400600140000020005400120001140087821a00000008040"},
107 response: "CONNECTED_SETUP_FAILED protocol_cause:ABSTRACT_SYNTAX_ERROR_IGNORE_AND_NOTIFY criticality_diagnostics:{triggering_message:UNSUCCESSFUL_OUTCOME procedure_criticality:NOTIFY information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING}}",
110 unsuccessfulOutcome_t
111 procedureCode_t = 0x6
115 ProtocolIE_Container_elm
120 ProtocolIE_Container_elm
123 CriticalityDiagnostics
124 triggeringMessage_t = 0x2
125 procedureCriticality_t = 0x2
126 iEsCriticalityDiagnostics_t:
127 CriticalityDiagnostics_IE_List_elm
132 packedPdu: "400600130000020005400144001140073a800000008040"},
135 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED criticality_diagnostics:{procedure_criticality:NOTIFY information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING}}",
138 unsuccessfulOutcome_t
139 procedureCode_t = 0x6
143 ProtocolIE_Container_elm
148 ProtocolIE_Container_elm
151 CriticalityDiagnostics
152 procedureCriticality_t = 0x2
153 iEsCriticalityDiagnostics_t:
154 CriticalityDiagnostics_IE_List_elm
159 packedPdu: "400600120000020005400168001140061a0000008040"},
162 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED criticality_diagnostics:{information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING} information_element_criticality_diagnostics:{ie_criticality:NOTIFY ie_id:255 type_of_error:NOT_UNDERSTOOD}}",
165 unsuccessfulOutcome_t
166 procedureCode_t = 0x6
170 ProtocolIE_Container_elm
175 ProtocolIE_Container_elm
178 CriticalityDiagnostics
179 iEsCriticalityDiagnostics_t:
180 CriticalityDiagnostics_IE_List_elm
184 CriticalityDiagnostics_IE_List_elm
185 iECriticality_t = 0x2
189 packedPdu: "4006001500000200054001680011400908010000804800ff00"},
193 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED criticality_diagnostics:{procedure_code:33}",
196 unsuccessfulOutcome_t
197 procedureCode_t = 0x6
201 ProtocolIE_Container_elm
206 ProtocolIE_Container_elm
209 CriticalityDiagnostics
210 procedureCode_t = 0x21
212 packedPdu: "4006000e0000020005400168001140024021"},
215 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED",
218 unsuccessfulOutcome_t
219 procedureCode_t = 0x6
223 ProtocolIE_Container_elm
229 packedPdu: "400600080000010005400168"},
231 response: "CONNECTED_SETUP_FAILED network_layer_cause:HANDOVER_DESIRABLE_FOR_RADIO_REASONS time_to_wait:V1S criticality_diagnostics:{procedure_code:33 triggering_message:UNSUCCESSFUL_OUTCOME procedure_criticality:NOTIFY information_element_criticality_diagnostics:{ie_criticality:REJECT ie_id:128 type_of_error:MISSING}}",
234 unsuccessfulOutcome_t
235 procedureCode_t = 0x6
239 ProtocolIE_Container_elm
244 ProtocolIE_Container_elm
248 ProtocolIE_Container_elm
251 CriticalityDiagnostics
252 procedureCode_t = 0x21
253 triggeringMessage_t = 0x2
254 procedureCriticality_t = 0x2
255 iEsCriticalityDiagnostics_t:
256 CriticalityDiagnostics_IE_List_elm
261 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040",
262 //failure: fmt.Errorf("getAtom for path [unsuccessfulOutcome_t X2SetupFailure protocolIEs_t ProtocolIE_Container_elm Cause radioNetwork_t] failed, rc = 2" /*NO_SPACE_LEFT*/),
266 converter := NewX2SetupFailureResponseConverter(logger)
268 for _, tc := range testCases {
269 t.Run(tc.packedPdu, func(t *testing.T) {
272 _, err := fmt.Sscanf(tc.packedPdu, "%x", &payload)
274 t.Errorf("convert inputPayloadAsStr to payloadAsByte. Error: %v\n", err)
277 response, err := converter.UnpackX2SetupFailureResponseAndExtract(payload)
280 if tc.failure == nil {
281 t.Errorf("want: success, got: error: %v\n", err)
283 if strings.Compare(err.Error(), tc.failure.Error()) != 0 {
284 t.Errorf("want: %s, got: %s", tc.failure, err)
290 if tc.failure == nil {
291 t.Errorf("want: response=%s, got: empty response", tc.response)
294 nb := &entities.NodebInfo{}
295 nb.ConnectionStatus = entities.ConnectionStatus_CONNECTED_SETUP_FAILED
296 nb.SetupFailure = response
297 nb.FailureType = entities.Failure_X2_SETUP_FAILURE
298 respStr := fmt.Sprintf("%s %s", nb.ConnectionStatus, response)
300 space := regexp.MustCompile(`\s+`)
301 s1 := space.ReplaceAllString(respStr, " ")
302 s2 := space.ReplaceAllString(tc.response," ")
304 if !strings.EqualFold(s1, s2) {
305 t.Errorf("want: [%s], got: [%s]", tc.response, respStr)