Added test for AbstractModule classes.

This commit is contained in:
Erik C. Thauvin 2019-04-07 14:46:19 -07:00
parent 4e26666823
commit e77ccf3211
6 changed files with 76 additions and 10 deletions

View file

@ -123,7 +123,7 @@ public abstract class AbstractModule {
* *
* @return <code>true</code> if the properties are valid, <code>false</code> otherwise. * @return <code>true</code> if the properties are valid, <code>false</code> otherwise.
*/ */
public boolean isValidProperties() { boolean isValidProperties() {
for (final String s : getPropertyKeys()) { for (final String s : getPropertyKeys()) {
if (!Utils.isValidString(properties.get(s))) { if (!Utils.isValidString(properties.get(s))) {
return false; return false;

View file

@ -49,7 +49,7 @@ public class Calc extends AbstractModule {
/** /**
* The Calc command. * The Calc command.
*/ */
public static final String CALC_CMD = "calc"; private static final String CALC_CMD = "calc";
/** /**
* The default constructor. * The default constructor.
@ -64,7 +64,7 @@ public class Calc extends AbstractModule {
* @param query The query. * @param query The query.
* @return The calculation result. * @return The calculation result.
*/ */
public static String calc(final String query) { static String calc(final String query) {
final DecimalFormat decimalFormat = new DecimalFormat("#.##"); final DecimalFormat decimalFormat = new DecimalFormat("#.##");
try { try {

View file

@ -46,15 +46,13 @@ import java.net.UnknownHostException;
* @since 1.0 * @since 1.0
*/ */
public final class Lookup extends AbstractModule { public final class Lookup extends AbstractModule {
/**
* The lookup command.
*/
public static final String LOOKUP_CMD = "lookup";
/** /**
* The whois default host. * The whois default host.
*/ */
public static final String WHOIS_HOST = "whois.arin.net"; static final String WHOIS_HOST = "whois.arin.net";
// The lookup command.
private static final String LOOKUP_CMD = "lookup";
/** /**
* The default constructor * The default constructor
@ -72,7 +70,7 @@ public final class Lookup extends AbstractModule {
*/ */
public static String lookup(final String query) public static String lookup(final String query)
throws UnknownHostException { throws UnknownHostException {
final StringBuilder buffer = new StringBuilder(""); final StringBuilder buffer = new StringBuilder();
final InetAddress[] results = InetAddress.getAllByName(query); final InetAddress[] results = InetAddress.getAllByName(query);
String hostInfo; String hostInfo;

View file

@ -0,0 +1,58 @@
/*
* AbstractModuleTest.java
*
* Copyright (c) 2004-2019, Erik C. Thauvin (erik@thauvin.net)
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of this project nor the names of its contributors may be
* used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.thauvin.erik.mobibot.modules;
import static org.assertj.core.api.Assertions.assertThat;
/**
* The <code>AbstractModuleTest</code> class.
*
* @author <a href="https://erik.thauvin.net/" target="_blank">Erik C. Thauvin</a>
* @created 2019-04-07
* @since 1.0
*/
final class AbstractModuleTest {
static void testAbstractModule(AbstractModule module) {
final String name = module.getClass().getName();
assertThat(module.isEnabled()).as(name + ": enabled").isTrue();
assertThat(module.getCommands().size()).as(name + ": commands > 0").isGreaterThan(0);
if (!module.hasProperties()) {
assertThat(module.getPropertyKeys().size()).as(name + ": no properties").isEqualTo(0);
module.setProperty("test", "test");
module.setProperty("", "invalid");
}
assertThat(module.getPropertyKeys().size()).as(name + ": properties > 0").isGreaterThan(0);
assertThat(module.isValidProperties()).as(name + ": isValidProperties()").isTrue();
module.setProperty("invalid", "");
assertThat(module.isValidProperties()).as(name + ": invalid properties").isFalse();
}
}

View file

@ -43,6 +43,11 @@ import static org.assertj.core.api.Assertions.assertThat;
* @since 1.0 * @since 1.0
*/ */
public class CalcTest { public class CalcTest {
@Test
public void testCalcImpl() {
AbstractModuleTest.testAbstractModule(new Calc());
}
@Test @Test
public void testCalc() { public void testCalc() {
assertThat(Calc.calc("1 + 1")).as("calc(1+1)").isEqualTo("1+1 = 2"); assertThat(Calc.calc("1 + 1")).as("calc(1+1)").isEqualTo("1+1 = 2");

View file

@ -45,6 +45,11 @@ import static org.assertj.core.api.Assertions.assertThat;
* @since 1.0 * @since 1.0
*/ */
public class LookupTest { public class LookupTest {
@Test
public void testLookupImpl() {
AbstractModuleTest.testAbstractModule(new Lookup());
}
@Test @Test
public void testLookup() throws Exception { public void testLookup() throws Exception {
final String result = Lookup.lookup("erik.thauvin.net"); final String result = Lookup.lookup("erik.thauvin.net");