- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我制作了一个模块,可以让我使用 Java SDK 与 splunk 集成。我们通过 Maven 使用 1.2.1.0。
我的模块似乎运行良好。但是,我想围绕它进行 junit 单元测试。我创建了试图恢复最近事件的测试,但除非我睡大觉,否则我永远不会得到我刚刚输入的内容,通常是它之前的事件。我还通过索引上的事件计数(我使用测试索引)尝试了它,但也没有正确更新。有什么好的方法可以执行我可以实际验证和断言的 JUnit 测试吗?
我在这个应用程序中使用了 spring,所以我有一个单例服务来做这个日志记录。这是服务实现:
/*
* Copyright (c) 2015 POS Portal, Inc.
* 180 Promenade Circle, Ste 215, Sacramento, CA 95834, USA
* All rights reserved.
*
* This software is the confidential and proprietary information
* of POS Portal, Inc.
*
*/
package com.posportal.splunk.impl;
import java.util.Date;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.posportal.splunk.api.SplunkLog;
import com.posportal.splunk.enumeration.SplunkLoggingLevel;
import com.splunk.Receiver;
import com.splunk.Service;
import com.splunk.ServiceArgs;
/**
* Represents a splunk logging instance. This is a spring singleton for logging.
*
* We log to the index given, so it is acceptable to have a singleton on a per index basis.
*
* Splunk configuration including index name are injected via Spring.
* @author Michael Wenk
*
*/
public class SplunkLogImpl implements SplunkLog {
private static Logger log = LoggerFactory.getLogger(SplunkLogImpl.class);
private String host;
private String user;
private String password;
private String scheme;
private String indexName;
private int port;
private boolean disabled = false;
private Service splunksvc = null;
private Receiver receiver = null;
@Override
public void logMessage(String msg, SplunkLoggingLevel level) {
if (disabled) {
log.warn("Splunk system disabled. Splunk message would be: " + msg + " on level: " + level);
} else {
if (receiver == null) {
initService();
}
String formattedMessageData = formatMessage(msg, level);
receiver.log(indexName, formattedMessageData);
}
}
private String formatMessage(String msg, SplunkLoggingLevel level) {
String fmt = "timestamp=\"%s\",level=\"%s\",data=\"%s\"";
Date now = new Date();
return String.format(fmt, now.toString(), level.toString(), msg);
}
private void initService() {
ServiceArgs loginArgs = new ServiceArgs();
loginArgs.setUsername(user);
loginArgs.setPassword(password);
loginArgs.setHost(host);
loginArgs.setScheme(scheme);
loginArgs.setPort(port);
splunksvc = Service.connect(loginArgs);
receiver = splunksvc.getReceiver();
}
public void setHost(String host) {
this.host = host;
}
public void setUser(String user) {
this.user = user;
}
public void setPassword(String password) {
this.password = password;
}
public void setScheme(String scheme) {
this.scheme = scheme;
}
public void setIndexName(String indexName) {
this.indexName = indexName;
}
public void setPort(int port) {
this.port = port;
}
@Override
public void setDisabled(boolean disabled) {
this.disabled = disabled;
}
@Override
public boolean isDisabled() {
return disabled;
}
}
这是单元测试代码:
/*
* Copyright (c) 2015 POS Portal, Inc.
* 180 Promenade Circle, Ste 215, Sacramento, CA 95834, USA
* All rights reserved.
*
* This software is the confidential and proprietary information
* of POS Portal, Inc.
*
*/
package com.posportal.splunk.test;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import java.util.Map;
import javax.annotation.Resource;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import com.posportal.splunk.api.SplunkLog;
import com.posportal.splunk.enumeration.SplunkLoggingLevel;
import com.splunk.Job;
import com.splunk.JobArgs;
import com.splunk.JobArgs.ExecutionMode;
import com.splunk.Service;
import com.splunk.ServiceArgs;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:pos-splunk-test-ctx.xml")
public class SplunkTest {
//private static Logger log = LoggerFactory.getLogger(SplunkTest.class);
@Resource(name = "splunkLog")
private SplunkLog splunk;
@Resource(name = "splunkConfig")
private Map<String,String> splunkConfig;
@Test
public void testInitialMessage() throws InterruptedException
{
if (splunk.isDisabled())
{
String msg = "This is my test";
splunk.logMessage(msg, SplunkLoggingLevel.INFO);
}
else
{
int startCount = getEventCountFromIndex();
String msg = "This is my test";
assertNotNull(splunk);
splunk.logMessage(msg, SplunkLoggingLevel.INFO);
Service svc = getService();
assertNotNull(svc);
// Sleep for a while.
Thread.sleep(4000);
int finalCount = getEventCountFromIndex();
assertTrue(finalCount > startCount);
}
}
@Test
public void testDisabled() {
if (!splunk.isDisabled())
{
splunk.setDisabled(true);
splunk.logMessage("This is a disabled test", SplunkLoggingLevel.INFO);
// Can't assert unfortunately,
//FIXME see if I can assert using log4j itself.
}
}
private int getEventCountFromIndex() {
String searchString = "search index="+ splunkConfig.get("indexName");
JobArgs jargs = new JobArgs();
jargs.setExecutionMode(ExecutionMode.BLOCKING);
Service svc = getService();
Job j = svc.getJobs().create(searchString, jargs);
return j != null ? j.getEventCount() : -1;
}
@Test
public void testSecondMessage() throws InterruptedException
{
if (splunk.isDisabled())
{
String msg = "This is my second test";
splunk.logMessage(msg, SplunkLoggingLevel.INFO);
}
else
{
int startCount = getEventCountFromIndex();
String msg = "This is my second test";
assertNotNull(splunk);
splunk.logMessage(msg, SplunkLoggingLevel.INFO);
Service svc = getService();
assertNotNull(svc);
// Sleep for a while.
Thread.sleep(4000);
int finalCount = getEventCountFromIndex();
assertTrue(finalCount > startCount);
}
}
private Service getService() {
ServiceArgs loginArgs = new ServiceArgs();
loginArgs.setUsername(splunkConfig.get("user"));
loginArgs.setPassword(splunkConfig.get("password"));
loginArgs.setHost(splunkConfig.get("host"));
loginArgs.setScheme(splunkConfig.get("scheme"));
int port = Integer.parseInt(splunkConfig.get("port"));
loginArgs.setPort(port);
Service service = Service.connect(loginArgs);
return service;
}
}
如果你注意到那里的 sleep 。如果我不 sleep ,索引中的事件数就不会增加。不幸的是,有时 4 秒是不够的。
最佳答案
您看到的时间延迟是 Splunk 索引事件,这涉及写入磁盘并且可能需要时间。正如您已经尝试过的那样,解决方案是等待 Splunk 完成。
我建议为您要尝试的次数设置一个上限,并每隔 x 秒( hibernate 时间)检查一次。
在 Splunk SDK for Java(参见 SearchJobTest.java 和 SDKTestCase.java)中,我们基本上使用 assertEventuallyTrue() 方法做同样的事情:
public static boolean assertEventuallyTrue(EventuallyTrueBehavior behavior) {
int remainingTries = behavior.tries;
while (remainingTries > 0) {
boolean succeeded = behavior.predicate();
if (succeeded) {
return true;
} else {
remainingTries -= 1;
try {
Thread.sleep(behavior.pauseTime);
} catch (InterruptedException e) {}
}
}
Assert.fail(behavior.timeoutMessage);
return false;
}
关于java - Splunk Java 与 JUnit 的集成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28619336/
Windows 集成 (NTLM) 身份验证和 Windows 集成 (Kerberos) 之间有什么区别? 如何在IIS6中实现这些 w.r.t. MSDN 最佳答案 Kerberos 和 NTLM
Keycloak是一个用 Java 编写的开源身份验证和身份管理解决方案。它提供了一个nodejs适配器,使用它我能够成功地与express集成。这是有效的路由文件: 'use strict'
这是我关于 Bamboo 的第二个问题 ( My First One )。阅读建议信息后我的理解是,我需要一个构建工具,例如 nAnt 或 MSbuild 来编写一个获取源代码并构建它的脚本(我正在开
可用于将第三方应用程序与 jira 4.3 集成的身份验证方案有哪些?显然,从客户那里获取用户名和密码听起来很荒谬。另外,我知道 oauth 身份验证仅适用于版本 5。请告诉我。谢谢。 附注。我不是在
我有一个使用 DDS 的旧版 C++ 应用程序用于异步通信/消息传递。我需要将此应用程序集成到使用 JMS 进行消息传递的 JavaEE 环境中。除了构建独立的 JMS/DDS 桥接模块之外,我还有其
我正在尝试使用 Whatsapp 发送测试消息,但收到此错误消息: "error":{"code":27,"description":"Recipient not available on chann
我想将 photologue 与我的 Django 应用程序集成,并使用它在车辆库存中显示照片......有点像 Boost Motor Group Inc. 提供的内容。我已经集成了该应用程序,所以
我目前正在尝试弄清楚如何与 fujitsu scansnap 扫描仪集成,但没有从 fujitsu 找到有关 fujitsu scansnap 管理器如何调用您的应用程序并将文件发送到您的应用程序的详
在我的项目中,我使用了 9 个(九个)int-ip:udp-inbound-channel-adapter 和一个 jms:inbound-channel-adapter。 Jms 适配器从服务器接收
在我们当前的原型(prototype)中,大多数标准 HTML 控件都被小程序取代,最重要的是表单提交由小程序触发。 有没有一种方法可以像 一样在服务器端调用关联的操作 ? 本文Applet and
是否可以使用 twilio 号码从 whatsapp 发送/接收短信?有人用whatsapp试过twilio吗?我问过客服,如果可能的话,他说,不确定,但很多人都问过这个问题。 最佳答案 万一其他人来
我们办公室中几乎不存在版本控制,这显然导致了很多麻烦。我们想使用SVN和Notepad++进行设置...任何人都对如何实现此目标有任何想法?我已经开始研究并浏览了这个网站: http://www.sw
曾经有提供这种集成的 spring-modules 项目;但是,该项目现已弃用。现在有没有人继续支持这种集成?谢谢。 最佳答案 工作正在进行中。 http://blog.athico.com/sear
我的理解是,根据 http://wiki.dbpedia.org/Datasets,DBpedia 从 YAGO 获取类层次结构,而不是实体。 .但是,类似 http://dbpedia.org/cl
任何人都可以帮助我如何将 OpenCMS 与 Java Spring Web 应用程序集成。已经用谷歌搜索并浏览了很多网站但没有用。所以,请帮助我。 最佳答案 我认为将 SpringMVC 与 Ope
我正在尝试使用新的 migs getaway (MPGS) 我遵循了下一个 url 中的代码 https://ap-gateway.mastercard.com/api/documentation/i
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我有一个 cmake 项目。我想轻松完成以下操作 搜索光标下任何变量、函数等的声明、定义和引用,这些可能在外部头文件中声明,其路径是在CMakeLists.txt中使用INCLUDE_DIRECTOR
有人能给我指点一下 Objective-C(或 c/c++)库的方向,或者教通过 FTP 上传或下载的教程(Objective-C)吗?最好能展示如何将文件下载到临时目录,然后稍后上传?我不介意针对
集成()给出了非常错误的答案: integrate(function (x) dnorm(x, -5, 0.07), -Inf, Inf, subdivisions = 10000L) # 2.127
我是一名优秀的程序员,十分优秀!