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

org.evosuite.testcase.statements.EntityWithParametersStatement Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (C) 2010-2018 Gordon Fraser, Andrea Arcuri and EvoSuite
 * contributors
 *
 * This file is part of EvoSuite.
 *
 * EvoSuite is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published
 * by the Free Software Foundation, either version 3.0 of the License, or
 * (at your option) any later version.
 *
 * EvoSuite 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
 * Lesser Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with EvoSuite. If not, see .
 */
package org.evosuite.testcase.statements;

import org.evosuite.Properties;
import org.evosuite.runtime.annotation.BoundInputVariable;
import org.evosuite.runtime.annotation.Constraints;
import org.evosuite.runtime.util.Inputs;
import org.evosuite.testcase.TestCase;
import org.evosuite.testcase.variable.ArrayIndex;
import org.evosuite.testcase.variable.NullReference;
import org.evosuite.testcase.variable.VariableReference;
import org.evosuite.utils.Randomness;
import org.evosuite.utils.generic.GenericUtils;

import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.util.*;

/**
 * Created by Andrea Arcuri on 04/07/15.
 */
public abstract class EntityWithParametersStatement extends AbstractStatement{

	private static final long serialVersionUID = 2971944785047056480L;
	protected final List parameters;
    protected final Annotation[][] parameterAnnotations;
    protected final Annotation[] annotations;

    protected EntityWithParametersStatement(TestCase tc, Type type, List parameters,
                                            Annotation[] annotations, Annotation[][] parameterAnnotations) throws IllegalArgumentException{
        super(tc,type);
        this.parameters = parameters;
        this.annotations = annotations;
        this.parameterAnnotations = parameterAnnotations;
        validateInputs();
    }

    protected EntityWithParametersStatement(TestCase tc, VariableReference retval, List parameters,
                                            Annotation[] annotations, Annotation[][] parameterAnnotations) throws IllegalArgumentException{
        super(tc,retval);
        this.parameters = parameters;
        this.annotations = annotations;
        this.parameterAnnotations = parameterAnnotations;
        validateInputs();
    }

    /**
     * Constructor needed for Functional Mocks where the number of input parameters
     * might vary during the search, ie not constant, and starts with 0
     * @param tc
     * @param retval
     */
    protected EntityWithParametersStatement(TestCase tc, VariableReference retval){
        super(tc, retval);
        this.parameters = new ArrayList<>();
        this.annotations=null;
        this.parameterAnnotations=null;
    }

    /**
     * Constructor needed for Functional Mocks where the number of input parameters
     * might vary during the search, ie not constant, and starts with 0
     * @param tc
     * @param type
     */
    protected EntityWithParametersStatement(TestCase tc, Type type){
        super(tc, type);
        this.parameters = new ArrayList<>();
        this.annotations=null;
        this.parameterAnnotations=null;
    }

    private void validateInputs() throws IllegalArgumentException{
        Inputs.checkNull(parameters);
        for(VariableReference ref : parameters){
            Inputs.checkNull(ref);
        }
        if(parameterAnnotations!=null){
            if(parameterAnnotations.length != parameters.size()){
                throw new IllegalArgumentException("Size mismatched");
            }
        }
    }

    public List getParameterReferences() {
        return Collections.unmodifiableList(parameters);
    }

    /* (non-Javadoc)
	 * @see org.evosuite.testcase.StatementInterface#replace(org.evosuite.testcase.VariableReference, org.evosuite.testcase.VariableReference)
	 */
    /** {@inheritDoc} */
    @Override
    public void replace(VariableReference var1, VariableReference var2) {

        if (retval.equals(var1)) {
            retval = var2;
            // TODO: Notify listener?
        }

        for (int i = 0; i < parameters.size(); i++) {

            if (parameters.get(i).equals(var1))
                parameters.set(i, var2);
            else
                parameters.get(i).replaceAdditionalVariableReference(var1, var2);
        }
    }


