All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.simulator.tests.network.PayloadUtils Maven / Gradle / Ivy

/*
 * Copyright (c) 2008-2017, Hazelcast, Inc. All Rights Reserved.
 *
 * 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.
 */
package com.hazelcast.simulator.tests.network;

import com.hazelcast.logging.ILogger;
import com.hazelcast.logging.Logger;

import static java.lang.String.format;

public final class PayloadUtils {

    public static final boolean COMPRESS_HEX_OUTPUT = true;
    private static final ILogger LOGGER = Logger.getLogger(PayloadUtils.class);

    private PayloadUtils() {
    }

    public static String toHexString(byte[] bytes) {
        if (bytes.length == 0) {
            return "";
        }

        StringBuilder sb = new StringBuilder();

        byte prev = bytes[0];
        int count = 1;
        for (int i = 1; i < bytes.length; i++) {
            byte current = bytes[i];
            if (COMPRESS_HEX_OUTPUT && prev == current) {
                count++;
            } else {
                if (count == 1) {
                    sb.append(format("%02X", prev));
                } else {
                    sb.append(format("%02X(%d)", prev, count));
                }
                count = 1;
            }

            prev = current;
        }

        if (count == 1) {
            sb.append(format("%02X", prev));
        } else {
            sb.append(format("%02X(%d)", prev, count));
        }

        return sb.toString();
    }

    public static byte[] makePayload(int payloadSize) {
        if (payloadSize <= 0) {
            return null;
        }

        byte[] payload = new byte[payloadSize];

        // put a well known head and tail on the payload; for debugging.
        if (payload.length >= 6 + 8) {
            addHeadTailMarkers(payload);
        }

        return payload;
    }

    public static void addHeadTailMarkers(byte[] payload) {
        payload[0] = 0xA;
        payload[1] = 0xB;
        payload[2] = 0xC;

        int length = payload.length;
        payload[length - 3] = 0xC;
        payload[length - 2] = 0xB;
        payload[length - 1] = 0xA;
    }


    public static void addSequenceId(byte[] payload, long sequenceId) {
        writeLong(payload, 3, sequenceId);
        // we write the sequence at the end.
        writeLong(payload, payload.length - (8 + 3), sequenceId);
    }

    public static void checkHeadTailMarkers(byte[] payload) {
        check(payload, 0, 0XA);
        check(payload, 1, 0XB);
        check(payload, 2, 0XC);

        int length = payload.length;
        check(payload, length - 3, 0XC);
        check(payload, length - 2, 0XB);
        check(payload, length - 1, 0XA);
    }

    public static void check(byte[] payload, int index, int value) {
        byte found = payload[index];
        if (found != value) {
            throw new IllegalStateException(format(
                    "invalid byte at index:%d, found:%02X, expected:%02X payload=", index, found, value)
                    + toHexString(payload));
        }
    }

    public static long readLong(byte[] bytes, int offset) {
        long result = 0;
        for (int i = 0; i < 8; i++) {
            result <<= 8;
            result |= (bytes[i + offset] & 0xFF);
        }
        return result;
    }

    public static void writeLong(byte[] bytes, int offset, long value) {
        for (int i = 7; i >= 0; i--) {
            bytes[i + offset] = (byte) (value & 0xFF);
            value >>= 8;
        }
    }

    public static void main(String[] args) {
        byte[] bytes = new byte[50];

        long sequenceId = Long.MAX_VALUE;

        addHeadTailMarkers(bytes);
        addSequenceId(bytes, sequenceId);
        writeLong(bytes, 3, sequenceId);
        writeLong(bytes, bytes.length - (8 + 3), sequenceId);
        LOGGER.info(toHexString(bytes));
        checkHeadTailMarkers(bytes);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy