summaryrefslogtreecommitdiff
path: root/src/test/java/sevenUnits/unit
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/java/sevenUnits/unit')
-rw-r--r--src/test/java/sevenUnits/unit/UnitDatabaseTest.java140
1 files changed, 138 insertions, 2 deletions
diff --git a/src/test/java/sevenUnits/unit/UnitDatabaseTest.java b/src/test/java/sevenUnits/unit/UnitDatabaseTest.java
index ed3b6b5..90c18e6 100644
--- a/src/test/java/sevenUnits/unit/UnitDatabaseTest.java
+++ b/src/test/java/sevenUnits/unit/UnitDatabaseTest.java
@@ -25,11 +25,13 @@ import static org.junit.jupiter.api.Assertions.fail;
import java.io.IOException;
import java.io.InputStream;
import java.util.Arrays;
+import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.NoSuchElementException;
+import java.util.Objects;
import java.util.Set;
import org.junit.jupiter.api.Test;
@@ -47,21 +49,70 @@ import sevenUnits.utils.UncertainDouble;
* @since v0.2.0
*/
class UnitDatabaseTest {
+ private static final class SimpleEntry<K, V> implements Map.Entry<K, V> {
+ private final K key;
+
+ private V value;
+
+ /**
+ *
+ * @since 2021-10-07
+ */
+ public SimpleEntry(K key, V value) {
+ this.key = key;
+ this.value = value;
+ }
+
+ @Override
+ public boolean equals(Object obj) {
+ if (this == obj)
+ return true;
+ if (!(obj instanceof Map.Entry<?, ?>))
+ return false;
+ final Map.Entry<?, ?> other = (Map.Entry<?, ?>) obj;
+ return Objects.equals(this.key, other.getKey())
+ && Objects.equals(this.value, other.getValue());
+ }
+
+ @Override
+ public K getKey() {
+ return this.key;
+ }
+
+ @Override
+ public V getValue() {
+ return this.value;
+ }
+
+ @Override
+ public int hashCode() {
+ return (this.key == null ? 0 : this.key.hashCode())
+ ^ (this.value == null ? 0 : this.value.hashCode());
+ }
+
+ @Override
+ public V setValue(V value) {
+ final V oldValue = this.value;
+ this.value = value;
+ return oldValue;
+ }
+ }
+
// some linear units and one nonlinear
private static final Unit U = Metric.METRE;
private static final Unit V = Metric.KILOGRAM;
- private static final Unit W = Metric.SECOND;
+ private static final Unit W = Metric.SECOND;
// used for testing expressions
// J = U^2 * V / W^2
private static final LinearUnit J = Metric.KILOGRAM
.times(Metric.METRE.toExponent(2))
.dividedBy(Metric.SECOND.toExponent(2));
+
private static final LinearUnit K = Metric.KELVIN;
private static final Unit NONLINEAR = Unit.fromConversionFunctions(
Metric.METRE.getBase(), o -> o + 1, o -> o - 1);
-
// make the prefix values prime so I can tell which multiplications were made
private static final UnitPrefix A = UnitPrefix.valueOf(2)
.withName(NameSymbol.ofName("A"));
@@ -70,9 +121,24 @@ class UnitDatabaseTest {
private static final UnitPrefix C = UnitPrefix.valueOf(5)
.withName(NameSymbol.ofName("C"));
private static final UnitPrefix AB = UnitPrefix.valueOf(7);
+
private static final UnitPrefix BC = UnitPrefix.valueOf(11);
/**
+ * Gets a map entry.
+ *
+ * @param <K> type of key
+ * @param <V> type of value
+ * @param key key in entry
+ * @param value value in entry
+ * @return entry
+ * @since 2021-10-07
+ */
+ private static <K, V> Map.Entry<K, V> entry(K key, V value) {
+ return new SimpleEntry<>(key, value);
+ }
+
+ /**
* Loads the dimensionfile at src/test/resources/[path] to the database
* {@code loadTo}.
*
@@ -132,6 +198,39 @@ class UnitDatabaseTest {
}
/**
+ * Test for {@link UnitDatabase#getUnit}, {@link UnitDatabase#getLinearUnit}
+ * and {@link UnitDatabase#getLinearUnitValue}.
+ *
+ * @since 2021-10-07
+ */
+ @Test
+ public void testGetUnit() {
+ final UnitDatabase database = new UnitDatabase();
+
+ database.addUnit("m", Metric.METRE);
+ database.addUnit("meter", Metric.METRE);
+ database.addUnit("metre", Metric.METRE);
+ database.addUnit("badname", Metric.METRE);
+ database.addUnit("K", Metric.KELVIN);
+ database.addUnit("degC", Metric.CELSIUS);
+
+ // ensure getUnit returns units, regardless of whether the name is one of
+ // the unit's names
+ assertEquals(Metric.METRE, database.getUnit("m"));
+ assertEquals(Metric.METRE, database.getUnit("metre"));
+ assertEquals(Metric.METRE, database.getUnit("meter"));
+ assertEquals(Metric.METRE, database.getUnit("badname"));
+ assertThrows(NoSuchElementException.class,
+ () -> database.getUnit("blabla"));
+
+ assertEquals(Metric.KELVIN, database.getLinearUnit("K"));
+ assertThrows(IllegalArgumentException.class,
+ () -> database.getLinearUnit("degC"));
+ assertEquals(Metric.KELVIN.times(373.15),
+ database.getLinearUnit("degC(100)"));
+ }
+
+ /**
* Confirms that operations that shouldn't function for infinite databases
* throw an {@code IllegalStateException}.
*
@@ -275,6 +374,43 @@ class UnitDatabaseTest {
}
/**
+ * Tests the iterator of the prefixless unit map. These tests are simple, as
+ * the unit map iterator is simple.
+ *
+ * @since 2021-10-07
+ */
+ @Test
+ public void testPrefixedUnitMapIterator() {
+ final UnitDatabase database1 = new UnitDatabase();
+
+ database1.addUnit("U", U);
+ database1.addUnit("V", V);
+ database1.addUnit("W", W);
+
+ final Map<String, Unit> map1 = database1.unitMap();
+ final Iterator<String> keyIterator1 = map1.keySet().iterator();
+ final Iterator<Map.Entry<String, Unit>> entryIterator1 = map1.entrySet()
+ .iterator();
+
+ final Set<String> expectedKeys = Set.of("U", "V", "W");
+ final Set<String> actualKeys = new HashSet<>();
+ while (keyIterator1.hasNext()) {
+ actualKeys.add(keyIterator1.next());
+ }
+ assertEquals(expectedKeys, actualKeys);
+ assertEquals(expectedKeys, map1.keySet());
+
+ final Set<Map.Entry<String, Unit>> expectedEntries = Set.of(entry("U", U),
+ entry("V", V), entry("W", W));
+ final Set<Map.Entry<String, Unit>> actualEntries = new HashSet<>();
+ while (entryIterator1.hasNext()) {
+ actualEntries.add(entryIterator1.next());
+ }
+ assertEquals(expectedEntries, actualEntries);
+ assertEquals(expectedEntries, map1.entrySet());
+ }
+
+ /**
* Test that prefixes correctly apply to units.
*
* @since 2019-04-14