/* * SPDX-License-Identifier: Apache-2.0 * * The OpenSearch Contributors require contributions made to * this file be licensed under the Apache-2.0 license or a * * Modifications Copyright OpenSearch Contributors. See * GitHub history for details. */ /* * Licensed to Elasticsearch under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch 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.opensearch.hadoop.util; import java.util.ArrayList; import java.util.Collections; import java.util.List; import org.opensearch.hadoop.OpenSearchHadoopIllegalArgumentException; import org.junit.Test; import static org.hamcrest.Matchers.greaterThanOrEqualTo; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertThat; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; public class OpenSearchMajorVersionTest { private static final List TEST_VERSIONS; static { List versions = new ArrayList<>(); versions.add("1.0.0-alpha1"); versions.add("1.0.0-beta2"); versions.add("1.0.0-rc3"); versions.add("1.0.0"); versions.add("1.1.0"); versions.add("1.1.1"); versions.add("1.2.0"); versions.add("1.2.1"); versions.add("1.2.2"); versions.add("1.2.3"); versions.add("1.2.4"); versions.add("1.2.5"); versions.add("1.3.0"); versions.add("1.3.1"); versions.add("1.3.2"); versions.add("1.3.3"); versions.add("1.3.4"); versions.add("1.3.5"); versions.add("1.3.6"); versions.add("1.3.7"); versions.add("1.3.8"); versions.add("2.0.0-alpha1"); versions.add("2.0.0-beta2"); versions.add("2.0.0-rc3"); versions.add("2.0.0"); versions.add("2.1.0"); versions.add("2.1.1"); versions.add("2.2.0"); versions.add("2.2.1"); versions.add("2.2.2"); versions.add("2.3.0"); versions.add("2.3.1"); versions.add("2.4.0"); versions.add("2.5.0"); versions.add("2.6.0"); versions.add("3.0.0-alpha1"); versions.add("3.0.0-beta2"); versions.add("3.0.0-rc3"); versions.add("3.0.0"); TEST_VERSIONS = Collections.unmodifiableList(versions); } @Test public void testVersionFromString() { for (int i = 0; i < TEST_VERSIONS.size(); i++) { String testVersion = TEST_VERSIONS.get(i); OpenSearchMajorVersion version = OpenSearchMajorVersion.parse(testVersion); OpenSearchMajorVersion version2 = OpenSearchMajorVersion.parse(testVersion); assertTrue(version.onOrAfter(version)); assertTrue(version.equals(version)); assertTrue(version.equals(version2)); for (int j = i + 1; j < TEST_VERSIONS.size(); j++) { String laterTestVersion = TEST_VERSIONS.get(j); OpenSearchMajorVersion compareVersion = OpenSearchMajorVersion.parse(laterTestVersion); assertTrue(compareVersion.onOrAfter(version)); assertFalse(compareVersion.equals(version)); } for (int j = i - 1; j >= 0; j--) { String earlierTestVersion = TEST_VERSIONS.get(j); OpenSearchMajorVersion cmp_version = OpenSearchMajorVersion.parse(earlierTestVersion); assertTrue(cmp_version.onOrBefore(version)); assertFalse(cmp_version.equals(version)); } } } @Test public void testMinorVersionParsing() { for (String testVersion : TEST_VERSIONS) { OpenSearchMajorVersion version = OpenSearchMajorVersion.parse(testVersion); int minorVersion = version.parseMinorVersion(testVersion); assertThat(minorVersion, greaterThanOrEqualTo(0)); } try { OpenSearchMajorVersion.V_3_X.parseMinorVersion("6.0.0"); fail("Invalid major version"); } catch (OpenSearchHadoopIllegalArgumentException e) { assertEquals("Invalid version string for major version; Received [6.0.0] for major version [3.x]", e.getMessage()); } try { OpenSearchMajorVersion.V_3_X.parseMinorVersion("3."); fail("Invalid major version"); } catch (OpenSearchHadoopIllegalArgumentException e) { assertEquals("Could not parse OpenSearch minor version [3.]. Invalid version format.", e.getMessage()); } try { OpenSearchMajorVersion.V_3_X.parseMinorVersion("3.4-abcd.4"); fail("Invalid major version"); } catch (OpenSearchHadoopIllegalArgumentException e) { assertEquals("Could not parse OpenSearch minor version [3.4-abcd.4]. Non-numeric minor version [4-abcd].", e.getMessage()); } } }