Skip to content

Commit

Permalink
Merge branch 'master' into bugfix/auto-config-timezone-for-Jackson
Browse files Browse the repository at this point in the history
  • Loading branch information
zqr10159 authored Jul 5, 2024
2 parents 36d0c25 + b9f8b7d commit 1ce3d2d
Show file tree
Hide file tree
Showing 21 changed files with 323 additions and 258 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ public void collect(CollectRep.MetricsData.Builder builder, long monitorId, Stri
if (telnetClient.isConnected()) {
long responseTime = System.currentTimeMillis() - startTime;
List<String> aliasFields = metrics.getAliasFields();
Map<String, String> resultMap = execCmdAndParseResult(telnetClient, telnet.getCmd());
Map<String, String> resultMap = execCmdAndParseResult(telnetClient, telnet.getCmd(), app);
resultMap.put(CollectorConstants.RESPONSE_TIME, Long.toString(responseTime));
if (resultMap.size() < aliasFields.size()) {
log.error("telnet response data not enough: {}", resultMap);
Expand Down Expand Up @@ -115,7 +115,7 @@ public String supportProtocol() {
return DispatchConstants.PROTOCOL_TELNET;
}

private static Map<String, String> execCmdAndParseResult(TelnetClient telnetClient, String cmd) throws IOException {
private static Map<String, String> execCmdAndParseResult(TelnetClient telnetClient, String cmd, String app) throws IOException {
if (cmd == null || cmd.trim().length() == 0) {
return new HashMap<>(16);
}
Expand All @@ -124,6 +124,11 @@ private static Map<String, String> execCmdAndParseResult(TelnetClient telnetClie
outputStream.flush();
String result = new String(telnetClient.getInputStream().readAllBytes());
String[] lines = result.split("\n");
if (CollectorConstants.ZOOKEEPER_APP.equals(app) && CollectorConstants.ZOOKEEPER_ENVI_HEAD.equals(lines[0])) {
lines = Arrays.stream(lines)
.skip(1)
.toArray(String[]::new);
}
boolean contains = lines[0].contains("=");
return Arrays.stream(lines)
.map(item -> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,4 +49,8 @@ public interface CollectorConstants {
* MongoDB Atlas model
*/
String MONGO_DB_ATLAS_MODEL = "mongodb-atlas";

String ZOOKEEPER_APP = "zookeeper";

String ZOOKEEPER_ENVI_HEAD = "Environment:";
}
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ private IntervalExpressionUtil() {
* @return true-yes false-no
*/
public static boolean validNumberIntervalExpress(Double numberValue, String expression) {
if (expression == null || "".equals(expression)) {
if (expression == null || expression.isEmpty()) {
return true;
}
if (numberValue == null) {
Expand All @@ -64,12 +64,12 @@ public static boolean validNumberIntervalExpress(Double numberValue, String expr
}
Double[] doubleValues = new Double[2];
if (NEGATIVE.equals(values[0])) {
doubleValues[0] = Double.MIN_VALUE;
doubleValues[0] = Double.NEGATIVE_INFINITY;
} else {
doubleValues[0] = Double.parseDouble(values[0]);
}
if (POSITIVE.equals(values[1])) {
doubleValues[1] = Double.MAX_VALUE;
doubleValues[1] = Double.POSITIVE_INFINITY;
} else {
doubleValues[1] = Double.parseDouble(values[1]);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
import org.springframework.util.StringUtils;

/**
* ipv4 ipv6 domain util
* ipv4 ipv6 domain util.
*/
@Slf4j
public final class IpDomainUtil {
Expand All @@ -40,15 +40,15 @@ public final class IpDomainUtil {
private static final String LOCALHOST = "localhost";

/**
* HTTP header schema
* HTTP header schema.
*/
private static final Pattern DOMAIN_SCHEMA = Pattern.compile("^([hH][tT]{2}[pP]://|[hH][tT]{2}[pP][sS]://){1}[^\\s]*");

private IpDomainUtil() {
}

/**
* whether it is ip or domain
* whether it is ip or domain.
* @param ipDomain ip domain string
* @return true-yes false-no
*/
Expand All @@ -70,7 +70,7 @@ public static boolean validateIpDomain(String ipDomain) {
}

/**
* if domain or ip has http / https schema
* if domain or ip has http / https schema.
* @param domainIp host
* @return true or false
*/
Expand All @@ -82,7 +82,7 @@ public static boolean isHasSchema(String domainIp) {
}

/**
* get localhost IP
* get localhost IP.
* @return ip
*/
public static String getLocalhostIp() {
Expand All @@ -108,7 +108,7 @@ public static String getLocalhostIp() {
}

/**
*
* check IP address type.
* @param ipDomain ip domain
* @return IP address type
*/
Expand All @@ -120,7 +120,7 @@ public static String checkIpAddressType(String ipDomain){
}

/**
* get current local host name
* get current local host name.
* @return hostname
*/
public static String getCurrentHostName() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,54 @@

package org.apache.hertzbeat.common.util;

import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;

import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertTrue;

/**
* Test case for {@link IntervalExpressionUtil}
*/
class IntervalExpressionUtilTest {

@BeforeEach
void setUp() {
}
@Test
public void testValidNumberIntervalExpress() {

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(5.0, null));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(5.0, ""));

assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(null, "(3,7)"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(5.0, "(3,7)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(3.0, "(3,7)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(7.0, "(3,7)"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(3.0, "[3,7]"));
assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(7.0, "[3,7]"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(2.0, "[3,7]"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(8.0, "[3,7]"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(3.0, "[3,7)"));
assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(6.9999, "[3,7)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(7.0, "[3,7)"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(4.0, "(3,7]"));
assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(7.0, "(3,7]"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(3.0, "(3,7]"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(-1000.0, "(-∞,5)"));
assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(-1.0, "(-∞,5)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(5.0, "(-∞,5)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(10.0, "(-∞,5)"));

assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(1000.0, "(5,+∞)"));
assertTrue(IntervalExpressionUtil.validNumberIntervalExpress(10.0, "(5,+∞)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(5.0, "(5,+∞)"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(0.0, "(5,+∞)"));

assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(5.0, "(3,7"));
assertFalse(IntervalExpressionUtil.validNumberIntervalExpress(5.0, "[3,7)3,7]"));
}

@Test
void validNumberIntervalExpress() {
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,24 @@

package org.apache.hertzbeat.common.util;

import java.net.Inet4Address;
import java.net.InetAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.util.Collections;
import java.util.Enumeration;

import org.apache.hertzbeat.common.constants.CollectorConstants;
import org.junit.jupiter.api.Test;
import org.mockito.MockedStatic;
import org.mockito.Mockito;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertNull;
import static org.junit.jupiter.api.Assertions.assertTrue;
import org.junit.jupiter.api.Test;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;

/**
* Test case for {@link IpDomainUtil}
Expand Down Expand Up @@ -56,4 +71,63 @@ void isHasSchema() {
assertFalse(IpDomainUtil.isHasSchema("www.baidu.com"));
assertFalse(IpDomainUtil.isHasSchema("https_www.baidu.com"));
}

@Test
void testGetLocalhostIp() throws SocketException {

// Success
InetAddress mockedInetAddress = mock(Inet4Address.class);
when(mockedInetAddress.getHostAddress()).thenReturn("192.168.1.100");

NetworkInterface mockedNetworkInterface = mock(NetworkInterface.class);
when(mockedNetworkInterface.isLoopback()).thenReturn(false);
when(mockedNetworkInterface.isVirtual()).thenReturn(false);
when(mockedNetworkInterface.isUp()).thenReturn(true);

Enumeration<InetAddress> inetAddresses = Collections.enumeration(Collections.singletonList(mockedInetAddress));
when(mockedNetworkInterface.getInetAddresses()).thenReturn(inetAddresses);

Enumeration<NetworkInterface> successNetworkInterfaces = Collections.enumeration(Collections.singletonList(mockedNetworkInterface));

try (MockedStatic<NetworkInterface> mockedStaticNetworkInterface = Mockito.mockStatic(NetworkInterface.class)) {
mockedStaticNetworkInterface.when(NetworkInterface::getNetworkInterfaces).thenReturn(successNetworkInterfaces);
String localhostIp = IpDomainUtil.getLocalhostIp();

assertEquals("192.168.1.100", localhostIp);
}

// no network interface
Enumeration<NetworkInterface> noNetworkIFNetworkInterfaces = Collections.enumeration(Collections.emptyList());

try (MockedStatic<NetworkInterface> mockedStaticNetworkInterface = Mockito.mockStatic(NetworkInterface.class)) {
mockedStaticNetworkInterface.when(NetworkInterface::getNetworkInterfaces).thenReturn(noNetworkIFNetworkInterfaces);
String localhostIp = IpDomainUtil.getLocalhostIp();

assertNull(localhostIp);
}

// throw exception
try (MockedStatic<NetworkInterface> mockedStaticNetworkInterface = Mockito.mockStatic(NetworkInterface.class)) {
mockedStaticNetworkInterface.when(NetworkInterface::getNetworkInterfaces).thenThrow(new RuntimeException("Test exception"));
String localhostIp = IpDomainUtil.getLocalhostIp();

assertNull(localhostIp);
}

}

@Test
void testCheckIpAddressType() {

assertEquals(CollectorConstants.IPV4, IpDomainUtil.checkIpAddressType("192.168.1.1"));
assertEquals(CollectorConstants.IPV4, IpDomainUtil.checkIpAddressType("127.0.0.1"));

assertEquals(CollectorConstants.IPV6, IpDomainUtil.checkIpAddressType("2001:0db8:85a3:0000:0000:8a2e:0370:7334"));
assertEquals(CollectorConstants.IPV6, IpDomainUtil.checkIpAddressType("::1"));

assertEquals(CollectorConstants.IPV4, IpDomainUtil.checkIpAddressType(""));
assertEquals(CollectorConstants.IPV4, IpDomainUtil.checkIpAddressType(null));
assertEquals(CollectorConstants.IPV4, IpDomainUtil.checkIpAddressType("invalid-ip"));

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -27,15 +27,15 @@ sidebar_position: 0

> 在 HertzBeat 社区,贡献方式有很多:
- 💻**代码**:可以帮助社区完成一些任务、编写新的feature或者是修复一些bug
- 💻**代码**:可以帮助社区完成一些任务、编写新的 feature 或者是修复一些 bug

- ⚠️**测试**:可以来参与测试代码的编写,包括了单元测试、集成测试、e2e测试
- ⚠️**测试**:可以来参与测试代码的编写,包括了单元测试、集成测试、e2e 测试

- 📖**文档**:可以编写或完善文档,来帮助用户更好地了解和使用 HertzBeat;

- 📝**博客**:可以撰写 HertzBeat 的相关文章,来帮助社区更好地推广;

- 🤔**讨论**:可以参与 HertzBeat 新的feature的讨论,将您的想法跟 HertzBeat 融合;
- 🤔**讨论**:可以参与 HertzBeat 新的 feature 的讨论,将您的想法跟 HertzBeat 融合;

- 💡**布道**:可以帮助宣传或推广 HertzBeat 社区,在 meetup 或 summit 中演讲;

Expand All @@ -62,31 +62,31 @@ sidebar_position: 0

#### 前端启动

1. 需要 `nodejs yarn` 环境, Make sure `Node.js >= 18`
1. 需要 `nodejs yarn` 环境, 确保 `Node.js >= 18`

2. 进入 `web-app` 目录: `cd web-app`

3. 安装yarn: `npm install -g yarn`
3. 安装 yarn: `npm install -g yarn`

4. 在前端工程目录 `web-app` 下执行: `yarn install` or `yarn install --registry=https://registry.npmmirror.com` in `web-app`

5. 全局安装 `angular-cli`: `yarn global add @angular/cli@15` or `yarn global add @angular/cli@15 --registry=https://registry.npmmirror.com`

6. 待本地后端启动后,在web-app目录下启动本地前端 `ng serve --open`
6. 待本地后端启动后,在 web-app 目录下启动本地前端 `ng serve --open`

7. 浏览器访问 localhost:4200 即可开始,默认账号密码 **admin/hertzbeat**

### 寻找任务

寻找您感兴趣的Issue!在我们的GitHub仓库和邮件列表中,我们经常会发布一些带有 good first issue 或者 status: volunteer wanted 标签的issue,这些issue都欢迎贡献者的帮助。
其中good first issue往往门槛较低、适合新手。
寻找您感兴趣的 Issue!在我们的 GitHub 仓库和邮件列表中,我们经常会发布一些带有 good first issue 或者 status: volunteer wanted 标签的 issue,这些issue都欢迎贡献者的帮助。
其中 good first issue 往往门槛较低、适合新手。

当然,如果您有好的想法,也可以直接在GitHub Discussion 中提出或者联系社区。
当然,如果您有好的想法,也可以直接在 GitHub Discussion 中提出或者联系社区。

### 提交 Pull Request

1. 首先您需要 Fork 目标仓库 [hertzbeat repository](https://github.com/apache/hertzbeat).
2. 然后 用git命令 将代码下载到本地:
2. 然后 用 git 命令 将代码下载到本地:
```shell
git clone [email protected]:${YOUR_USERNAME}/hertzbeat.git #Recommended
```
Expand All @@ -95,7 +95,7 @@ git clone [email protected]:${YOUR_USERNAME}/hertzbeat.git #Recommended
```shell
git checkout -b a-feature-branch #Recommended
```
5. 提交 commit , commit 描述信息需要符合约定格式: [module name or type name]feature or bugfix or doc: custom message.
5. 提交 commit, commit 描述信息需要符合约定格式: [module name or type name]feature or bugfix or doc: custom message.
```shell
git add <modified file/path>
git commit -m '[docs]feature: necessary instructions' #Recommended
Expand Down Expand Up @@ -135,7 +135,7 @@ git checkout master
git pull upstream master
```

### 如何成为Committer
### 如何成为 Committer

通过上述步骤,您就是 HertzBeat 的贡献者了。重复前面的步骤,在社区中保持活跃,坚持下去,您就能成为 Committer!

Expand Down
Loading

0 comments on commit 1ce3d2d

Please sign in to comment.