1 /*******************************************************************************
3 * Copyright (c) 2019 AT&T Intellectual Property.
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 *******************************************************************************/
23 "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities"
29 Test permutations of x2 setup response to protobuf enb
32 func TestUnpackX2SetupFailureResponseAndExtract(t *testing.T) {
33 logger, _ := logger.InitLogger(logger.InfoLevel)
35 var testCases = []struct {
41 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 > > ",
49 ProtocolIE_Container_elm
54 ProtocolIE_Container_elm
58 ProtocolIE_Container_elm
61 CriticalityDiagnostics
62 procedureCode_t = 0x21
63 triggeringMessage_t = 0x2
64 procedureCriticality_t = 0x2
65 iEsCriticalityDiagnostics_t:
66 CriticalityDiagnostics_IE_List_elm
71 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040"},
73 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 > > ",
81 ProtocolIE_Container_elm
86 ProtocolIE_Container_elm
89 CriticalityDiagnostics
90 procedureCode_t = 0x21
91 triggeringMessage_t = 0x2
92 procedureCriticality_t = 0x2
93 iEsCriticalityDiagnostics_t:
94 CriticalityDiagnostics_IE_List_elm
99 packedPdu: "400600140000020005400120001140087821a00000008040"},
101 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 > > ",
104 unsuccessfulOutcome_t
105 procedureCode_t = 0x6
109 ProtocolIE_Container_elm
114 ProtocolIE_Container_elm
117 CriticalityDiagnostics
118 triggeringMessage_t = 0x2
119 procedureCriticality_t = 0x2
120 iEsCriticalityDiagnostics_t:
121 CriticalityDiagnostics_IE_List_elm
126 packedPdu: "400600130000020005400144001140073a800000008040"},
129 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 > > ",
132 unsuccessfulOutcome_t
133 procedureCode_t = 0x6
137 ProtocolIE_Container_elm
142 ProtocolIE_Container_elm
145 CriticalityDiagnostics
146 procedureCriticality_t = 0x2
147 iEsCriticalityDiagnostics_t:
148 CriticalityDiagnostics_IE_List_elm
153 packedPdu: "400600120000020005400168001140061a0000008040"},
156 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 > > ",
159 unsuccessfulOutcome_t
160 procedureCode_t = 0x6
164 ProtocolIE_Container_elm
169 ProtocolIE_Container_elm
172 CriticalityDiagnostics
173 iEsCriticalityDiagnostics_t:
174 CriticalityDiagnostics_IE_List_elm
178 CriticalityDiagnostics_IE_List_elm
179 iECriticality_t = 0x2
183 packedPdu: "4006001500000200054001680011400908010000804800ff00"},
187 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED criticality_diagnostics:<procedure_code:33 > ",
190 unsuccessfulOutcome_t
191 procedureCode_t = 0x6
195 ProtocolIE_Container_elm
200 ProtocolIE_Container_elm
203 CriticalityDiagnostics
204 procedureCode_t = 0x21
206 packedPdu: "4006000e0000020005400168001140024021"},
209 response: "CONNECTED_SETUP_FAILED miscellaneous_cause:UNSPECIFIED ",
212 unsuccessfulOutcome_t
213 procedureCode_t = 0x6
217 ProtocolIE_Container_elm
223 packedPdu: "400600080000010005400168"},
225 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 > > ",
228 unsuccessfulOutcome_t
229 procedureCode_t = 0x6
233 ProtocolIE_Container_elm
238 ProtocolIE_Container_elm
242 ProtocolIE_Container_elm
245 CriticalityDiagnostics
246 procedureCode_t = 0x21
247 triggeringMessage_t = 0x2
248 procedureCriticality_t = 0x2
249 iEsCriticalityDiagnostics_t:
250 CriticalityDiagnostics_IE_List_elm
255 packedPdu: "4006001a0000030005400200000016400100001140087821a00000008040",
256 //failure: fmt.Errorf("getAtom for path [unsuccessfulOutcome_t X2SetupFailure protocolIEs_t ProtocolIE_Container_elm Cause radioNetwork_t] failed, rc = 2" /*NO_SPACE_LEFT*/),
260 converter := NewX2SetupFailureResponseConverter(logger)
262 for _, tc := range testCases {
263 t.Run(tc.packedPdu, func(t *testing.T) {
266 _, err := fmt.Sscanf(tc.packedPdu, "%x", &payload)
268 t.Errorf("convert inputPayloadAsStr to payloadAsByte. Error: %v\n", err)
271 response, err := converter.UnpackX2SetupFailureResponseAndExtract(payload)
274 if tc.failure == nil {
275 t.Errorf("want: success, got: error: %v\n", err)
277 if strings.Compare(err.Error(), tc.failure.Error()) != 0 {
278 t.Errorf("want: %s, got: %s", tc.failure, err)
284 if tc.failure == nil {
285 t.Errorf("want: response=%s, got: empty response", tc.response)
288 nb := &entities.NodebInfo{}
289 nb.ConnectionStatus = entities.ConnectionStatus_CONNECTED_SETUP_FAILED
290 nb.SetupFailure = response
291 nb.FailureType = entities.Failure_X2_SETUP_FAILURE
292 respStr := fmt.Sprintf("%s %s", nb.ConnectionStatus, response)
293 if !strings.EqualFold(respStr, tc.response) {
294 t.Errorf("want: response=[%s], got: [%s]", tc.response, respStr)