12:00:21.630 Running procedure: 8.14.2.2
12:00:21.637 This procedure is enabled because the following options:
12:00:21.637 - supports.binaryInputChangeEvents == true
12:00:21.638 step: 1
12:00:21.638 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:00:21.638 - g2v0, All Objects
12:00:21.639 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:00:21.639 g2v0, All Objects
12:00:21.640 --T-> fir: 1 fin: 1 seq: 0
12:00:21.640 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:00:21.641 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:00:21.641 C0 C1 01 02 00 06 95 76
12:00:21.642 step: 2
12:00:21.642 - Read a single fragment response w/ sequence(0x01)
12:00:21.642 - If the response is not Null, verify that the device requests an application layer confirmation.
12:00:21.643 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:00:21.643 C0 C1 81 90 00 73 EE
12:00:21.643 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:00:21.644 <-T-- fir: 1 fin: 1 seq: 0
12:00:21.644 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01 IIN(DeviceRestart, NeedTime)
12:00:21.645 step: 3
12:00:21.645 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:00:21.645 - g2v0, All Objects
12:00:21.646 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:00:21.646 g2v0, All Objects
12:00:21.647 --T-> fir: 1 fin: 1 seq: 0
12:00:21.647 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:00:21.648 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:00:21.648 C0 C2 01 02 00 06 9F 13
12:00:21.648 step: 4
12:00:21.648 - Read a single fragment response w/ sequence(0x02)
12:00:21.648 - Verify that the response is empty
12:00:21.649 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:00:21.649 C1 C2 81 90 00 34 C7
12:00:21.649 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:00:21.649 <-T-- fir: 1 fin: 1 seq: 1
12:00:21.649 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02 IIN(DeviceRestart, NeedTime)
12:00:21.650 step: 5
12:00:21.650 - Generate several Binary Input Change Events
12:00:21.651 Updated BI 41: value=true, flags=81, timestamp=DNPTime(1586534421650)
12:00:21.651 Updated BI 1024: value=true, flags=81, timestamp=DNPTime(1586534421651)
12:00:21.651 Updated BI 41: value=false, flags=1, timestamp=DNPTime(1586534421651)
12:00:21.652 step: 6
12:00:21.652 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:21.652 - g2v0, All Objects
12:00:21.653 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:21.653 g2v0, All Objects
12:00:21.653 --T-> fir: 1 fin: 1 seq: 0
12:00:21.653 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:00:21.654 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:00:21.654 C0 C3 01 02 00 06 99 30
12:00:21.656 steps: 7 to 11
12:00:21.656 - Read a single fragment response w/ sequence(0x03)
12:00:21.656 - Verify the device responds with all generated Binary Input events
12:00:21.656 - If the variation contains timestamps, verify that they are reasonable according to the resolution specified in the Device Profile
12:00:21.656 - Verify that an application layer confirmation is requested.
12:00:21.656 - Verify that the response contains only the following variations: List(g2v1, g2v2, g2v3)
12:00:21.656 - Verify that the data is reported using 8 bit indexing (qualifier 0x17) or 16 bit indexing (qualifier 0x28).
12:00:21.656 - Verify that flag behavior complies with Section 2, Note #5.
12:00:21.657 <-P-- 05 64 18 44 01 00 00 04 11 D6
12:00:21.657 C2 E3 81 90 00 02 01 28 03 00 29 00 81 00 04 81 03 6A
12:00:21.657 29 00 01 52 FD
12:00:21.657 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 24 dest: 1 src: 1024
12:00:21.658 <-T-- fir: 1 fin: 1 seq: 2
12:00:21.659 <-A-- Response(0x81) fir: 1 fin: 1 con: 1 uns: 0 seq: 0x03 IIN(DeviceRestart, NeedTime)
12:00:21.659 g2v1, 2-Byte Count and Index, count: 3
12:00:21.659 [41] - flags: 0x81
12:00:21.659 [1024] - flags: 0x81
12:00:21.659 [41] - flags: 0x01
12:00:21.659 --A-> Confirm(0x00) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:00:21.660 --T-> fir: 1 fin: 1 seq: 0
12:00:21.660 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 8 dest: 1024 src: 1
12:00:21.660 --P-> 05 64 08 C4 00 04 01 00 9A 19
12:00:21.660 C0 C3 00 98 26
12:00:21.663 step: 12
12:00:21.663 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04
12:00:21.663 - g2v0, All Objects
12:00:21.664 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04
12:00:21.664 g2v0, All Objects
12:00:21.665 --T-> fir: 1 fin: 1 seq: 0
12:00:21.665 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:00:21.666 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:00:21.666 C0 C4 01 02 00 06 8B D9
12:00:21.667 step: 13
12:00:21.667 - Read a single fragment response w/ sequence(0x04)
12:00:21.667 - Verify that the response is empty
12:00:21.667 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:00:21.667 C3 C4 81 90 00 BA 95
12:00:21.668 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:00:21.668 <-T-- fir: 1 fin: 1 seq: 3
12:00:21.668 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04 IIN(DeviceRestart, NeedTime)
12:00:21.669 Passed procedure: 8.14.2.2