From defa9111438ff0a70e084847feb811b113ed5037 Mon Sep 17 00:00:00 2001 From: Justin Bertram Date: Wed, 4 Sep 2024 12:19:50 -0500 Subject: [PATCH] ARTEMIS-5028 use a default filter when none is specified for mngmnt ops This is a small usability improvement for management whereby invocations of some operations no longer require JSON boilerplate. It impacts the following operations on the ActiveMQServerControl: - listConnections - listSessions - listAddresses - listQueues - listConsumers - listProducers --- .../impl/view/ActiveMQAbstractView.java | 10 +- .../core/management/impl/view/ViewTest.java | 108 ++++++++++++++++++ 2 files changed, 117 insertions(+), 1 deletion(-) create mode 100644 artemis-server/src/test/java/org/apache/activemq/artemis/core/management/impl/view/ViewTest.java diff --git a/artemis-server/src/main/java/org/apache/activemq/artemis/core/management/impl/view/ActiveMQAbstractView.java b/artemis-server/src/main/java/org/apache/activemq/artemis/core/management/impl/view/ActiveMQAbstractView.java index 9522a28654..1491849d6a 100644 --- a/artemis-server/src/main/java/org/apache/activemq/artemis/core/management/impl/view/ActiveMQAbstractView.java +++ b/artemis-server/src/main/java/org/apache/activemq/artemis/core/management/impl/view/ActiveMQAbstractView.java @@ -24,6 +24,7 @@ import java.util.Collection; import java.util.Collections; import java.util.Comparator; import java.util.List; +import java.util.Map; import java.util.function.Predicate; import java.util.stream.Collectors; @@ -43,6 +44,8 @@ public abstract class ActiveMQAbstractView { private static final String SORT_COLUMN = "sortColumn"; + private static final JsonObject DEFAULT_FILTER = JsonUtil.toJsonObject(Map.of(FILTER_FIELD, "", FILTER_OPERATION, "", FILTER_VALUE, "")); + protected Collection collection; protected ActiveMQFilterPredicate predicate; @@ -119,7 +122,12 @@ public abstract class ActiveMQAbstractView { abstract Object getField(T t, String fieldName); public void setOptions(String options) { - JsonObject json = JsonUtil.readJsonObject(options); + JsonObject json; + if (options == null || options.isBlank()) { + json = DEFAULT_FILTER; + } else { + json = JsonUtil.readJsonObject(options); + } if (predicate != null) { predicate.setField(json.getString(FILTER_FIELD)); predicate.setOperation(json.getString(FILTER_OPERATION)); diff --git a/artemis-server/src/test/java/org/apache/activemq/artemis/core/management/impl/view/ViewTest.java b/artemis-server/src/test/java/org/apache/activemq/artemis/core/management/impl/view/ViewTest.java new file mode 100644 index 0000000000..10b7e2584b --- /dev/null +++ b/artemis-server/src/test/java/org/apache/activemq/artemis/core/management/impl/view/ViewTest.java @@ -0,0 +1,108 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.activemq.artemis.core.management.impl.view; + +import org.apache.activemq.artemis.core.server.ActiveMQServer; +import org.junit.jupiter.api.Test; +import org.mockito.Mockito; + +public class ViewTest { + + @Test + public void testDefaultConnectionViewNullOptions() { + ConnectionView connectionView = new ConnectionView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + connectionView.setOptions(null); + } + + @Test + public void testDefaultConnectionViewEmptyOptions() { + ConnectionView connectionView = new ConnectionView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + connectionView.setOptions(""); + } + + @Test + public void testDefaultSessionViewNullOptions() { + SessionView sessionView = new SessionView(); + // sanity check to ensure this doesn't just blow up + sessionView.setOptions(null); + } + + @Test + public void testDefaultSessionViewEmptyOptions() { + SessionView sessionView = new SessionView(); + // sanity check to ensure this doesn't just blow up + sessionView.setOptions(""); + } + + @Test + public void testDefaultAddressViewNullOptions() { + AddressView addressView = new AddressView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + addressView.setOptions(null); + } + + @Test + public void testDefaultAddressViewEmptyOptions() { + AddressView addressView = new AddressView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + addressView.setOptions(""); + } + + @Test + public void testDefaultQueueViewNullOptions() { + QueueView queueView = new QueueView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + queueView.setOptions(null); + } + + @Test + public void testDefaultQueueViewEmptyOptions() { + QueueView queueView = new QueueView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + queueView.setOptions(""); + } + + @Test + public void testDefaultConsumerViewNullOptions() { + ConsumerView consumerView = new ConsumerView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + consumerView.setOptions(null); + } + + @Test + public void testDefaultConsumerViewEmptyOptions() { + ConsumerView consumerView = new ConsumerView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + consumerView.setOptions(""); + } + + @Test + public void testDefaultProducerViewNullOptions() { + ProducerView producerView = new ProducerView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + producerView.setOptions(null); + } + + @Test + public void testDefaultProducerViewEmptyOptions() { + ProducerView producerView = new ProducerView(Mockito.mock(ActiveMQServer.class)); + // sanity check to ensure this doesn't just blow up + producerView.setOptions(""); + } +}