File: SOPClassExtendedNegotiation.cpp

package info (click to toggle)
odil 0.13.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,476 kB
  • sloc: cpp: 55,982; python: 3,947; javascript: 460; xml: 182; makefile: 99; sh: 36
file content (71 lines) | stat: -rw-r--r-- 2,035 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#define BOOST_TEST_MODULE SOPClassExtendedNegotiation
#include <boost/test/unit_test.hpp>

#include <sstream>
#include <string>

#include "odil/Exception.h"
#include "odil/pdu/SOPClassExtendedNegotiation.h"

BOOST_AUTO_TEST_CASE(Constructor)
{
    odil::pdu::SOPClassExtendedNegotiation const item(
        "sop_class", {'\x01', '\x02', '\x03', '\x04'});
    BOOST_REQUIRE_EQUAL(item.get_sop_class_uid(), "sop_class");
    BOOST_REQUIRE(
        item.get_service_class_application_information() ==
            std::vector<uint8_t>({'\x01', '\x02', '\x03', '\x04'}));
}

BOOST_AUTO_TEST_CASE(FromStream)
{
    std::string const data(
        "\x56\x00\x00\x0f"
        "\x00\x09" "sop_class"
        "\x01\x02\x03\x04",
        19
    );
    std::istringstream stream(data);

    odil::pdu::SOPClassExtendedNegotiation const item(stream);

    BOOST_REQUIRE_EQUAL(item.get_sop_class_uid(), "sop_class");
    BOOST_REQUIRE(
        item.get_service_class_application_information() ==
            std::vector<uint8_t>({'\x01', '\x02', '\x03', '\x04'}));
}

BOOST_AUTO_TEST_CASE(SOPClassUID)
{
    odil::pdu::SOPClassExtendedNegotiation item(
        "sop_class", {'\x01', '\x02', '\x03', '\x04'});
    item.set_sop_class_uid("bar");
    BOOST_REQUIRE_EQUAL(item.get_sop_class_uid(), "bar");
}

BOOST_AUTO_TEST_CASE(ServiceClassApplicationInformation)
{
    odil::pdu::SOPClassExtendedNegotiation item(
        "sop_class", {'\x01', '\x02', '\x03', '\x04'});
    item.set_service_class_application_information({'\x05', '\x06'});
    BOOST_REQUIRE(
        item.get_service_class_application_information() ==
            std::vector<uint8_t>({'\x05', '\x06'}));
}

BOOST_AUTO_TEST_CASE(Write)
{
    odil::pdu::SOPClassExtendedNegotiation const item(
        "sop_class", {'\x01', '\x02', '\x03', '\x04'});
    std::ostringstream data;
    data << item;

    std::string const expected(
        "\x56\x00\x00\x0f"
        "\x00\x09" "sop_class"
        "\x01\x02\x03\x04",
        19
    );

    BOOST_REQUIRE_EQUAL(data.str(), expected);
}