All Downloads are FREE. Search and download functionalities are using the official Maven repository.

progress.Consultingwerk.Assertion.Assert.cls Maven / Gradle / Ivy

There is a newer version: 229
Show newest version
/**********************************************************************
 * Copyright (C) 2006-2013 by Consultingwerk Ltd. ("CW") -            *
 * www.consultingwerk.de and other contributors as listed             *
 * below.  All Rights Reserved.                                       *
 *                                                                    *
 *  Software is distributed on an "AS IS", WITHOUT WARRANTY OF ANY    *
 *   KIND, either express or implied.                                 *
 *                                                                    *
 *  Contributors:                                                     *
 *                                                                    *
 **********************************************************************/ 
/*------------------------------------------------------------------------
    File        : Assert
    Purpose     : Provides generic methods for validation of ABL primitive values
    Syntax      : 
    Description : Routines in this class typically raise an error condition
                  when the condition is not met.
    Author(s)   : Mike Fechner / Consultingwerk Ltd.
    Created     : Fri Apr 27 23:31:14 CEST 2012
    Notes       : 
  ----------------------------------------------------------------------*/

ROUTINE-LEVEL ON ERROR UNDO, THROW.

{Consultingwerk/products.i}

USING Consultingwerk.Assertion.*  FROM PROPATH . 
USING Consultingwerk.Exceptions.* FROM PROPATH . 
USING Progress.Lang.*             FROM PROPATH .

