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"
33 Test permutations of x2 setup response to protobuf enb
36 func TestUnpackX2SetupFailureResponseAndExtract(t *testing.T) {
37 logger, _ := logger.InitLogger(logger.InfoLevel)
39 var testCases = []struct {
45 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 > > ",
53 ProtocolIE_Container_elm
58 ProtocolIE_Container_elm
62 ProtocolIE_Container_elm
65 CriticalityDiagnostics
66 procedureCode_t = 0x21
67 triggeringMessage_t = 0x2
68 procedureCriticality_t = 0x2
69 iEsCriticalityDiagnostics_t:
70 CriticalityDiagnostics_IE_List_elm
75 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040"},
77 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 > > ",
85 ProtocolIE_Container_elm
90 ProtocolIE_Container_elm
93 CriticalityDiagnostics
94 procedureCode_t = 0x21
95 triggeringMessage_t = 0x2
96 procedureCriticality_t = 0x2
97 iEsCriticalityDiagnostics_t:
98 CriticalityDiagnostics_IE_List_elm
103 packedPdu: "400600140000020005400120001140087821a00000008040"},
105 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 > > ",
108 unsuccessfulOutcome_t
109 procedureCode_t = 0x6
113 ProtocolIE_Container_elm
118 ProtocolIE_Container_elm
121 CriticalityDiagnostics
122 triggeringMessage_t = 0x2
123 procedureCriticality_t = 0x2
124 iEsCriticalityDiagnostics_t:
125 CriticalityDiagnostics_IE_List_elm
130 packedPdu: "400600130000020005400144001140073a800000008040"},
133 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 > > ",
136 unsuccessfulOutcome_t
137 procedureCode_t = 0x6
141 ProtocolIE_Container_elm
146 ProtocolIE_Container_elm
149 CriticalityDiagnostics
150 procedureCriticality_t = 0x2
151 iEsCriticalityDiagnostics_t:
152 CriticalityDiagnostics_IE_List_elm
157 packedPdu: "400600120000020005400168001140061a0000008040"},
160 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 > > ",
163 unsuccessfulOutcome_t
164 procedureCode_t = 0x6
168 ProtocolIE_Container_elm
173 ProtocolIE_Container_elm
176 CriticalityDiagnostics
177 iEsCriticalityDiagnostics_t:
178 CriticalityDiagnostics_IE_List_elm
182 CriticalityDiagnostics_IE_List_elm
183 iECriticality_t = 0x2
187 packedPdu: "4006001500000200054001680011400908010000804800ff00"},
191 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED criticality_diagnostics:<procedure_code:33 > ",
194 unsuccessfulOutcome_t
195 procedureCode_t = 0x6
199 ProtocolIE_Container_elm
204 ProtocolIE_Container_elm
207 CriticalityDiagnostics
208 procedureCode_t = 0x21
210 packedPdu: "4006000e0000020005400168001140024021"},
213 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED ",
216 unsuccessfulOutcome_t
217 procedureCode_t = 0x6
221 ProtocolIE_Container_elm
227 packedPdu: "400600080000010005400168"},
229 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 > > ",
232 unsuccessfulOutcome_t
233 procedureCode_t = 0x6
237 ProtocolIE_Container_elm
242 ProtocolIE_Container_elm
246 ProtocolIE_Container_elm
249 CriticalityDiagnostics
250 procedureCode_t = 0x21
251 triggeringMessage_t = 0x2
252 procedureCriticality_t = 0x2
253 iEsCriticalityDiagnostics_t:
254 CriticalityDiagnostics_IE_List_elm
259 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040",
260 //failure: fmt.Errorf("getAtom for path [unsuccessfulOutcome_t X2SetupFailure protocolIEs_t ProtocolIE_Container_elm Cause radioNetwork_t] failed, rc = 2" /*NO_SPACE_LEFT*/),
264 converter := NewX2SetupFailureResponseConverter(logger)
266 for _, tc := range testCases {
267 t.Run(tc.packedPdu, func(t *testing.T) {
270 _, err := fmt.Sscanf(tc.packedPdu, "%x", &payload)
272 t.Errorf("convert inputPayloadAsStr to payloadAsByte. Error: %v\n", err)
275 response, err := converter.UnpackX2SetupFailureResponseAndExtract(payload)
278 if tc.failure == nil {
279 t.Errorf("want: success, got: error: %v\n", err)
281 if strings.Compare(err.Error(), tc.failure.Error()) != 0 {
282 t.Errorf("want: %s, got: %s", tc.failure, err)
288 if tc.failure == nil {
289 t.Errorf("want: response=%s, got: empty response", tc.response)
292 nb := &entities.NodebInfo{}
293 nb.ConnectionStatus = entities.ConnectionStatus_CONNECTED_SETUP_FAILED
294 nb.SetupFailure = response
295 nb.FailureType = entities.Failure_X2_SETUP_FAILURE
296 respStr := fmt.Sprintf("%s %s", nb.ConnectionStatus, response)
297 if !strings.EqualFold(respStr, tc.response) {
298 t.Errorf("want: response=[%s], got: [%s]", tc.response, respStr)