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());
}
}
}
}
}