    @Override
    public List getUniqueVariableReferences() {
        List references = new ArrayList<>();
        references.add(retval);
        references.addAll(parameters);
        for (VariableReference param : parameters) {
            if (param instanceof ArrayIndex)
                references.add(((ArrayIndex) param).getArray());
        }
        return references;

    }

    @Override
    public Set getVariableReferences() {
        Set references = new LinkedHashSet<>();
        references.add(retval);
        for (VariableReference param : parameters) {
            if(param == null){
                /*
                    This could happen while building a functional mock, and creation
                    of its input values lead to a forward check of properties
                 */
                continue;
            }
            references.add(param);
            if (param.getAdditionalVariableReference() != null)
                references.add(param.getAdditionalVariableReference());
        }
        references.addAll(getAssertionReferences());

        return references;
    }


    @Override
    public int getNumParameters() {
        return parameters.size();
    }

    /**
     * 

* replaceParameterReference *

* * @param var * a {@link org.evosuite.testcase.variable.VariableReference} object. * @param numParameter * a int. */ public void replaceParameterReference(VariableReference var, int numParameter) throws IllegalArgumentException{ Inputs.checkNull(var); if(numParameter<0 || numParameter>= parameters.size()){ throw new IllegalArgumentException("Out of range index "+numParameter+" from list of size "+parameters.size()); } parameters.set(numParameter, var); } /** * Check if the given var is bounded in this method/constructor as input parameter * @param var * @return */ public boolean isBounded(VariableReference var) throws IllegalArgumentException{ Inputs.checkNull(var); if(parameterAnnotations==null){ assert this instanceof FunctionalMockStatement; //for now this should be the only valid case return false; } for(int i=0; i clazz) { int num = 0; for(VariableReference var : parameters) { if(var.getVariableClass().equals(clazz)) num++; } return num; } protected Constraints getConstraints(){ for(Annotation annotation : annotations){ if(annotation instanceof Constraints){ return (Constraints)annotation; } } return null; } protected boolean mutateParameter(TestCase test, int numParameter) { // replace a parameter VariableReference parameter = parameters.get(numParameter); List objects = test.getObjects(parameter.getType(),getPosition()); objects.remove(parameter); objects.remove(getReturnValue()); NullStatement nullStatement = new NullStatement(test, parameter.getType()); Statement copy = null; //check if NULL is a valid option Constraints constraint = getConstraints(); boolean avoidNull = constraint!=null && constraint.noNullInputs(); if(Properties.HONOUR_DATA_ANNOTATIONS && (numParameter < parameterAnnotations.length)) { if (GenericUtils.isAnnotationTypePresent(parameterAnnotations[numParameter], GenericUtils.NONNULL)) { avoidNull = true; } } if(avoidNull){ //be sure to remove all references pointing to NULL Iterator iter = objects.iterator(); while(iter.hasNext()){ VariableReference ref = iter.next(); if(ref instanceof NullReference){ iter.remove(); } } } else { // If it's not a primitive, then changing to null is also an option if (!parameter.isPrimitive()) { objects.add(nullStatement.getReturnValue()); } } // If there are fewer objects than parameters of that type, // we consider adding an instance if(getNumParametersOfType(parameter.getVariableClass()) + 1 < objects.size()) { Statement originalStatement = test.getStatement(parameter.getStPosition()); copy = originalStatement.clone(test); if (originalStatement instanceof PrimitiveStatement) { ((PrimitiveStatement)copy).delta(); } objects.add(copy.getReturnValue()); } if (objects.isEmpty()) return false; VariableReference replacement = Randomness.choice(objects); if (replacement == nullStatement.getReturnValue()) { test.addStatement(nullStatement, getPosition()); } else if (copy != null && replacement == copy.getReturnValue()) { test.addStatement(copy, getPosition()); } replaceParameterReference(replacement, numParameter); return true; } public abstract String getDeclaringClassName(); public abstract String getMethodName(); public abstract String getDescriptor(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy