From 30488f1922f789c5b8e18934456968aa354c9671 Mon Sep 17 00:00:00 2001 From: Piotr Jaszczyk Date: Mon, 17 Dec 2018 13:22:52 +0100 Subject: Metric: Message latency Defined as a difference between now and vesHeader.lastEpochTime. Change-Id: I4aa97e8efc13cb0039fde38b4fd2aa6411c7b89a Issue-ID: DCAEGEN2-1036 Signed-off-by: Piotr Jaszczyk --- .../org/onap/dcae/collectors/veshv/utils/time.kt | 37 ++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 sources/hv-collector-utils/src/main/kotlin/org/onap/dcae/collectors/veshv/utils/time.kt (limited to 'sources/hv-collector-utils/src/main/kotlin') diff --git a/sources/hv-collector-utils/src/main/kotlin/org/onap/dcae/collectors/veshv/utils/time.kt b/sources/hv-collector-utils/src/main/kotlin/org/onap/dcae/collectors/veshv/utils/time.kt new file mode 100644 index 00000000..c07da670 --- /dev/null +++ b/sources/hv-collector-utils/src/main/kotlin/org/onap/dcae/collectors/veshv/utils/time.kt @@ -0,0 +1,37 @@ +/* + * ============LICENSE_START======================================================= + * dcaegen2-collectors-veshv + * ================================================================================ + * Copyright (C) 2018 NOKIA + * ================================================================================ + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ============LICENSE_END========================================================= + */ +package org.onap.dcae.collectors.veshv.utils + +import java.time.Instant + +/** + * @author Piotr Jaszczyk + * @since December 2018 + */ +object TimeUtils { + fun epochMicroToInstant(epochMicroseconds: Long): Instant { + val seconds = epochMicroseconds / MICROSECONDS_IN_SECOND + val nanos = (epochMicroseconds - seconds * MICROSECONDS_IN_SECOND) * NANOSECONDS_IN_MICROSECOND + return Instant.ofEpochSecond(seconds, nanos) + } + + private const val MICROSECONDS_IN_SECOND = 1_000_000L + private const val NANOSECONDS_IN_MICROSECOND = 1_000L +} -- cgit 1.2.3-korg