use of io.strimzi.operator.common.operator.resource.AbstractWatchableStatusedResourceOperator in project strimzi-kafka-operator by strimzi.
the class OperatorMetricsTest method resourceOperatorWithExistingPausedResource.
private AbstractWatchableStatusedResourceOperator resourceOperatorWithExistingPausedResource() {
return new AbstractWatchableStatusedResourceOperator(vertx, null, "TestResource") {
@Override
public Future updateStatusAsync(Reconciliation reconciliation, HasMetadata resource) {
return Future.succeededFuture();
}
@Override
protected MixedOperation operation() {
return null;
}
@Override
public CustomResource get(String namespace, String name) {
@Group("strimzi")
@Version("v1")
class Foo extends MyResource {
@Override
public ObjectMeta getMetadata() {
ObjectMeta md = new ObjectMeta();
md.setAnnotations(singletonMap("strimzi.io/pause-reconciliation", "true"));
return md;
}
@Override
public void setMetadata(ObjectMeta objectMeta) {
}
@Override
public String getKind() {
return "TestResource";
}
@Override
public String getApiVersion() {
return "v1";
}
@Override
public void setApiVersion(String s) {
}
@Override
public Spec getSpec() {
return new Spec() {
};
}
@Override
public void setSpec(Object spec) {
}
@Override
public Status getStatus() {
return null;
}
@Override
public void setStatus(Object status) {
}
}
return new Foo();
}
@Override
public Future getAsync(String namespace, String name) {
@Group("strimzi")
@Version("v1")
class Foo extends MyResource {
@Override
public ObjectMeta getMetadata() {
ObjectMeta md = new ObjectMeta();
md.setAnnotations(singletonMap("strimzi.io/pause-reconciliation", "true"));
return md;
}
@Override
public void setMetadata(ObjectMeta objectMeta) {
}
@Override
public String getKind() {
return "TestResource";
}
@Override
public String getApiVersion() {
return "v1";
}
@Override
public void setApiVersion(String s) {
}
@Override
public Spec getSpec() {
return new Spec() {
};
}
@Override
public void setSpec(Object spec) {
}
@Override
public Status getStatus() {
return null;
}
@Override
public void setStatus(Object status) {
}
}
return Future.succeededFuture(new Foo());
}
};
}
use of io.strimzi.operator.common.operator.resource.AbstractWatchableStatusedResourceOperator in project strimzi-kafka-operator by strimzi.
the class OperatorMetricsTest method testReconcileAll.
@Test
public void testReconcileAll(VertxTestContext context) {
MetricsProvider metrics = createCleanMetricsProvider();
Set<NamespaceAndName> resources = new HashSet<>(3);
resources.add(new NamespaceAndName("my-namespace", "avfc"));
resources.add(new NamespaceAndName("my-namespace", "vtid"));
resources.add(new NamespaceAndName("my-namespace", "utv"));
AbstractWatchableStatusedResourceOperator resourceOperator = resourceOperatorWithExistingResourceWithoutSelectorLabel();
AbstractOperator operator = new ReconcileAllMockOperator(vertx, "TestResource", resourceOperator, metrics, null);
Promise<Void> reconcileAllPromise = Promise.promise();
((ReconcileAllMockOperator) operator).setResources(resources);
operator.reconcileAll("test", "my-namespace", reconcileAllPromise);
Checkpoint async = context.checkpoint();
reconcileAllPromise.future().onComplete(context.succeeding(v -> context.verify(() -> {
MeterRegistry registry = metrics.meterRegistry();
Tag selectorTag = Tag.of("selector", "");
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.periodical").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.periodical").tag("kind", "TestResource").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").counter().count(), is(3.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").tag("kind", "TestResource").counter().count(), is(3.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").timer().count(), is(3L));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").timer().totalTime(TimeUnit.MILLISECONDS), greaterThan(0.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").tag("kind", "TestResource").tag("namespace", "my-namespace").gauge().value(), is(3.0));
for (NamespaceAndName resource : resources) {
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resource.state").tag("kind", "TestResource").tag("name", resource.getName()).tag("resource-namespace", resource.getNamespace()).gauge().value(), is(1.0));
}
async.flag();
})));
}
use of io.strimzi.operator.common.operator.resource.AbstractWatchableStatusedResourceOperator in project strimzi by strimzi.
the class OperatorMetricsTest method resourceOperatorWithExistingPausedResource.
private AbstractWatchableStatusedResourceOperator resourceOperatorWithExistingPausedResource() {
return new AbstractWatchableStatusedResourceOperator(vertx, null, "TestResource") {
@Override
public Future updateStatusAsync(Reconciliation reconciliation, HasMetadata resource) {
return Future.succeededFuture();
}
@Override
protected MixedOperation operation() {
return null;
}
@Override
public CustomResource get(String namespace, String name) {
@Group("strimzi")
@Version("v1")
class Foo extends MyResource {
@Override
public ObjectMeta getMetadata() {
ObjectMeta md = new ObjectMeta();
md.setAnnotations(singletonMap("strimzi.io/pause-reconciliation", "true"));
return md;
}
@Override
public void setMetadata(ObjectMeta objectMeta) {
}
@Override
public String getKind() {
return "TestResource";
}
@Override
public String getApiVersion() {
return "v1";
}
@Override
public void setApiVersion(String s) {
}
@Override
public Spec getSpec() {
return new Spec() {
};
}
@Override
public void setSpec(Object spec) {
}
@Override
public Status getStatus() {
return null;
}
@Override
public void setStatus(Object status) {
}
}
return new Foo();
}
@Override
public Future getAsync(String namespace, String name) {
@Group("strimzi")
@Version("v1")
class Foo extends MyResource {
@Override
public ObjectMeta getMetadata() {
ObjectMeta md = new ObjectMeta();
md.setAnnotations(singletonMap("strimzi.io/pause-reconciliation", "true"));
return md;
}
@Override
public void setMetadata(ObjectMeta objectMeta) {
}
@Override
public String getKind() {
return "TestResource";
}
@Override
public String getApiVersion() {
return "v1";
}
@Override
public void setApiVersion(String s) {
}
@Override
public Spec getSpec() {
return new Spec() {
};
}
@Override
public void setSpec(Object spec) {
}
@Override
public Status getStatus() {
return null;
}
@Override
public void setStatus(Object status) {
}
}
return Future.succeededFuture(new Foo());
}
};
}
use of io.strimzi.operator.common.operator.resource.AbstractWatchableStatusedResourceOperator in project strimzi by strimzi.
the class OperatorMetricsTest method testReconcileAllOverMultipleNamespaces.
@Test
public void testReconcileAllOverMultipleNamespaces(VertxTestContext context) {
MetricsProvider metrics = createCleanMetricsProvider();
Set<NamespaceAndName> resources = new HashSet<>(3);
resources.add(new NamespaceAndName("my-namespace", "avfc"));
resources.add(new NamespaceAndName("my-namespace", "vtid"));
resources.add(new NamespaceAndName("my-namespace2", "utv"));
Set<NamespaceAndName> updatedResources = new HashSet<>(2);
updatedResources.add(new NamespaceAndName("my-namespace", "avfc"));
updatedResources.add(new NamespaceAndName("my-namespace", "vtid"));
AbstractWatchableStatusedResourceOperator resourceOperator = resourceOperatorWithExistingResourceWithoutSelectorLabel();
AbstractOperator operator = new ReconcileAllMockOperator(vertx, "TestResource", resourceOperator, metrics, null);
Promise<Void> reconcileAllPromise = Promise.promise();
((ReconcileAllMockOperator) operator).setResources(resources);
operator.reconcileAll("test", "*", reconcileAllPromise);
Checkpoint async = context.checkpoint();
reconcileAllPromise.future().onComplete(context.succeeding(v -> context.verify(() -> {
MeterRegistry registry = metrics.meterRegistry();
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.periodical").tag("kind", "TestResource").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").tag("namespace", "my-namespace").counter().count(), is(2.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").tag("namespace", "my-namespace2").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").tag("kind", "TestResource").tag("namespace", "my-namespace").counter().count(), is(2.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").tag("kind", "TestResource").tag("namespace", "my-namespace2").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace").timer().count(), is(2L));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace2").timer().count(), is(1L));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace").timer().totalTime(TimeUnit.MILLISECONDS), greaterThan(0.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace2").timer().totalTime(TimeUnit.MILLISECONDS), greaterThan(0.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").tag("kind", "TestResource").tag("namespace", "my-namespace").gauge().value(), is(2.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").tag("kind", "TestResource").tag("namespace", "my-namespace2").gauge().value(), is(1.0));
for (NamespaceAndName resource : resources) {
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resource.state").tag("kind", "TestResource").tag("name", resource.getName()).tag("resource-namespace", resource.getNamespace()).gauge().value(), is(1.0));
}
}))).compose(ignore -> {
// Reconcile again with resource in my-namespace2 deleted
Promise<Void> secondReconcileAllPromise = Promise.promise();
((ReconcileAllMockOperator) operator).setResources(updatedResources);
operator.reconcileAll("test", "*", secondReconcileAllPromise);
return secondReconcileAllPromise.future();
}).onComplete(context.succeeding(v -> context.verify(() -> {
MeterRegistry registry = metrics.meterRegistry();
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.periodical").tag("kind", "TestResource").counter().count(), is(2.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").tag("namespace", "my-namespace").counter().count(), is(4.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").tag("namespace", "my-namespace2").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").tag("kind", "TestResource").tag("namespace", "my-namespace").counter().count(), is(4.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.successful").tag("kind", "TestResource").tag("namespace", "my-namespace2").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace").timer().count(), is(4L));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace2").timer().count(), is(1L));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace").timer().totalTime(TimeUnit.MILLISECONDS), greaterThan(0.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.duration").tag("kind", "TestResource").tag("namespace", "my-namespace2").timer().totalTime(TimeUnit.MILLISECONDS), greaterThan(0.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").tag("kind", "TestResource").tag("namespace", "my-namespace").gauge().value(), is(2.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resources").tag("kind", "TestResource").tag("namespace", "my-namespace2").gauge().value(), is(0.0));
for (NamespaceAndName resource : updatedResources) {
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "resource.state").tag("kind", "TestResource").tag("name", resource.getName()).tag("resource-namespace", resource.getNamespace()).gauge().value(), is(1.0));
}
async.flag();
})));
}
use of io.strimzi.operator.common.operator.resource.AbstractWatchableStatusedResourceOperator in project strimzi by strimzi.
the class OperatorMetricsTest method testFailingWithLockReconcile.
@Test
public void testFailingWithLockReconcile(VertxTestContext context) {
MetricsProvider metrics = createCleanMetricsProvider();
AbstractWatchableStatusedResourceOperator resourceOperator = resourceOperatorWithExistingResourceWithoutSelectorLabel();
AbstractOperator operator = new AbstractOperator(vertx, "TestResource", resourceOperator, metrics, null) {
@Override
protected Future createOrUpdate(Reconciliation reconciliation, CustomResource resource) {
return Future.failedFuture(new UnableToAcquireLockException());
}
@Override
public Set<Condition> validate(Reconciliation reconciliation, CustomResource resource) {
// Do nothing
return emptySet();
}
@Override
protected Future<Boolean> delete(Reconciliation reconciliation) {
return null;
}
@Override
protected Status createStatus() {
return new Status() {
};
}
};
Checkpoint async = context.checkpoint();
operator.reconcile(new Reconciliation("test", "TestResource", "my-namespace", "my-resource")).onComplete(context.failing(v -> context.verify(() -> {
MeterRegistry registry = metrics.meterRegistry();
Tag selectorTag = Tag.of("selector", "");
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations").tag("kind", "TestResource").counter().count(), is(1.0));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.locked").meter().getId().getTags().get(2), is(selectorTag));
assertThat(registry.get(AbstractOperator.METRICS_PREFIX + "reconciliations.locked").tag("kind", "TestResource").counter().count(), is(1.0));
async.flag();
})));
}
Aggregations