12:00:22.833 Running procedure: 8.14.2.4
12:00:22.838 This procedure is enabled because the following options:
12:00:22.838 - supports.binaryInputChangeEvents == true
12:00:22.839 step: 1
12:00:22.839 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:00:22.839 - g2v0, All Objects
12:00:22.840 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:00:22.840 g2v0, All Objects
12:00:22.840 --T-> fir: 1 fin: 1 seq: 0
12:00:22.840 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:00:22.841 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:00:22.841 C0 C1 01 02 00 06 95 76
12:00:22.842 steps: 2 to 3
12:00:22.842 - Read a single fragment response w/ sequence(0x01)
12:00:22.842 - If the response is not Null, verify that the device requests an application layer confirmation.
12:00:22.843 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:00:22.843 C0 C1 81 90 00 73 EE
12:00:22.843 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:00:22.843 <-T-- fir: 1 fin: 1 seq: 0
12:00:22.844 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01 IIN(DeviceRestart, NeedTime)
12:00:22.844 step: 4
12:00:22.844 - Generate several Binary Input Change Events
12:00:22.845 Updated BI 1024: value=true, flags=81, timestamp=DNPTime(1586534422844)
12:00:22.845 Updated BI 65535: value=true, flags=81, timestamp=DNPTime(1586534422845)
12:00:22.846 Updated BI 41: value=true, flags=81, timestamp=DNPTime(1586534422845)
12:00:22.846 step: 5
12:00:22.846 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:00:22.846 - g2v0, 2-Byte Count, count: 1
12:00:22.847 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:00:22.847 g2v0, 2-Byte Count, count: 1
12:00:22.848 --T-> fir: 1 fin: 1 seq: 0
12:00:22.848 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 13 dest: 1024 src: 1
12:00:22.848 --P-> 05 64 0D C4 00 04 01 00 13 E1
12:00:22.848 C0 C2 01 02 00 08 01 00 5F 6E
12:00:22.850 steps: 6 to 10
12:00:22.850 - Read a single fragment response w/ sequence(0x02)
12:00:22.850 - Verify the device responds with the first Binary Input event
12:00:22.850 - If the variation contains timestamps, verify that they are reasonable according to the resolution specified in the Device Profile
12:00:22.850 - Verify that an application layer confirmation is requested.
12:00:22.850 - Verify that the response contains only the following variations: List(g2v1, g2v2, g2v3)
12:00:22.850 - Verify that the data is reported using 8 bit indexing (qualifier 0x17) or 16 bit indexing (qualifier 0x28).
12:00:22.850 - Verify that flag behavior complies with Section 2, Note #5.
12:00:22.851 <-P-- 05 64 12 44 01 00 00 04 7A 6A
12:00:22.851 C1 E2 81 92 00 02 01 28 01 00 00 04 81 E3 23
12:00:22.851 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 18 dest: 1 src: 1024
12:00:22.851 <-T-- fir: 1 fin: 1 seq: 1
12:00:22.852 <-A-- Response(0x81) fir: 1 fin: 1 con: 1 uns: 0 seq: 0x02 IIN(DeviceRestart, NeedTime, Class1Events)
12:00:22.852 g2v1, 2-Byte Count and Index, count: 1
12:00:22.852 [1024] - flags: 0x81
12:00:22.852 --A-> Confirm(0x00) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:00:22.852 --T-> fir: 1 fin: 1 seq: 0
12:00:22.853 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 8 dest: 1024 src: 1
12:00:22.853 --P-> 05 64 08 C4 00 04 01 00 9A 19
12:00:22.853 C0 C2 00 D6 8D
12:00:22.855 step: 11
12:00:22.855 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:22.855 - g2v0, 2-Byte Count, count: 2
12:00:22.855 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:22.855 g2v0, 2-Byte Count, count: 2
12:00:22.855 --T-> fir: 1 fin: 1 seq: 0
12:00:22.856 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 13 dest: 1024 src: 1
12:00:22.856 --P-> 05 64 0D C4 00 04 01 00 13 E1
12:00:22.856 C0 C3 01 02 00 08 02 00 96 81
12:00:22.859 steps: 12 to 13
12:00:22.859 - Read a single fragment response w/ sequence(0x03)
12:00:22.859 - Verify the device responds with the rest of Binary Input events
12:00:22.859 - If the variation contains timestamps, verify that they are reasonable according to the resolution specified in the Device Profile
12:00:22.859 - Verify that an application layer confirmation is requested.
12:00:22.859 - Verify that the response contains only the following variations: List(g2v1, g2v2, g2v3)
12:00:22.859 - Verify that the data is reported using 8 bit indexing (qualifier 0x17) or 16 bit indexing (qualifier 0x28).
12:00:22.859 - Verify that flag behavior complies with Section 2, Note #5.
12:00:22.859 <-P-- 05 64 15 44 01 00 00 04 44 B4
12:00:22.859 C2 E3 81 90 00 02 01 28 02 00 FF FF 81 29 00 81 94 8C
12:00:22.859 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 21 dest: 1 src: 1024
12:00:22.860 <-T-- fir: 1 fin: 1 seq: 2
12:00:22.861 <-A-- Response(0x81) fir: 1 fin: 1 con: 1 uns: 0 seq: 0x03 IIN(DeviceRestart, NeedTime)
12:00:22.861 g2v1, 2-Byte Count and Index, count: 2
12:00:22.861 [65535] - flags: 0x81
12:00:22.861 [41] - flags: 0x81
12:00:22.861 --A-> Confirm(0x00) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:22.861 --T-> fir: 1 fin: 1 seq: 0
12:00:22.862 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 8 dest: 1024 src: 1
12:00:22.862 --P-> 05 64 08 C4 00 04 01 00 9A 19
12:00:22.862 C0 C3 00 98 26
12:00:22.863 Passed procedure: 8.14.2.4