/* ==================================================================== * Limited Evaluation License: * * This software is open source, but licensed. The license with this package * is an evaluation license, which may not be used for productive systems. If * you want a full license, please contact us. * * The exclusive owner of this work is the OpenRate project. * This work, including all associated documents and components * is Copyright of the OpenRate project 2006-2015. * * The following restrictions apply unless they are expressly relaxed in a * contractual agreement between the license holder or one of its officially * assigned agents and you or your organisation: * * 1) This work may not be disclosed, either in full or in part, in any form * electronic or physical, to any third party. This includes both in the * form of source code and compiled modules. * 2) This work contains trade secrets in the form of architecture, algorithms * methods and technologies. These trade secrets may not be disclosed to * third parties in any form, either directly or in summary or paraphrased * form, nor may these trade secrets be used to construct products of a * similar or competing nature either by you or third parties. * 3) This work may not be included in full or in part in any application. * 4) You may not remove or alter any proprietary legends or notices contained * in or on this work. * 5) This software may not be reverse-engineered or otherwise decompiled, if * you received this work in a compiled form. * 6) This work is licensed, not sold. Possession of this software does not * imply or grant any right to you. * 7) You agree to disclose any changes to this work to the copyright holder * and that the copyright holder may include any such changes at its own * discretion into the work * 8) You agree not to derive other works from the trade secrets in this work, * and that any such derivation may make you liable to pay damages to the * copyright holder * 9) You agree to use this software exclusively for evaluation purposes, and * that you shall not use this software to derive commercial profit or * support your business or personal activities. * * This software is provided "as is" and any expressed or impled warranties, * including, but not limited to, the impled warranties of merchantability * and fitness for a particular purpose are disclaimed. In no event shall * The OpenRate Project or its officially assigned agents be liable to 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 any business interruption) however caused * and on 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. * This software contains portions by The Apache Software Foundation, Robert * Half International. * ==================================================================== */ package OpenRate.process; import OpenRate.OpenRate; import OpenRate.exception.InitializationException; import OpenRate.exception.ProcessingException; import OpenRate.record.IRecord; import TestUtils.FrameworkUtils; import java.net.URL; import java.util.ArrayList; import org.junit.*; /** * Unit test for AbstractRegexMatch using the file based interface. * * @author tgdspia1 */ public class AbstractRegexMatchFileTest { private static URL FQConfigFileName; private static AbstractRegexMatch instance; // Used for logging and exception handling private static String message; private static OpenRate appl; @BeforeClass public static void setUpClass() throws Exception { FQConfigFileName = new URL("File:src/test/resources/TestRegexFile.properties.xml"); // Set up the OpenRate internal logger - this is normally done by app startup appl = OpenRate.getApplicationInstance(); // Load the properties into the OpenRate object FrameworkUtils.loadProperties(FQConfigFileName); // Get the loggers FrameworkUtils.startupLoggers(); // Get the transaction manager FrameworkUtils.startupTransactionManager(); // Get the caches that we are using FrameworkUtils.startupCaches(); } @AfterClass public static void tearDownClass() { // Deallocate OpenRate.getApplicationInstance().finaliseApplication(); } @Before public void setUp() { getInstance(); } @After public void tearDown() { releaseInstance(); } /** * Test of getRegexMatch method, of class AbstractRegexMatch. */ @Test public void testGetRegexMatch() { String result; String expResult; String Group; System.out.println("getRegexMatch File"); String[] searchParameters = new String[1]; // Simple good case Group = "DefaultMap"; searchParameters[0] = "023456"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK2"; Assert.assertEquals(expResult, result); // Simple Assert.fail case because of non matching regex Group = "DefaultMap"; searchParameters[0] = "1"; result = instance.getRegexMatch(Group, searchParameters); expResult = "NOMATCH"; Assert.assertEquals(expResult, result); // Simple Assert.fail case because of non matching regex Group = "DefaultNOMAP"; searchParameters[0] = "0"; result = instance.getRegexMatch(Group, searchParameters); expResult = "NOMATCH"; Assert.assertEquals(expResult, result); // Simple good case with lower rank Group = "DefaultMap"; searchParameters[0] = "0123456"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK1"; Assert.assertEquals(expResult, result); } /** * Test of getRegexMatch method, of class AbstractRegexMatch. */ @Test public void testGetRegexMatchNumericalComparison() { String result; String expResult; String Group; System.out.println("getRegexMatch (Numerical Comparison) File"); String[] searchParameters = new String[2]; // Simple good case Group = "NumericalMap"; searchParameters[0] = "2"; searchParameters[1] = "2"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK1"; Assert.assertEquals(expResult, result); // Simple good case with a double value searchParameters[0] = "1.00001"; searchParameters[1] = "2"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK1"; Assert.assertEquals(expResult, result); // Simple good case with a double value searchParameters[0] = "0.8"; searchParameters[1] = "2"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK2"; Assert.assertEquals(expResult, result); // Simple bad case with a double value searchParameters[0] = "0.8"; searchParameters[1] = "3"; result = instance.getRegexMatch(Group, searchParameters); expResult = "NOMATCH"; Assert.assertEquals(expResult, result); // Simple good case with a double value - this is there to check if we are rounding anywhere searchParameters[0] = "9.2"; searchParameters[1] = "9.2"; result = instance.getRegexMatch(Group, searchParameters); expResult = "OK3"; Assert.assertEquals(expResult, result); } /** * Test of getRegexMatchWithChildData method, of class AbstractRegexMatch. */ @Test public void testGetRegexMatchWithChildData() { ArrayList<String> result; ArrayList<String> expResult = new ArrayList<>(); String Group; System.out.println("getRegexMatchWithChildData File"); String[] searchParameters = new String[1]; // Simple good case Group = "DefaultMap"; searchParameters[0] = "023456"; result = instance.getRegexMatchWithChildData(Group, searchParameters); expResult.clear(); expResult.add("OK2"); expResult.add("OUT2"); Assert.assertEquals(expResult, result); // Simple Assert.fail case because of non matching regex Group = "DefaultMap"; searchParameters[0] = "1"; result = instance.getRegexMatchWithChildData(Group, searchParameters); expResult.clear(); expResult.add("NOMATCH"); Assert.assertEquals(expResult, result); // Simple Assert.fail case because of non matching regex Group = "DefaultNOMAP"; searchParameters[0] = "0"; result = instance.getRegexMatchWithChildData(Group, searchParameters); expResult.clear(); expResult.add("NOMATCH"); Assert.assertEquals(expResult, result); // Simple good case with lower rank Group = "DefaultMap"; searchParameters[0] = "0123456"; result = instance.getRegexMatchWithChildData(Group, searchParameters); expResult.clear(); expResult.add("OK1"); expResult.add("OUT2"); Assert.assertEquals(expResult, result); } /** * Test of getAllEntries method, of class AbstractRegexMatch. */ @Test public void testGetAllEntries() { System.out.println("getAllEntries File"); ArrayList<String> result; String expResult; String Group; int resultCount; String[] searchParameters = new String[1]; // Simple good case Group = "DefaultMap"; searchParameters[0] = "0123456"; result = instance.getAllEntries(Group, searchParameters); resultCount = 2; Assert.assertEquals(resultCount, result.size()); expResult = "OK1"; Assert.assertEquals(expResult, result.get(0)); expResult = "OK2"; Assert.assertEquals(expResult, result.get(1)); // Simple Assert.fail case because of non matching regex Group = "DefaultMap"; searchParameters[0] = "1"; result = instance.getAllEntries(Group, searchParameters); resultCount = 0; Assert.assertEquals(resultCount, result.size()); } /** * Test of isValidRegexMatchResult method, of class AbstractRegexMatch. */ @Test public void testIsValidRegexMatchResult_ArrayList() { ArrayList<String> resultToCheck; String Group; String expResultMatch; boolean expResult; boolean result; System.out.println("isValidRegexMatchResult File"); String[] searchParameters = new String[1]; // Simple Assert.fail case because of non matching regex Group = "DefaultNOMAP"; searchParameters[0] = "0"; resultToCheck = instance.getRegexMatchWithChildData(Group, searchParameters); expResultMatch = "NOMATCH"; Assert.assertEquals(expResultMatch, resultToCheck.get(0)); // Check that we have the result we need expResult = false; result = instance.isValidRegexMatchResult(resultToCheck); Assert.assertEquals(expResult, result); // Simple pass case Group = "DefaultMap"; searchParameters[0] = "0"; resultToCheck = instance.getRegexMatchWithChildData(Group, searchParameters); expResultMatch = "OK2"; Assert.assertEquals(expResultMatch, resultToCheck.get(0)); // Check that we have the result we need expResult = true; result = instance.isValidRegexMatchResult(resultToCheck); Assert.assertEquals(expResult, result); } /** * Test of isValidRegexMatchResult method, of class AbstractRegexMatch. */ @Test public void testIsValidRegexMatchResult_String() { String resultToCheck; String Group; String expResultMatch; boolean expResult; boolean result; System.out.println("isValidRegexMatchResult File"); String[] searchParameters = new String[1]; // Simple Assert.fail case because of non matching regex Group = "DefaultNOMAP"; searchParameters[0] = "0"; resultToCheck = instance.getRegexMatch(Group, searchParameters); expResultMatch = "NOMATCH"; Assert.assertEquals(expResultMatch, resultToCheck); // Check that we have the result we need expResult = false; result = instance.isValidRegexMatchResult(resultToCheck); Assert.assertEquals(expResult, result); // Simple pass case Group = "DefaultMap"; searchParameters[0] = "0"; resultToCheck = instance.getRegexMatch(Group, searchParameters); expResultMatch = "OK2"; Assert.assertEquals(expResultMatch, resultToCheck); // Check that we have the result we need expResult = true; result = instance.isValidRegexMatchResult(resultToCheck); Assert.assertEquals(expResult, result); } public class AbstractRegexMatchImpl extends AbstractRegexMatch { /** * Override the unused event handling routines. * * @param r input record * @return return record * @throws ProcessingException */ @Override public IRecord procValidRecord(IRecord r) throws ProcessingException { return r; } /** * Override the unused event handling routines. * * @param r input record * @return return record * @throws ProcessingException */ @Override public IRecord procErrorRecord(IRecord r) throws ProcessingException { return r; } } /** * Method to get an instance of the implementation. Done this way to allow * tests to be executed individually. * * @throws InitializationException */ private void getInstance() { if (instance == null) { // Get an initialise the cache instance = new AbstractRegexMatchFileTest.AbstractRegexMatchImpl(); try { // Get the instance instance.init("DBTestPipe", "AbstractRegexMatchTest"); } catch (InitializationException ex) { org.junit.Assert.fail(); } } else { org.junit.Assert.fail("Instance already allocated"); } } /** * Method to release an instance of the implementation. */ private void releaseInstance() { instance = null; } }