blob: 1ce8f76a5992f354494f24a197f8142f39a5db51 [file] [log] [blame]
= 5G system TS29502 Nsmf Protocol Modules for TTCN-3 Toolset with TITAN, Description
:author: Gábor Szalai
:toc: left
== About This Document
This is the description for the 5G system TS29502 Nsmf protocol module. The 5G system TS29502 Nsmf protocol modules are developed for the TTCN-3 Toolset with Titan.
== Functionality
The 5G system TS29502 Nsmf protocol module implements the object structures of the 3GPP TS 29502 v15.1.0<<_5, [5]>> in a formalized way, using the standard specification language TTCN-3. This allows defining of test data (templates) in the TTCN-3 language and correctly encoding/decoding messages when executing test suites using the Titan TTCN-3 test environment.
The 5G system TS29502 Nsmf protocol module uses Titans JSON encoding <<_3, [3]>> and hence is usable with the Titan test toolset only.
=== System Requirements
Protocol modules are a set of TTCN-3 source code files that can be used as part of TTCN-3 test suites only. Hence, protocol modules alone do not put specific requirements on the system used. However, in order to compile and execute a TTCN-3 test suite using the set of protocol modules the following system requirements must be satisfied:
* Titan TTCN-3 Test Executor version CRL 113 200/6 R5A (6.5.pl0) or higher installed. For Installation Guide see <<_2, [2]>>. Please note: This version of the test port is not compatible with Titan releases earlier than CRL 113 200/6 R5A.
=== Installation
The set of protocol modules can be used in developing TTCN-3 test suites using any text editor. Since the 5G system TS29502 Nsmf protocol is used as a part of a TTCN-3 test suite, this requires TTCN-3 Test Executor be installed before the module can be compiled and executed together with other parts of the test suite. For more details on the installation of TTCN-3 Test Executor see the relevant section of <<_2, [2]>>.
== Interface description
=== Encoding/decoding and other related functions
This product also contains encoding/decoding functions, which assure correct encoding of messages when sent from Titan and correct decoding of messages when received by Titan.
==== Implemented encoding and decoding functions
[source]
----
Name Type of formal parameters Type of return value
f_enc_PduSessionCreateError(in PduSessionCreateError pdu) return octetstring
f_dec_PduSessionCreateError(in octetstring stream, out PduSessionCreateError pdu) return integer
f_enc_HsmfUpdateError(in HsmfUpdateError pdu) return octetstring
f_dec_HsmfUpdateError(in octetstring stream, out HsmfUpdateError pdu) return integer
f_enc_VsmfUpdateError(in VsmfUpdateError pdu) return octetstring
f_dec_VsmfUpdateError(in octetstring stream, out VsmfUpdateError pdu) return integer
f_enc_SmContextCreatedData(in SmContextCreatedData pdu) return octetstring
f_dec_SmContextCreatedData(in octetstring stream, out SmContextCreatedData pdu) return integer
f_enc_SmContextCreateError(in SmContextCreateError pdu) return octetstring
f_dec_SmContextCreateError(in octetstring stream, out SmContextCreateError pdu) return integer
f_enc_SmContextStatusNotification(in SmContextStatusNotification pdu) return octetstring
f_dec_SmContextStatusNotification(in octetstring stream, out SmContextStatusNotification pdu) return integer
f_enc_SmContextRetrieveData(in SmContextRetrieveData pdu) return octetstring
f_dec_SmContextRetrieveData(in octetstring stream, out SmContextRetrieveData pdu) return integer
f_enc_SmContextRetrievedData(in SmContextRetrievedData pdu) return octetstring
f_dec_SmContextRetrievedData(in octetstring stream, out SmContextRetrievedData pdu) return integer
f_enc_SmContextUpdateData(in SmContextUpdateData pdu) return octetstring
f_dec_SmContextUpdateData(in octetstring stream, out SmContextUpdateData pdu) return integer
f_enc_SmContextUpdatedData(in SmContextUpdatedData pdu) return octetstring
f_dec_SmContextUpdatedData(in octetstring stream, out SmContextUpdatedData pdu) return integer
f_enc_SmContextUpdateError(in SmContextUpdateError pdu) return octetstring
f_dec_SmContextUpdateError(in octetstring stream, out SmContextUpdateError pdu) return integer
f_enc_SmContextReleaseData(in SmContextReleaseData pdu) return octetstring
f_dec_SmContextReleaseData(in octetstring stream, out SmContextReleaseData pdu) return integer
f_enc_PduSessionCreateData(in PduSessionCreateData pdu) return octetstring
f_dec_PduSessionCreateData(in octetstring stream, out PduSessionCreateData pdu) return integer
f_enc_PduSessionCreatedData(in PduSessionCreatedData pdu) return octetstring
f_dec_PduSessionCreatedData(in octetstring stream, out PduSessionCreatedData pdu) return integer
f_enc_StatusNotification(in StatusNotification pdu) return octetstring
f_dec_StatusNotification(in octetstring stream, out StatusNotification pdu) return integer
f_enc_VsmfUpdateData(in VsmfUpdateData pdu) return octetstring
f_dec_VsmfUpdateData(in octetstring stream, out VsmfUpdateData pdu) return integer
f_enc_VsmfUpdatedData(in VsmfUpdatedData pdu) return octetstring
f_dec_VsmfUpdatedData(in octetstring stream, out VsmfUpdatedData pdu) return integer
f_enc_HsmfUpdateData(in HsmfUpdateData pdu) return octetstring
f_dec_HsmfUpdateData(in octetstring stream, out HsmfUpdateData pdu) return integer
f_enc_HsmfUpdatedData(in HsmfUpdatedData pdu) return octetstring
f_dec_HsmfUpdatedData(in octetstring stream, out HsmfUpdatedData pdu) return integer
f_enc_ReleaseData(in ReleaseData pdu) return octetstring
f_dec_ReleaseData(in octetstring stream, out ReleaseData pdu) return integer
----
== Usage
The protocol module provides abstract data types for JSON objects used by the services defined in the standard <<_5, [5]>>. The protocol module provides encoder and decoder functions for the JSON objects. The decoder validates the received JSON object based on the JSON schema as well. Only the validated JSON value is decoded.
== Terminology
=== Abbreviations
JSON:: JavaScript Object Notation
PDU:: Protocol Data Unit
TTCN-3:: Testing and Test Control Notation version 3
== References
[[_1]]
[1] ETSI ES 201 873-1 v4.4.1 (2012-04) +
The Testing and Test Control Notation version 3. Part 1: Core Language
[[_2]]
[2] 1/ 198 17-CRL 113 200/6 Uen +
Installation Guide for the TITAN TTCN-3 Test Executor
[[_3]]
[3] 2/198 17-CRL 113 200/6 Uen +
Programmer's Technical Reference for Titan TTCN-3 Test Executor
[[_4]]
[4] https://www.json.org
[[_5]]
[5] 3GPP TS 29502 v15.1.0+
5G System; Session Management Services; Stage 3