CLASS Consultingwerk.Assertion.Assert: 
    
    /*------------------------------------------------------------------------------
        Purpose: Disallow instance creation                                                                        
        Notes:                                                                        
    ------------------------------------------------------------------------------*/
    CONSTRUCTOR PRIVATE Assert ():
        SUPER ().
        
    END CONSTRUCTOR.

	/*------------------------------------------------------------------------------
		Purpose: Validates that two character values are equal 																	  
		Notes:   
		Throws:  Consultingwerk.Assertion.AssertException  											
		@param pcValue1 The first value to compare
		@param pcValue2 The second value to compare						  
	------------------------------------------------------------------------------*/
	METHOD PUBLIC STATIC VOID Equals (pcValue1 AS CHARACTER,
	                                  pcValue2 AS CHARACTER):
		
		IF pcValue1 <> pcValue2 THEN 
		    UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
        		                                         QUOTER (pcValue1), 
        		                                         QUOTER (pcValue2)), 0) .

	END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates that two decimal values are equal                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param pdeValue1 The first value to compare
        @param pdeValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID Equals (pdeValue1 AS DECIMAL,
                                      pdeValue2 AS DECIMAL):
        
        IF pdeValue1 <> pdeValue2 THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (pdeValue1), 
                                                         QUOTER (pdeValue2)), 0) .

    END METHOD.
    
    /*------------------------------------------------------------------------------
        Purpose: Validates that two integer values are equal                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param piValue1 The first value to compare
        @param piValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID Equals (piValue1 AS INT64,
                                      piValue2 AS INT64):
        
        IF piValue1 <> piValue2 THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (piValue1), 
                                                         QUOTER (piValue2)), 0) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates that handles are equal                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param phValue1 The first value to compare
        @param phValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID Equals (phValue1 AS HANDLE,
                                      phValue2 AS HANDLE):
        
        IF phValue1 <> phValue2 THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (phValue1), 
                                                         QUOTER (phValue2)), 0) .

    END METHOD.
        
    /*------------------------------------------------------------------------------
        Purpose: Validates that two logical values are equal                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param plValue1 The first value to compare
        @param plValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID Equals (plValue1 AS LOGICAL,
                                      plValue2 AS LOGICAL):
        
        IF plValue1 <> plValue2 THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (plValue1), 
                                                         QUOTER (plValue2)), 0) .

    END METHOD.
        
    /*------------------------------------------------------------------------------
        Purpose: Validates that two longchar values are equal                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param plcValue1 The first value to compare
        @param plcValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID Equals (plcValue1 AS LONGCHAR,
                                      plcValue2 AS LONGCHAR):
        
        IF plcValue1 <> plcValue2 THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (STRING(plcValue1)), 
                                                         QUOTER (STRING(plcValue2))), 0) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates that two character values are equal based on a raw compare                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param pcValue1 The first value to compare
        @param pcValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID EqualsRaw (pcValue1 AS CHARACTER,
                                         pcValue2 AS CHARACTER):
        
        IF COMPARE (pcValue1, "NE":U, pcValue2, "RAW":U) THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (pcValue1), 
                                                         QUOTER (pcValue2)), 0) .

    END METHOD.
    
    /*------------------------------------------------------------------------------
        Purpose: Validates that two longchar values are equal based on a raw compare                                                                    
        Notes:                                              
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param plcValue1 The first value to compare
        @param plcValue2 The second value to compare                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID EqualsRaw (plcValue1 AS LONGCHAR,
                                         plcValue2 AS LONGCHAR):
        
        IF COMPARE (plcValue1, "NE":U, plcValue2, "RAW":U) THEN 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 does not equal &2"{&TRAN}, 
                                                         QUOTER (plcValue1), 
                                                         QUOTER (plcValue2)), 0) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates that a LOGICAL Value is FALSE 
        Notes:   
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param plValue The logical value to validate
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID EqualsFalse (plValue AS LOGICAL):
        
        IF plValue = FALSE THEN . 
        ELSE 
            UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 is not FALSE"{&TRAN}, 
                                                         QUOTER (plValue)), 0) .
    END METHOD .
                
    /*------------------------------------------------------------------------------
        Purpose: Validates that a LOGICAL Value is TRUE 
        Notes:   
        Throws:  Consultingwerk.Assertion.AssertException                                           
        @param plValue The logical value to validate
    ------------------------------------------------------------------------------*/
	METHOD PUBLIC STATIC VOID EqualsTrue (plValue AS LOGICAL):
		
		IF plValue = TRUE THEN . 
		ELSE 
		    UNDO, THROW NEW AssertException (SUBSTITUTE ("Value &1 is not TRUE"{&TRAN}, 
                                                         QUOTER (plValue)), 0) .
	END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Integer value so that it is greater than 0   
        Notes:  
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param piValue The Integer value to validate                                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID GreaterThanZero (piValue AS INTEGER):
        
        IF piValue > 0 THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING (piValue)) .

    END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Integer value so that it is greater than 0   
        Notes:   
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param piValue The Integer value to validate                                       
        @param pcValueDesc The optional description of the value used in the InvalidValueException
    ------------------------------------------------------------------------------*/
	METHOD PUBLIC STATIC VOID GreaterThanZero (piValue AS INTEGER,
                                               pcValueDesc AS CHARACTER):
		
        IF piValue > 0 THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING (piValue), pcValueDesc) .

	END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Logical value so that it is not ? 
        Notes:   
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param plValue The Logical value to validate  
    ------------------------------------------------------------------------------*/
	METHOD PUBLIC STATIC VOID NotNull (plValue AS LOGICAL):
		
        IF plValue = ? THEN  
            UNDO, THROW NEW InvalidValueException (STRING (plValue)) .
            
	END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Charcater value so that it is not ? or Empty
        Notes:                              
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param pcValue The Character value to validate                                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrEmpty (pcValue AS CHARACTER):
        
        IF pcValue > "":U THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (pcValue) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Charcater value so that it is not ? or Empty
        Notes:                              
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param pcValue The Character value to validate                                       
        @param pcValueDesc The optional description of the value used in the InvalidValueException
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrEmpty (pcValue AS CHARACTER,
                                              pcValueDesc AS CHARACTER):
        
        IF pcValue > "":U THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (pcValue, pcValueDesc) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL LONGCHAR value so that it is not ? or Empty
        Notes:                              
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param plcValue The Character value to validate                                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrEmpty (plcValue AS LONGCHAR):
        
        IF plcValue > "":U THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING (plcValue)) .

    END METHOD.

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL LONGCHAR value so that it is not ? or Empty
        Notes:                              
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param plcValue The Character value to validate                                       
        @param pcValueDesc The optional description of the value used in the InvalidValueException
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrEmpty (plcValue AS LONGCHAR,
                                              pcValueDesc AS CHARACTER):
        
        IF plcValue > "":U THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING(plcValue), pcValueDesc) .

    END METHOD.
    
    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Integer value so that it is not ? or 0   
        Notes:   
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param piValue The Integer value to validate                                       
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrZero (piValue AS INTEGER):
        
        IF piValue <> 0 AND piValue <> ? THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING (piValue)) .

    END METHOD .

    /*------------------------------------------------------------------------------
        Purpose: Validates an ABL Integer value so that it is not ? or 0   
        Notes:   
        Throws:  Consultingwerk.Exceptions.InvalidValueException 
        @param piValue The Integer value to validate                                       
        @param pcValueDesc The optional description of the value used in the InvalidValueException
    ------------------------------------------------------------------------------*/
    METHOD PUBLIC STATIC VOID NotNullOrZero (piValue AS INTEGER,
                                             pcValueDesc AS CHARACTER):
        
        IF piValue <> 0 AND piValue <> ? THEN . 
        ELSE  
            UNDO, THROW NEW InvalidValueException (STRING (piValue), pcValueDesc) .

    END METHOD .

END CLASS.




© 2015 - 2025 Weber Informatics LLC | Privacy Policy