org.opennms.smoketest.utils.SyslogUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of smoke-test Show documentation
Show all versions of smoke-test Show documentation
Smoke Test APIs for OpenNMS
The newest version!
/*
* Licensed to The OpenNMS Group, Inc (TOG) under one or more
* contributor license agreements. See the LICENSE.md file
* distributed with this work for additional information
* regarding copyright ownership.
*
* TOG licenses this file to You under the GNU Affero General
* Public License Version 3 (the "License") or (at your option)
* any later version. You may not use this file except in
* compliance with the License. You may obtain a copy of the
* License at:
*
* https://www.gnu.org/licenses/agpl-3.0.txt
*
* 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 org.opennms.smoketest.utils;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.StandardProtocolFamily;
import java.net.StandardSocketOptions;
import java.nio.ByteBuffer;
import java.nio.channels.DatagramChannel;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.atomic.AtomicInteger;
public class SyslogUtils {
/**
* Event UEI that is expected to be generated by Syslog messages sent using the {@link #sendMessage(InetSocketAddress, String, int)} call.
*/
public static final String SYSLOG_MESSAGE_UEI = "uei.opennms.org/vendor/cisco/syslog/SEC-6-IPACCESSLOGP/aclDeniedIPTraffic";
private static final AtomicInteger ORDINAL = new AtomicInteger();
/**
* Use a {@link DatagramChannel} to send a number of syslog messages to the Minion host.
*
* @param host Hostname to inject into the syslog message
* @param eventCount Number of messages to send
*/
public static void sendMessage(InetSocketAddress syslogAddr, final String host, final int eventCount) {
List randomNumbers = new ArrayList<>();
for (int i = 0; i < eventCount; i++) {
int eventNum = Double.valueOf(Math.random() * 10000).intValue();
randomNumbers.add(eventNum);
}
String message = "<190>Mar 11 08:35:17 " + host + " 30128311: Mar 11 08:35:16.844 CST: %SEC-6-IPACCESSLOGP: list in110 denied tcp 192.168.10.100(63923) -> 192.168.11.128(1521), " + ORDINAL.getAndIncrement() + " packet\n";
Set sendSizes = new HashSet<>();
// Test by sending over an IPv4 NIO channel
try (final DatagramChannel channel = DatagramChannel.open(StandardProtocolFamily.INET)) {
// Set the socket send buffer to the maximum value allowed by the kernel
channel.setOption(StandardSocketOptions.SO_SNDBUF, Integer.MAX_VALUE);
channel.connect(syslogAddr);
final ByteBuffer buffer = ByteBuffer.allocate(4096);
buffer.clear();
for (int i = 0; i < eventCount; i++) {
buffer.put(message.getBytes());
buffer.flip();
final int sent = channel.send(buffer, syslogAddr);
sendSizes.add(sent);
buffer.clear();
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}