Package com.denimgroup.threadfix.framework.impl.jsp

Source Code of com.denimgroup.threadfix.framework.impl.jsp.JSPParameterParserTests

////////////////////////////////////////////////////////////////////////
//
//     Copyright (c) 2009-2014 Denim Group, Ltd.
//
//     The contents of this file are subject to the Mozilla Public License
//     Version 2.0 (the "License"); you may not use this file except in
//     compliance with the License. You may obtain a copy of the License at
//     http://www.mozilla.org/MPL/
//
//     Software distributed under the License is distributed on an "AS IS"
//     basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
//     License for the specific language governing rights and limitations
//     under the License.
//
//     The Original Code is ThreadFix.
//
//     The Initial Developer of the Original Code is Denim Group, Ltd.
//     Portions created by Denim Group, Ltd. are Copyright (C)
//     Denim Group, Ltd. All Rights Reserved.
//
//     Contributor(s): Denim Group, Ltd.
//
////////////////////////////////////////////////////////////////////////
package com.denimgroup.threadfix.framework.impl.jsp;

import static org.junit.Assert.assertTrue;

import java.io.File;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import com.denimgroup.threadfix.data.enums.FrameworkType;
import com.denimgroup.threadfix.data.enums.SourceCodeAccessLevel;
import javax.annotation.Nonnull;
import org.junit.Test;

import com.denimgroup.threadfix.framework.TestConstants;
import com.denimgroup.threadfix.framework.engine.CodePoint;
import com.denimgroup.threadfix.framework.engine.DefaultCodePoint;
import com.denimgroup.threadfix.framework.engine.ProjectConfig;
import com.denimgroup.threadfix.framework.engine.full.EndpointQuery;
import com.denimgroup.threadfix.framework.engine.full.EndpointQueryBuilder;
import com.denimgroup.threadfix.framework.engine.parameter.ParameterParser;
import com.denimgroup.threadfix.framework.engine.parameter.ParameterParserFactory;

public class JSPParameterParserTests {
 
  @Nonnull
    ProjectConfig
    fullSourceConfig = new ProjectConfig(FrameworkType.JSP, SourceCodeAccessLevel.FULL,
        new File(TestConstants.BODGEIT_SOURCE_LOCATION), "/"),
    noSourceConfig = new ProjectConfig(FrameworkType.JSP, SourceCodeAccessLevel.NONE, null, null);

  @Nonnull
    ParameterParser
    factoryParser = ParameterParserFactory.getParameterParser(fullSourceConfig),
    fullSourceParser = new JSPDataFlowParser(fullSourceConfig),
    noSourceParser = new JSPDataFlowParser(noSourceConfig);
 
  // These are from the PetClinic Fortify results
  @Nonnull
    private static List<? extends CodePoint> basicModelElements = Arrays.asList(
    new DefaultCodePoint("root/register.jsp",32,
        "String username = (String) request.getParameter(\"username\");"),
    new DefaultCodePoint("root/register.jsp",32,
        "String username = (String) request.getParameter(\"username\");"),
    new DefaultCodePoint("root/register.jsp",60,
        "   session.setAttribute(\"username\", username);"),
    new DefaultCodePoint("root/contact.jsp",33,
        "String username = (String) session.getAttribute(\"username\");"),
    new DefaultCodePoint("root/contact.jsp",33,
        "String username = (String) session.getAttribute(\"username\");"),
    new DefaultCodePoint("root/contact.jsp",115,
        "<input type=\"hidden\" id=\"user\" name=\"<%=username%>\" value=\"\"/>")
    );
 
  @Test
  public void testBasicNoSourceParsing() {
    EndpointQuery query = EndpointQueryBuilder.start().setCodePoints(basicModelElements).generateQuery();
   
    String result = noSourceParser.parse(query);
    assertTrue("Parameter was " + result + " instead of username", "username".equals(result));
  }
 
  @Test
  public void testBasicWithSourceParsing() {
    EndpointQuery query = EndpointQueryBuilder.start().setCodePoints(basicModelElements).generateQuery();
   
    String result = fullSourceParser.parse(query);
    assertTrue("Parameter was " + result + " instead of username", "username".equals(result));
  }

    @Test(expected= NullPointerException.class)
    public void testNullArgument() {
        factoryParser.parse(null);
    }
 
  @Test
  public void testNullInput() {
    EndpointQuery emptyDataFlowFinding = EndpointQueryBuilder.start().setCodePoints(new ArrayList<CodePoint>()).generateQuery();
    EndpointQuery nonEmptyDataFlowFinding = EndpointQueryBuilder.start().setCodePoints(basicModelElements).generateQuery();
   
    for (ParameterParser parser : new ParameterParser[] {
        factoryParser, fullSourceParser, noSourceParser
        }) {
      assertTrue("Parameter was not null and should have been.", parser.parse(EndpointQueryBuilder.start().generateQuery()) == null);
      assertTrue("Parameter was not null and should have been.", parser.parse(emptyDataFlowFinding) == null);
    }
   
    File[] rootFiles = { null, new File(TestConstants.BODGEIT_SOURCE_LOCATION) };

    for (File file : rootFiles) {
      for (SourceCodeAccessLevel accessLevel : SourceCodeAccessLevel.values()) {
        ProjectConfig config = new ProjectConfig(FrameworkType.JSP, accessLevel, file, null);
                JSPDataFlowParser parser = new JSPDataFlowParser(config);
        assertTrue("Parameter was not null and should have been.",
            parser.parse(EndpointQueryBuilder.start().generateQuery()) == null);
        assertTrue("Parameter was not null and should have been.",
            parser.parse(emptyDataFlowFinding) == null);
        assertTrue("Parameter was not username and should have been.",
            "username".equals(parser.parse(nonEmptyDataFlowFinding)));
      }
    }
   
  }

    @Test(expected=NullPointerException.class)
    public void testParserNullInput() {
        ProjectConfig config = new ProjectConfig(FrameworkType.JSP, SourceCodeAccessLevel.DETECT,
                new File(TestConstants.BODGEIT_SOURCE_LOCATION), null);
        JSPDataFlowParser parser = new JSPDataFlowParser(config);
        parser.parse(null);
    }
 
}
TOP

Related Classes of com.denimgroup.threadfix.framework.impl.jsp.JSPParameterParserTests

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.