diff --git a/java-client/src/main/java/co/elastic/clients/elasticsearch/_types/query_dsl/BoolQuery.java b/java-client/src/main/java/co/elastic/clients/elasticsearch/_types/query_dsl/BoolQuery.java
index a9774d181..d14992e5c 100644
--- a/java-client/src/main/java/co/elastic/clients/elasticsearch/_types/query_dsl/BoolQuery.java
+++ b/java-client/src/main/java/co/elastic/clients/elasticsearch/_types/query_dsl/BoolQuery.java
@@ -331,6 +331,16 @@ public BoolQuery build() {
return new BoolQuery(this);
}
+
+ /**
+ * Returns true
if this query has at least one should, must, must
+ * not or filter clause.
+ */
+ public boolean hasClauses() {
+ return !(this.must == null || this.must.isEmpty()) || !(this.mustNot == null || this.mustNot.isEmpty())
+ || !(this.should == null || this.should.isEmpty())
+ || !(this.filter == null || this.filter.isEmpty());
+ }
}
// ---------------------------------------------------------------------------------------------
@@ -351,4 +361,12 @@ protected static void setupBoolQueryDeserializer(ObjectDeserializertrue if this query has at least one should, must, must
+ * not or filter clause.
+ */
+ public boolean hasClauses() {
+ return !(this.must == null || this.must.isEmpty()) || !(this.mustNot == null || this.mustNot.isEmpty())
+ || !(this.should == null || this.should.isEmpty()) || !(this.filter == null || this.filter.isEmpty());
+ }
}
diff --git a/java-client/src/test/java/co/elastic/clients/elasticsearch/model/CodeAdditionsTests.java b/java-client/src/test/java/co/elastic/clients/elasticsearch/model/CodeAdditionsTests.java
new file mode 100644
index 000000000..e19ea16a0
--- /dev/null
+++ b/java-client/src/test/java/co/elastic/clients/elasticsearch/model/CodeAdditionsTests.java
@@ -0,0 +1,49 @@
+/*
+ * Licensed to Elasticsearch B.V. under one or more contributor
+ * license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright
+ * ownership. Elasticsearch B.V. 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 co.elastic.clients.elasticsearch.model;
+
+import co.elastic.clients.elasticsearch._types.query_dsl.BoolQuery;
+import co.elastic.clients.elasticsearch._types.query_dsl.QueryBuilders;
+import org.junit.jupiter.api.Assertions;
+import org.junit.jupiter.api.Test;
+
+public class CodeAdditionsTests extends Assertions {
+
+ @Test
+ public void testHasClauses() {
+
+ {
+ BoolQuery.Builder builder = new BoolQuery.Builder();
+ assertFalse(builder.hasClauses());
+
+ BoolQuery query = builder.build();
+ assertFalse(query.hasClauses());
+ }
+
+ {
+ BoolQuery.Builder builder = new BoolQuery.Builder();
+ builder.must(QueryBuilders.matchAll(b -> b));
+ assertTrue(builder.hasClauses());
+
+ BoolQuery query = builder.build();
+ assertTrue(query.hasClauses());
+ }
+ }
+}