/** * Copyright (C) 2018 Adrien Hopkins * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ package test.java; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.unitConverter.dimension.StandardDimensions.AREA; import static org.unitConverter.dimension.StandardDimensions.ENERGY; import static org.unitConverter.dimension.StandardDimensions.LENGTH; import static org.unitConverter.dimension.StandardDimensions.MASS; import static org.unitConverter.dimension.StandardDimensions.MASS_DENSITY; import static org.unitConverter.dimension.StandardDimensions.QUANTITY; import static org.unitConverter.dimension.StandardDimensions.TIME; import static org.unitConverter.dimension.StandardDimensions.VOLUME; import org.junit.Test; import org.unitConverter.dimension.SIBaseDimension; import org.unitConverter.dimension.UnitDimension; /** * Tests for {@link UnitDimension}. This is NOT part of this program's public API. * * @author Adrien Hopkins * @since 2018-12-12 * @since v0.1.0 */ public class UnitDimensionTest { /** * Tests {@link UnitDimension#equals} * * @since 2018-12-12 * @since v0.1.0 */ @Test public void testEquals() { assertEquals(LENGTH, LENGTH); assertFalse(LENGTH.equals(QUANTITY)); } /** * Tests {@code UnitDimension}'s exponentiation * * @since 2019-01-15 * @since v0.1.0 */ @Test public void testExponents() { assertEquals(1, LENGTH.getExponent(SIBaseDimension.LENGTH)); assertEquals(3, VOLUME.getExponent(SIBaseDimension.LENGTH)); } /** * Tests {@code UnitDimension}'s multiplication and division. * * @since 2018-12-12 * @since v0.1.0 */ @Test public void testMultiplicationAndDivision() { assertEquals(AREA, LENGTH.times(LENGTH)); assertEquals(MASS_DENSITY, MASS.dividedBy(VOLUME)); assertEquals(ENERGY, AREA.times(MASS).dividedBy(TIME).dividedBy(TIME)); assertEquals(LENGTH, LENGTH.times(TIME).dividedBy(TIME)); } }