Update alarm resource test to green

This commit is contained in:
Jonathan Halterman 2014-03-24 15:42:25 -07:00
parent 1d5847562e
commit 3e4b697a50
3 changed files with 39 additions and 49 deletions

View File

@ -57,20 +57,22 @@ public class CreateAlarmCommand {
public void validate() {
if (name.length() > 250)
Exceptions.unprocessableEntity("Name %s must be 250 characters or less", name);
throw Exceptions.unprocessableEntity("Name %s must be 250 characters or less", name);
if (description != null && description.length() > 250)
Exceptions.unprocessableEntity("Description %s must be 250 characters or less", description);
throw Exceptions.unprocessableEntity("Description %s must be 250 characters or less",
description);
for (String action : alarmActions)
if (action.length() > 50)
Exceptions.unprocessableEntity("Alarm action %s must be 50 characters or less", action);
throw Exceptions.unprocessableEntity("Alarm action %s must be 50 characters or less",
action);
if (okActions != null)
for (String action : okActions)
if (action.length() > 50)
Exceptions.unprocessableEntity("Ok action %s must be 50 characters or less", action);
throw Exceptions.unprocessableEntity("Ok action %s must be 50 characters or less", action);
if (undeterminedActions != null)
for (String action : undeterminedActions)
if (action.length() > 50)
Exceptions.unprocessableEntity("Undetermined action %s must be 50 characters or less",
action);
throw Exceptions.unprocessableEntity(
"Undetermined action %s must be 50 characters or less", action);
}
}

View File

@ -1,7 +1,5 @@
package com.hpcloud.mon.resource;
import io.dropwizard.jersey.jackson.JsonProcessingExceptionMapper;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.PropertyNamingStrategy;
import com.hpcloud.dropwizard.AbstractResourceTest;
@ -11,6 +9,7 @@ import com.hpcloud.mon.resource.exception.EntityNotFoundExceptionMapper;
import com.hpcloud.mon.resource.exception.IllegalArgumentExceptionMapper;
import com.hpcloud.mon.resource.exception.InvalidEntityExceptionMapper;
import com.hpcloud.mon.resource.exception.JsonMappingExceptionManager;
import com.hpcloud.mon.resource.exception.JsonProcessingExceptionMapper;
import com.hpcloud.mon.resource.exception.ResourceNotFoundExceptionMapper;
import com.hpcloud.mon.resource.exception.ThrowableExceptionMapper;

View File

