TestECSchema.java

/**
 * 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.hadoop.io.erasurecode;

import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Timeout;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;

import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;

@Timeout(300)
public class TestECSchema {

  @Test
  public void testGoodSchema() {
    int numDataUnits = 6;
    int numParityUnits = 3;
    String codec = "rs";
    String extraOption = "extraOption";
    String extraOptionValue = "extraOptionValue";

    Map<String, String> options = new HashMap<String, String>();
    options.put(ECSchema.NUM_DATA_UNITS_KEY, String.valueOf(numDataUnits));
    options.put(ECSchema.NUM_PARITY_UNITS_KEY, String.valueOf(numParityUnits));
    options.put(ECSchema.CODEC_NAME_KEY, codec);
    options.put(extraOption, extraOptionValue);

    ECSchema schema = new ECSchema(options);
    System.out.println(schema.toString());

    assertEquals(numDataUnits, schema.getNumDataUnits());
    assertEquals(numParityUnits, schema.getNumParityUnits());
    assertEquals(codec, schema.getCodecName());
    assertEquals(extraOptionValue, schema.getExtraOptions().get(extraOption));

    Map<String, String> extraMap = new TreeMap<>();
    extraMap.put(extraOption, extraOptionValue);
    ECSchema sameSchema = new ECSchema(codec, numDataUnits, numParityUnits,
        extraMap);
    assertEquals(sameSchema, schema, "Different constructors not equal");
  }

  @Test
  public void testEqualsAndHashCode() {
    Map<String, String> extraMap = new TreeMap<>();
    extraMap.put("key", "value");

    ECSchema[] schemas = new ECSchema[]{
        new ECSchema("one", 1, 2, null),
        new ECSchema("two", 1, 2, null),
        new ECSchema("one", 2, 2, null),
        new ECSchema("one", 1, 1, null),
        new ECSchema("one", 1, 2, extraMap),
    };

    for (int i = 0; i < schemas.length; i++) {
      final ECSchema ei = schemas[i];
      // Check identity
      ECSchema temp = new ECSchema(ei.getCodecName(), ei.getNumDataUnits(),
          ei.getNumParityUnits(), ei.getExtraOptions());
      assertEquals(ei, temp);
      assertEquals(ei.hashCode(), temp.hashCode());
      // Check against other schemas
      for (int j = 0; j < schemas.length; j++) {
        final ECSchema ej = schemas[j];
        if (i == j) {
          assertEquals(ei, ej);
          assertEquals(ei.hashCode(), ej.hashCode());
        } else {
          assertNotEquals(ei, ej);
          assertNotEquals(ei, ej.hashCode());
        }
      }
    }
  }
}