12:02:04.479 Running procedure: 8.17.2.5
12:02:04.483 This procedure is enabled because the following options:
12:02:04.483 - supports.counterChangeEvents == true
12:02:04.483 step: 1
12:02:04.483 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:02:04.483 - g22v0, All Objects
12:02:04.484 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01
12:02:04.484 g22v0, All Objects
12:02:04.484 --T-> fir: 1 fin: 1 seq: 0
12:02:04.485 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:02:04.485 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:02:04.485 C0 C1 01 16 00 06 8C C6
12:02:04.486 steps: 2 to 3
12:02:04.486 - Read a single fragment response w/ sequence(0x01)
12:02:04.486 - If the response is not Null, verify that the device requests an application layer confirmation.
12:02:04.487 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:02:04.487 C0 C1 81 90 00 73 EE
12:02:04.487 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:02:04.487 <-T-- fir: 1 fin: 1 seq: 0
12:02:04.487 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x01 IIN(DeviceRestart, NeedTime)
12:02:04.488 step: 4
12:02:04.488 - Generate binary counter input data
12:02:04.488 Updated Counter 65535: value=2, flags=1, timestamp=DNPTime(1586534524488)
12:02:04.489 Updated Counter 0: value=2, flags=1, timestamp=DNPTime(1586534524488)
12:02:04.489 Updated Counter 41: value=2, flags=1, timestamp=DNPTime(1586534524489)
12:02:04.490 step: 5
12:02:04.490 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:02:04.490 - g22v0, All Objects
12:02:04.490 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x02
12:02:04.490 g22v0, All Objects
12:02:04.491 --T-> fir: 1 fin: 1 seq: 0
12:02:04.491 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:02:04.491 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:02:04.491 C0 C2 01 16 00 06 86 A3
12:02:04.492 steps: 6 to 7
12:02:04.492 - Read a single fragment response w/ sequence(0x02)
12:02:04.492 - Verify the device responds with all generated counter events
12:02:04.492 - Verify that an application layer confirmation is requested.
12:02:04.493 <-P-- 05 64 24 44 01 00 00 04 E0 88
12:02:04.493 C1 E2 81 90 00 16 01 28 03 00 FF FF 01 02 00 00 16 C6
12:02:04.493 00 00 00 01 02 00 00 00 29 00 01 02 00 00 00 DA 21
12:02:04.494 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 36 dest: 1 src: 1024
12:02:04.494 <-T-- fir: 1 fin: 1 seq: 1
12:02:04.495 <-A-- Response(0x81) fir: 1 fin: 1 con: 1 uns: 0 seq: 0x02 IIN(DeviceRestart, NeedTime)
12:02:04.495 g22v1, 2-Byte Count and Index, count: 3
12:02:04.495 [65535] - flags: 0x01 count: 2
12:02:04.495 [0] - flags: 0x01 count: 2
12:02:04.495 [41] - flags: 0x01 count: 2
12:02:04.496 step: 8
12:02:04.496 - Do not issue an application layer confirm to the device.
12:02:04.496 step: 9
12:02:04.496 - Wait for 2000 milliseconds
12:02:06.497 step: 10
12:02:06.497 - Expect no response.
12:02:08.698 step: 11
12:02:08.698 - Generate binary counter input data
12:02:08.699 Updated Counter 41: value=3, flags=1, timestamp=DNPTime(1586534528698)
12:02:08.699 Updated Counter 65535: value=3, flags=1, timestamp=DNPTime(1586534528699)
12:02:08.699 Updated Counter 1024: value=2, flags=1, timestamp=DNPTime(1586534528699)
12:02:08.700 step: 12
12:02:08.700 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:02:08.700 - g22v0, All Objects
12:02:08.701 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:02:08.701 g22v0, All Objects
12:02:08.701 --T-> fir: 1 fin: 1 seq: 0
12:02:08.701 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:02:08.702 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:02:08.702 C0 C3 01 16 00 06 80 80
12:02:08.704 steps: 13 to 18
12:02:08.704 - Read a single fragment response w/ sequence(0x03)
12:02:08.704 - Verify the device responds with values representing the current state of the counters
12:02:08.704 - Optionally, the device can report the previous state followed by the current state
12:02:08.704 - Verify that an application layer confirmation is requested.
12:02:08.704 - Verify that the response contains only Object 22, Variation 1 and/or 2.
12:02:08.704 - Verify that the data is reported using 8 bit indexing (qualifier 0x17) or 16 bit indexing (qualifier 0x28).
12:02:08.704 - Verify that flag behavior complies with Section 2, Note #5.
12:02:08.706 <-P-- 05 64 39 44 01 00 00 04 74 92
12:02:08.706 C2 E3 81 90 00 16 01 28 06 00 FF FF 01 02 00 00 C0 30
12:02:08.706 00 00 00 01 02 00 00 00 29 00 01 02 00 00 00 29 D0 D9
12:02:08.706 00 01 03 00 00 00 FF FF 01 03 00 00 00 00 04 01 07 68
12:02:08.706 02 00 00 00 56 37
12:02:08.706 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 57 dest: 1 src: 1024
12:02:08.706 <-T-- fir: 1 fin: 1 seq: 2
12:02:08.709 <-A-- Response(0x81) fir: 1 fin: 1 con: 1 uns: 0 seq: 0x03 IIN(DeviceRestart, NeedTime)
12:02:08.709 g22v1, 2-Byte Count and Index, count: 6
12:02:08.709 [65535] - flags: 0x01 count: 2
12:02:08.709 [0] - flags: 0x01 count: 2
12:02:08.709 [41] - flags: 0x01 count: 2
12:02:08.709 [41] - flags: 0x01 count: 3
12:02:08.709 [65535] - flags: 0x01 count: 3
12:02:08.709 [1024] - flags: 0x01 count: 2
12:02:08.709 --A-> Confirm(0x00) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x03
12:02:08.709 --T-> fir: 1 fin: 1 seq: 0
12:02:08.709 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 8 dest: 1024 src: 1
12:02:08.710 --P-> 05 64 08 C4 00 04 01 00 9A 19
12:02:08.710 C0 C3 00 98 26
12:02:08.712 step: 19
12:02:08.712 - Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04
12:02:08.712 - g22v0, All Objects
12:02:08.713 --A-> Read(0x01) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04
12:02:08.713 g22v0, All Objects
12:02:08.713 --T-> fir: 1 fin: 1 seq: 0
12:02:08.713 --L-> master: 1 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0xC4 length: 11 dest: 1024 src: 1
12:02:08.714 --P-> 05 64 0B C4 00 04 01 00 CA 8A
12:02:08.714 C0 C4 01 16 00 06 92 69
12:02:08.715 step: 20
12:02:08.715 - Read a single fragment response w/ sequence(0x04)
12:02:08.715 - Verify that the response is empty
12:02:08.715 <-P-- 05 64 0A 44 01 00 00 04 67 88
12:02:08.715 C3 C4 81 90 00 BA 95
12:02:08.715 <-L-- master: 0 pri: 1 fcb: 0 fcv: 0 func: UNCONFIRMED_USER_DATA(0x04) 0x44 length: 10 dest: 1 src: 1024
12:02:08.716 <-T-- fir: 1 fin: 1 seq: 3
12:02:08.716 <-A-- Response(0x81) fir: 1 fin: 1 con: 0 uns: 0 seq: 0x04 IIN(DeviceRestart, NeedTime)
12:02:08.716 Passed procedure: 8.17.2.5