@ -37,6 +37,7 @@ import com.sun.jersey.api.client.GenericType;
*/
@Test
public class AlarmResourceTest extends AbstractMonApiResourceTest {
private String expression;
private AlarmDetail alarm;
private Alarm alarmItem;
private AlarmService service;
@ -47,8 +48,8 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
@SuppressWarnings("unchecked")
protected void setupResources() throws Exception {
super.setupResources();
String expression = "avg(hpcs.compute{instance_id=937, az=2, instance_uuid=0ff588fc-d298-482f-bb11-4b52d56801a4, metric_name=disk_read_ops}) >= 90";
expression = "avg(disk_read_ops{service=hpcs.compute, instance_id=937}) >= 90";
alarmItem = new Alarm("123", "Disk Exceeds 1k Operations", null, expression, AlarmState.OK);
alarmActions = new ArrayList<String>();
alarmActions.add("29387234");
@ -71,27 +72,35 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
@SuppressWarnings("unchecked")
public void shouldCreate() {
String expression = "avg(hpcs.compute{instance_id=937, az=2, instance_uuid=0ff588fc-d298-482f-bb11-4b52d56801a4, metric_name=disk_read_ops}) >= 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, alarmActions));
assertEquals(response.getStatus(), 201);
AlarmDetail newAlarm = response.getEntity(AlarmDetail.class);
String location = response.getHeaders().get("Location").get(0);
assertEquals(location, "/v1.1/alarms/" + newAlarm.getId());
assertEquals(location, "/v2.0/alarms/" + newAlarm.getId());
assertEquals(newAlarm, alarm);
verify(service).create(eq("abc"), eq("Disk Exceeds 1k Operations"), any(String.class),
eq(expression), eq(AlarmExpression.of(expression)), any(List.class), any(List.class),
any(List.class));
}
public void shouldErrorOnCreateWithInvalidDimensions() {
String expression = "avg(hpcs.compute{instance_id=937, metric_name=disk_read_ops}) >= 90";
public void shouldErrorOnCreateWithInvalidMetricName() {
String expression = "avg(foo{service=hpcs.compute, instance_id=937}) >= 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, alarmActions));
ErrorMessages.assertThat(response.getEntity(String.class)).matches("unprocessable_entity", 422,
"The required dimensions");
"foo is not a valid metric name for namespace hpcs.compute");
}
public void shouldErrorOnCreateWithInvalidDimensions() {
String expression = "avg(disk_read_ops{service=hpcs.compute, instance_id=937, foo=bar}) >= 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, alarmActions));
ErrorMessages.assertThat(response.getEntity(String.class)).matches("unprocessable_entity", 422,
"foo is not a valid dimension name for service hpcs.compute");
}
public void shouldErrorOnCreateWithDuplicateDimensions() {
@ -104,15 +113,6 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
"More than one value was given for dimension instance_id");
}
public void shouldErrorOnCreateWithEmptyDimensionsForHpCloudNamespace() {
String expression = "avg(hpcs.compute{metric_name=disk_read_ops}) >= 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, alarmActions));
ErrorMessages.assertThat(response.getEntity(String.class)).matches("unprocessable_entity", 422,
"The required dimensions [instance_id, instance_uuid, az] are not present");
}
@SuppressWarnings("unchecked")
public void shouldNotRequireDimensionsForCustomNamespace() {
String expression = "avg(foo{metric_name=bar}) >= 90";
@ -132,15 +132,6 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
"Unable to process the provided JSON", "Unexpected character (':'");
}
public void shouldErrorOnCreateWithInvalidMetricType() {
String expression = "avg(hpcs.compute{instance_id=937, az=2, instance_uuid=0ff588fc-d298-482f-bb11-4b52d56801a4, metric_name=blah}) >= 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, alarmActions));
ErrorMessages.assertThat(response.getEntity(String.class)).matches("unprocessable_entity", 422,
"blah is not a valid metric name for namespace hpcs.compute");
}
public void shouldErrorOnCreateWithInvalidOperator() {
String expression = "avg(hpcs.compute{instance_id=937, az=2, instance_uuid=0ff588fc-d298-482f-bb11-4b52d56801a4, metric_name=disk_read_ops}) & 90";
ClientResponse response = createResponseFor(new CreateAlarmCommand(
@ -155,9 +146,8 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
ClientResponse response = createResponseFor(new CreateAlarmCommand(
"Disk Exceeds 1k Operations", null, expression, null));
ErrorMessages.assertThat(response.getEntity(String.class)).matches("bad_request", 400,
"The request entity had the following errors:",
"[alarm.alarmActions may not be empty (was null)]");
ErrorMessages.assertThat(response.getEntity(String.class)).matches("unprocessable_entity", 422,
"[alarmActions may not be empty (was null)]");
}
public void shouldErrorOnCreateWith0Period() {
@ -212,7 +202,6 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldErrorOnCreateWithTooLongAlarmAction() {
String expression = "avg(hpcs.compute{instance_id=937, az=2, instance_uuid=0ff588fc-d298-482f-bb11-4b52d56801a4, metric_name=disk_read_ops}) >= 90";
alarmActions = new ArrayList<String>();
alarmActions.add("012345678901234567890123456789012345678901234567890");
ClientResponse response = createResponseFor(new CreateAlarmCommand(
@ -224,7 +213,7 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldList() {
List<Alarm> alarms = client().resource("/v1.1/alarms")
List<Alarm> alarms = client().resource("/v2.0/alarms")
.header("X-Tenant-Id", "abc")
.get(new GenericType<List<Alarm>>() {
});
@ -234,9 +223,9 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldGet() {
assertEquals(client().resource("/v1.1/alarms/123")
assertEquals(client().resource("/v2.0/alarms/123")
.header("X-Tenant-Id", "abc")
.get(Alarm.class), alarm);
.get(AlarmDetail.class), alarm);
verify(repo).findById(eq("abc"), eq("123"));
}
@ -244,7 +233,7 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
doThrow(new EntityNotFoundException(null)).when(repo).findById(eq("abc"), eq("999"));
try {
client().resource("/v1.1/alarms/999").header("X-Tenant-Id", "abc").get(Alarm.class);
client().resource("/v2.0/alarms/999").header("X-Tenant-Id", "abc").get(Alarm.class);
fail();
} catch (Exception e) {
assertTrue(e.getMessage().contains("404"));
@ -252,7 +241,7 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldDelete() {
ClientResponse response = client().resource("/v1.1/alarms/123")
ClientResponse response = client().resource("/v2.0/alarms/123")
.header("X-Tenant-Id", "abc")
.delete(ClientResponse.class);
assertEquals(response.getStatus(), 204);
@ -263,7 +252,7 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
doThrow(new EntityNotFoundException(null)).when(service).delete(eq("abc"), eq("999"));
try {
client().resource("/v1.1/alarms/999").header("X-Tenant-Id", "abc").delete();
client().resource("/v2.0/alarms/999").header("X-Tenant-Id", "abc").delete();
fail();
} catch (Exception e) {
assertTrue(e.getMessage().contains("404"));
@ -274,7 +263,7 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
doThrow(new RuntimeException("")).when(repo).find(anyString());
try {
client().resource("/v1.1/alarms").header("X-Tenant-Id", "abc").get(List.class);
client().resource("/v2.0/alarms").header("X-Tenant-Id", "abc").get(List.class);
fail();
} catch (Exception e) {
assertTrue(e.getMessage().contains("500"));
@ -282,8 +271,8 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldHydateLinksOnList() {
List<Link> expected = Arrays.asList(new Link("self", "/v1.1/alarms/123"));
List<Link> links = client().resource("/v1.1/alarms")
List<Link> expected = Arrays.asList(new Link("self", "/v2.0/alarms/123"));
List<Link> links = client().resource("/v2.0/alarms")
.header("X-Tenant-Id", "abc")
.get(new GenericType<List<Alarm>>() {
})
@ -293,15 +282,15 @@ public class AlarmResourceTest extends AbstractMonApiResourceTest {
}
public void shouldHydateLinksOnGet() {
List<Link> links = Arrays.asList(new Link("self", "/v1.1/alarms/123"));
assertEquals(client().resource("/v1.1/alarms/123")
List<Link> links = Arrays.asList(new Link("self", "/v2.0/alarms/123"));
assertEquals(client().resource("/v2.0/alarms/123")
.header("X-Tenant-Id", "abc")
.get(Alarm.class)
.get(AlarmDetail.class)
.getLinks(), links);
}
private ClientResponse createResponseFor(Object request) {
return client().resource("/v1.1/alarms")
return client().resource("/v2.0/alarms")
.header("X-Tenant-Id", "abc")
.header("Content-Type", MediaType.APPLICATION_JSON)
.post(ClientResponse.class, request);