Polish "Support IPv6 addresses when configuring RabbitMQ using properties"

See gh-37619
3.1.x
Scott Frederick 1 year ago
parent c1972f6db6
commit fad43adf14

@ -53,9 +53,9 @@ class PropertiesRabbitConnectionDetails implements RabbitConnectionDetails {
public List<Address> getAddresses() { public List<Address> getAddresses() {
List<Address> addresses = new ArrayList<>(); List<Address> addresses = new ArrayList<>();
for (String address : this.properties.determineAddresses().split(",")) { for (String address : this.properties.determineAddresses().split(",")) {
int portSeparatorPosition = address.lastIndexOf(':'); int portSeparatorIndex = address.lastIndexOf(':');
String host = address.substring(0, portSeparatorPosition); String host = address.substring(0, portSeparatorIndex);
String port = address.substring(portSeparatorPosition + 1); String port = address.substring(portSeparatorIndex + 1);
addresses.add(new Address(host, Integer.parseInt(port))); addresses.add(new Address(host, Integer.parseInt(port)));
} }
return addresses; return addresses;

@ -23,20 +23,32 @@ import org.junit.jupiter.api.Test;
import org.springframework.boot.autoconfigure.amqp.RabbitConnectionDetails.Address; import org.springframework.boot.autoconfigure.amqp.RabbitConnectionDetails.Address;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
import static org.junit.jupiter.api.Assertions.*;
class PropertiesRabbitConnectionDetailsTest { /**
* Tests for {@link PropertiesRabbitConnectionDetails}.
*
* @author Jonas Fügedi
*/
class PropertiesRabbitConnectionDetailsTests {
private static final int DEFAULT_PORT = 5672;
@Test @Test
void getAddresses() { void getAddresses() {
RabbitProperties properties = new RabbitProperties(); RabbitProperties properties = new RabbitProperties();
properties.setAddresses("localhost:1234,[::1]:32863"); properties.setAddresses("localhost,localhost:1234,[::1],[::1]:32863");
PropertiesRabbitConnectionDetails propertiesRabbitConnectionDetails = new PropertiesRabbitConnectionDetails(properties); PropertiesRabbitConnectionDetails propertiesRabbitConnectionDetails = new PropertiesRabbitConnectionDetails(
properties);
List<Address> addresses = propertiesRabbitConnectionDetails.getAddresses(); List<Address> addresses = propertiesRabbitConnectionDetails.getAddresses();
assertThat(addresses.size()).isEqualTo(2); assertThat(addresses.size()).isEqualTo(4);
assertThat(addresses.get(0).host()).isEqualTo("localhost"); assertThat(addresses.get(0).host()).isEqualTo("localhost");
assertThat(addresses.get(1).host()).isEqualTo("[::1]"); assertThat(addresses.get(0).port()).isEqualTo(DEFAULT_PORT);
assertThat(addresses.get(0).port()).isEqualTo(1234); assertThat(addresses.get(1).host()).isEqualTo("localhost");
assertThat(addresses.get(1).port()).isEqualTo(32863); assertThat(addresses.get(1).port()).isEqualTo(1234);
assertThat(addresses.get(2).host()).isEqualTo("[::1]");
assertThat(addresses.get(2).port()).isEqualTo(DEFAULT_PORT);
assertThat(addresses.get(3).host()).isEqualTo("[::1]");
assertThat(addresses.get(3).port()).isEqualTo(32863);
} }
}
}

@ -274,13 +274,6 @@ class RabbitPropertiesTests {
assertThat(this.properties.determineAddresses()).isEqualTo("localhost:5671"); assertThat(this.properties.determineAddresses()).isEqualTo("localhost:5671");
} }
@Test
void determineAddressesUsesHostAndPortPropertiesWhenNoAddressesSetIpV6() {
this.properties.setHost("[::1]");
this.properties.setPort(32863);
assertThat(this.properties.determineAddresses()).isEqualTo("[::1]:32863");
}
@Test @Test
void determineAddressesUsesHostAndPortPropertiesWhenNoAddressesSet() { void determineAddressesUsesHostAndPortPropertiesWhenNoAddressesSet() {
this.properties.setHost("rabbit.example.com"); this.properties.setHost("rabbit.example.com");
@ -288,6 +281,13 @@ class RabbitPropertiesTests {
assertThat(this.properties.determineAddresses()).isEqualTo("rabbit.example.com:1234"); assertThat(this.properties.determineAddresses()).isEqualTo("rabbit.example.com:1234");
} }
@Test
void determineAddressesUsesIpv6HostAndPortPropertiesWhenNoAddressesSet() {
this.properties.setHost("[::1]");
this.properties.setPort(32863);
assertThat(this.properties.determineAddresses()).isEqualTo("[::1]:32863");
}
@Test @Test
void determineSslUsingAmqpsReturnsStateOfFirstAddress() { void determineSslUsingAmqpsReturnsStateOfFirstAddress() {
this.properties.setAddresses("amqps://root:password@otherhost,amqp://root:password2@otherhost2"); this.properties.setAddresses("amqps://root:password@otherhost,amqp://root:password2@otherhost2");

Loading…
Cancel
Save