Merge branch '2.0.x'

pull/14823/head
Phillip Webb 6 years ago
commit 9a80e88a73

@ -22,16 +22,16 @@ import java.util.regex.Pattern;
import org.springframework.util.Assert;
/**
* An identifier for an actuator endpoint. Endpoint IDs may contain only letters and
* numbers and must begin with a lower-case letter. Case is ignored when comparing
* endpoint IDs.
* An identifier for an actuator endpoint. Endpoint IDs may contain only letters, numbers
* and {@code '.'}. They must begin with a lower-case letter. Case is ignored when
* comparing endpoint IDs.
*
* @author Phillip Webb
* @since 2.0.6
*/
public final class EndpointId {
private static final Pattern ALPHA_NUMERIC = Pattern.compile("[a-zA-Z0-9]+");
private static final Pattern VALID_CHARS = Pattern.compile("[a-zA-Z0-9\\.]+");
private final String value;
@ -39,8 +39,8 @@ public final class EndpointId {
private EndpointId(String value) {
Assert.hasText(value, "Value must not be empty");
Assert.isTrue(ALPHA_NUMERIC.matcher(value).matches(),
"Value must be alpha-numeric");
Assert.isTrue(VALID_CHARS.matcher(value).matches(),
"Value must be alpha-numeric or '.'");
Assert.isTrue(!Character.isDigit(value.charAt(0)),
"Value must not start with a number");
Assert.isTrue(!Character.isUpperCase(value.charAt(0)),

@ -43,13 +43,13 @@ public class EndpointIdTests {
@Test
public void ofWhenContainsDashThrowsException() {
assertThatIllegalArgumentException().isThrownBy(() -> EndpointId.of("foo-bar"))
.withMessage("Value must be alpha-numeric");
.withMessageContaining("Value must be alpha-numeric");
}
@Test
public void ofWhenHasBadCharThrowsException() {
assertThatIllegalArgumentException().isThrownBy(() -> EndpointId.of("foo!bar"))
.withMessage("Value must be alpha-numeric");
.withMessageContaining("Value must be alpha-numeric");
}
@Test
@ -64,6 +64,14 @@ public class EndpointIdTests {
.withMessage("Value must not start with an uppercase letter");
}
@Test
public void ofWhenContainsDotIsValid() {
// Ideally we wouldn't support this but there are existing endpoints using the
// pattern. See gh-14773
EndpointId endpointId = EndpointId.of("foo.bar");
assertThat(endpointId.toString()).isEqualTo("foo.bar");
}
@Test
public void equalsAndHashCode() {
EndpointId one = EndpointId.of("foobar");

Loading…
Cancel
Save