Skip to content

Commit

Permalink
Add system tests for --capath option.
Browse files Browse the repository at this point in the history
  • Loading branch information
LukasBrand committed Oct 11, 2023
1 parent df40427 commit 3c9c765
Show file tree
Hide file tree
Showing 7 changed files with 296 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -242,6 +242,45 @@ void test_tls_pem_format(
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_pem_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/pem").getPath();

final List<String> publishCommand = List.of("pub",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-t",
"test",
"-m",
"message",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey,
"-d");

final ExecutionResultAsync executionResult = mqttCli.executeAsync(publishCommand);
executionResult.awaitStdOut("finish PUBLISH");
assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));

assertPublishPacket(hivemq.getPublishPackets().get(0), publishAssertion -> {
publishAssertion.setTopic("test");
publishAssertion.setPayload(ByteBuffer.wrap("message".getBytes(StandardCharsets.UTF_8)));
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_pem_format(
Expand Down Expand Up @@ -323,6 +362,45 @@ void test_tls_der_format(
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_der_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/der").getPath();

final List<String> publishCommand = List.of("pub",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-t",
"test",
"-m",
"message",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey,
"-d");

final ExecutionResultAsync executionResult = mqttCli.executeAsync(publishCommand);
executionResult.awaitStdOut("finish PUBLISH");
assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));

assertPublishPacket(hivemq.getPublishPackets().get(0), publishAssertion -> {
publishAssertion.setTopic("test");
publishAssertion.setPayload(ByteBuffer.wrap("message".getBytes(StandardCharsets.UTF_8)));
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_der_format(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,48 @@ void test_tls_pem_format(
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_pem_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/pem").getPath();

final List<String> subscribeCommand = List.of("sub",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-t",
"topic",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey,
"-d");

final ExecutionResultAsync executionResultAsync = mqttCli.executeAsync(subscribeCommand);
executionResultAsync.awaitStdOut("sending CONNECT");
executionResultAsync.awaitStdOut("received CONNACK");
executionResultAsync.awaitStdOut("sending SUBSCRIBE");
executionResultAsync.awaitStdOut("received SUBACK");

assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));

assertSubscribePacket(hivemq.getSubscribePackets().get(0), subscribeAssertion -> {
final List<Subscription> expectedSubscriptions =
List.of(new SubscriptionImpl("topic", Qos.EXACTLY_ONCE, RetainHandling.SEND, false, false));
subscribeAssertion.setSubscriptions(expectedSubscriptions);
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_pem_format(
Expand Down Expand Up @@ -332,6 +374,48 @@ void test_tls_der_format(
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_der_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/der").getPath();

final List<String> subscribeCommand = List.of("sub",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-t",
"topic",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey,
"-d");

final ExecutionResultAsync executionResultAsync = mqttCli.executeAsync(subscribeCommand);
executionResultAsync.awaitStdOut("sending CONNECT");
executionResultAsync.awaitStdOut("received CONNACK");
executionResultAsync.awaitStdOut("sending SUBSCRIBE");
executionResultAsync.awaitStdOut("received SUBACK");

assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));

assertSubscribePacket(hivemq.getSubscribePackets().get(0), subscribeAssertion -> {
final List<Subscription> expectedSubscriptions =
List.of(new SubscriptionImpl("topic", Qos.EXACTLY_ONCE, RetainHandling.SEND, false, false));
subscribeAssertion.setSubscriptions(expectedSubscriptions);
});
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_der_format(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,34 @@ void test_tls_pem_format(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_pem_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/pem").getPath();

final List<String> testCommand = List.of("test",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey);

final ExecutionResultAsync executionResult = mqttCli.executeAsync(testCommand);
executionResult.awaitStdOut("MQTT " + mqttVersion + ": OK");

assertTestConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_pem_format(
Expand Down Expand Up @@ -252,6 +280,34 @@ void test_tls_der_format(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_der_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/der").getPath();

final List<String> testCommand = List.of("test",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey);

final ExecutionResultAsync executionResult = mqttCli.executeAsync(testCommand);
executionResult.awaitStdOut("MQTT " + mqttVersion + ": OK");

assertTestConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_properties_tls_der_format(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,35 @@ void test_tls_pem_format(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_pem_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/pem").getPath();

final List<String> connectCommand = List.of("con",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey);

mqttCliShell.executeAsync(connectCommand).awaitLog("sending CONNECT").awaitLog("received CONNACK");

assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));
}


//DER

Expand Down Expand Up @@ -191,6 +220,35 @@ void test_tls_der_format(
mqttVersion)));
}

@CartesianTest
@Timeout(value = 3, unit = TimeUnit.MINUTES)
void test_tls_der_format_via_folder(
@CartesianTest.Values(chars = {'3', '5'}) final char mqttVersion,
@CartesianTest.Enum final @NotNull TlsVersion tlsVersion) throws Exception {
final String certificateAuthorityPublicKey = Resources.getResource("tls/certificateAuthority/capath/der").getPath();

final List<String> connectCommand = List.of("con",
"-h",
hivemq.getHost(),
"-p",
String.valueOf(hivemq.getMqttTlsPort()),
"-V",
String.valueOf(mqttVersion),
"-i",
"cliTest",
"-s",
"--tls-version",
tlsVersion.toString(),
"--capath",
certificateAuthorityPublicKey);

mqttCliShell.executeAsync(connectCommand).awaitLog("sending CONNECT").awaitLog("received CONNACK");

assertConnectPacket(hivemq.getConnectPackets().get(0),
connectAssertion -> connectAssertion.setMqttVersion(MqttVersionConverter.toExtensionSdkVersion(
mqttVersion)));
}


//NO CERT

Expand Down
3 changes: 2 additions & 1 deletion src/systemTest/resources/tls/certificate-generator-tool.sh
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,8 @@ keytool -exportcert -alias ca -file $caFolder/$caCertName.cer -keystore $caFolde
keytool -exportcert -alias ca -file $caFolder/$caCertName.pem -keystore $caFolder/$caKeystoreName.p12 -storepass $caKeystorePass -rfc
##JKS
keytool -importkeystore -srckeystore $caFolder/$caKeystoreName.p12 -destkeystore $caFolder/$caKeystoreName.jks -srcstoretype PKCS12 -deststoretype JKS -srcstorepass $caKeystorePass -deststorepass $caKeystorePass -srcalias ca -destalias ca -srckeypass $caKeyPass -destkeypass $caKeyPass -noprompt

mkdir -p $caFolder/capath/der && cp $caFolder/$caCertName.cer $caFolder/capath/der
mkdir -p $caFolder/capath/pem && cp $caFolder/$caCertName.pem $caFolder/capath/pem


#*****************************************#
Expand Down
Binary file not shown.
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
-----BEGIN CERTIFICATE-----
MIIC4zCCAcugAwIBAgIEcqEwRzANBgkqhkiG9w0BAQsFADASMRAwDgYDVQQDEwdS
b290LUNBMCAXDTIzMDIxNzEwMjM1N1oYDzMwMjIwNjIwMTAyMzU3WjASMRAwDgYD
VQQDEwdSb290LUNBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhqkJ
mgBCcnc3xf2qnJvD3txr8ASAmQMt14FzINmRoOBu9FyPQ9sc1EkfzywTHWBySzYK
sqS2ofk+4aL3j3O3dhBZNngUJS69zF37K72E9NhQss9EiocLzHhDfj1v+xAhDRfe
rLcKgGYSqX0SsRabKD8UGViDc3AHblvScelS4Ohc9NP+QwJJxLqQ7p5cNnh1MGr4
Y6M2kYMFZwcqxQIcx67A9kZlLU6ER909Pg8/Ip+MGPv2xAZp5z7nli+rm6LyUDUg
tP3VXQ4VvZuYT+04dcwuP7NP+N1IZDN6aQA5+XbT16NWZ/KrXFLi+dXJdeObUmDS
gkPsNy3t9GYonwLzlwIDAQABoz8wPTAdBgNVHQ4EFgQUT6Dk80UQ2jayXbtGO6Lk
k6gR0oYwCwYDVR0PBAQDAgKEMA8GA1UdEwQIMAYBAf8CAQMwDQYJKoZIhvcNAQEL
BQADggEBAHFsqy7uJpJGkUCLjb116XsAmJE/1zcParuhBNT/rLCqiA6vYYUiNRd0
qTHzR/M7tSe52gMt6MNaDzPA/MBE30foHL5j+SjD3p8XJF68ReByQCXpj4njwQ6n
EkYSlTplCNNjQ6ivef78T4Tb5RITOn9SRmd+0mUVzFtcetRa+2cafLAgA0XKp4Tv
/EQ/7f9RcGIMaf/Umpum0rax+/omn0yz2G8eURNh13ZgP4/dsw2EXUUCfvQ84TdL
yDuZnxLRieHtAA0h+AMC4t1JHz6QfrDcbP1tptyXbae9LTsCjGZN+SJRQ3Y79dJD
GuyIlVc3tCIMdHH9kqNAe696K242YJo=
-----END CERTIFICATE-----

0 comments on commit 3c9c765

Please sign in to comment.