From d95317819b2bfbb91fd3b0977c573827e76725be Mon Sep 17 00:00:00 2001 From: Abner Eduardo Ferreira Date: Tue, 12 Oct 2021 18:47:57 +0000 Subject: [PATCH] [FlightSQL] Add missing method for creating bitmask from GetSqlInfo option enum (#148) * Add util method for creating bitmask from multiple protobuf enums for FlightSql GetSqlInfo enum * Add test cases for utility method for creating bitmask from protobuf options * Make changes regarding to reviews Co-authored-by: Rafael Telles --- .../sql/util/SqlInfoOptionsUtilsTest.java | 102 ------------------ 1 file changed, 102 deletions(-) delete mode 100644 java/flight/flight-sql/src/test/java/org/apache/arrow/flight/sql/util/SqlInfoOptionsUtilsTest.java diff --git a/java/flight/flight-sql/src/test/java/org/apache/arrow/flight/sql/util/SqlInfoOptionsUtilsTest.java b/java/flight/flight-sql/src/test/java/org/apache/arrow/flight/sql/util/SqlInfoOptionsUtilsTest.java deleted file mode 100644 index 30f63fba49002..0000000000000 --- a/java/flight/flight-sql/src/test/java/org/apache/arrow/flight/sql/util/SqlInfoOptionsUtilsTest.java +++ /dev/null @@ -1,102 +0,0 @@ -/* - * 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.arrow.flight.sql.util; - -import static java.util.stream.Collectors.toCollection; -import static org.apache.arrow.flight.sql.util.SqlInfoOptionsUtils.doesBitmaskTranslateToEnum; -import static org.hamcrest.CoreMatchers.is; - -import java.util.Arrays; -import java.util.EnumSet; -import java.util.List; -import java.util.Set; - -import org.junit.Before; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.junit.runner.RunWith; -import org.junit.runners.Parameterized; -import org.junit.runners.Parameterized.Parameter; -import org.junit.runners.Parameterized.Parameters; - -import com.google.protobuf.Descriptors.EnumDescriptor; -import com.google.protobuf.Descriptors.EnumValueDescriptor; -import com.google.protobuf.ProtocolMessageEnum; - -@RunWith(Parameterized.class) -public final class SqlInfoOptionsUtilsTest { - - @Parameter - public long bitmask; - @Parameter(value = 1) - public Set messageEnums; - public Set expectedOutcome; - @Rule - public final ErrorCollector collector = new ErrorCollector(); - - @Before - public void setUp() { - expectedOutcome = - Arrays.stream(TestOption.values()) - .filter(enumInstance -> doesBitmaskTranslateToEnum(enumInstance, bitmask)) - .collect(toCollection(() -> EnumSet.noneOf(TestOption.class))); - } - - @Parameters - public static List provideParameters() { - return Arrays.asList(new Object[][]{ - {0, EnumSet.noneOf(TestOption.class)}, - {1, EnumSet.of(TestOption.OPTION_A)}, - {0b10, EnumSet.of(TestOption.OPTION_B)}, - {0b11, EnumSet.of(TestOption.OPTION_A, TestOption.OPTION_B)}, - {0b100, EnumSet.of(TestOption.OPTION_C)}, - {0b101, EnumSet.of(TestOption.OPTION_A, TestOption.OPTION_C)}, - {0b110, EnumSet.of(TestOption.OPTION_B, TestOption.OPTION_C)}, - {0b111, EnumSet.allOf(TestOption.class)}, - }); - } - - @Test - public void testShouldFilterOutEnumsBasedOnBitmask() { - collector.checkThat(messageEnums, is(expectedOutcome)); - } - - private enum TestOption implements ProtocolMessageEnum { - OPTION_A, OPTION_B, OPTION_C; - - @Override - public int getNumber() { - return ordinal(); - } - - @Override - public EnumValueDescriptor getValueDescriptor() { - throw getUnsupportedException(); - } - - @Override - public EnumDescriptor getDescriptorForType() { - throw getUnsupportedException(); - } - - private UnsupportedOperationException getUnsupportedException() { - return new UnsupportedOperationException("Unimplemented method is irrelevant for the scope of this test."); - } - } -}