/******************************************************************************* * Copyright (c) 2008 IBM Corporation. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package com.ibm.wala.core.tests.demandpa; import java.io.IOException; import java.util.Collection; import org.junit.Assert; import org.junit.Ignore; import org.junit.Test; import com.ibm.wala.demandpa.alg.ContextSensitiveStateMachine; import com.ibm.wala.demandpa.alg.DemandRefinementPointsTo; import com.ibm.wala.demandpa.alg.IDemandPointerAnalysis; import com.ibm.wala.demandpa.alg.refinepolicy.TunedRefinementPolicy; import com.ibm.wala.demandpa.alg.statemachine.StateMachineFactory; import com.ibm.wala.demandpa.flowgraph.IFlowLabel; import com.ibm.wala.ipa.callgraph.CGNode; import com.ibm.wala.ipa.callgraph.propagation.InstanceKey; import com.ibm.wala.ipa.callgraph.propagation.PointerKey; import com.ibm.wala.ipa.cha.ClassHierarchyException; import com.ibm.wala.types.Descriptor; import com.ibm.wala.util.CancelException; import com.ibm.wala.util.strings.Atom; public class TunedRefinementTest extends AbstractPtrTest { public TunedRefinementTest() { super(TestInfo.SCOPE_FILE); // TODO Auto-generated constructor stub } @Test public void testArraySet() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_ARRAY_SET, 1); } @Test public void testClone() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_CLONE, 1); } @Test public void testFooId() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_ID, 1); } @Test public void testHashtableEnum() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { // 3 because // can't tell between key and value enumerators in Hashtable doPointsToSizeTest(TestInfo.TEST_HASHTABLE_ENUM, 2); } // we know this one fails... // @Test public void testOnTheFlyCS() throws ClassHierarchyException { // String mainClass = TestInfo.TEST_ONTHEFLY_CS; // final IDemandPointerAnalysis<InstanceKey> dmp = // makeDemandPointerAnalysis(TestInfo.SCOPE_FILE, mainClass); // CGNode testMethod = // AbstractPtrTest.findInstanceMethod(dmp.getBaseCallGraph(), // dmp.getClassHierarchy().lookupClass( // TypeReference.findOrCreate(ClassLoaderReference.Application, // "Ltestdata/TestOnTheFlyCS$C2")), Atom // .findOrCreateUnicodeAtom("doSomething"), // Descriptor.findOrCreateUTF8("(Ljava/lang/Object;)V")); // PointerKey keyToQuery = AbstractPtrTest.getParam(testMethod, "testThisVar", // dmp.getHeapModel()); // Collection<InstanceKey> pointsTo = dmp.getPointsTo(keyToQuery); // if (debug) { // System.err.println("points-to for " + mainClass + ": " + pointsTo); // } // assertEquals(1, pointsTo.size()); // } @Test public void testWithinMethodCall() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { String mainClass = TestInfo.TEST_WITHIN_METHOD_CALL; final IDemandPointerAnalysis dmp = makeDemandPointerAnalysis(mainClass); CGNode testMethod = AbstractPtrTest.findStaticMethod(dmp.getBaseCallGraph(), Atom.findOrCreateUnicodeAtom("testMethod"), Descriptor.findOrCreateUTF8("(Ljava/lang/Object;)V")); PointerKey keyToQuery = AbstractPtrTest.getParam(testMethod, "testThisVar", dmp.getHeapModel()); Collection<InstanceKey> pointsTo = dmp.getPointsTo(keyToQuery); if (debug) { System.err.println("points-to for " + mainClass + ": " + pointsTo); } Assert.assertEquals(1, pointsTo.size()); } @Test public void testLinkedListIter() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_LINKEDLIST_ITER, 1); } @Test public void testGlobal() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_GLOBAL, 1); } @Test public void testHashSet() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_HASH_SET, 1); } @Test public void testHashMapGet() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_HASHMAP_GET, 1); } @Test public void testMethodRecursion() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_METHOD_RECURSION, 2); } @Test public void testArraySetIter() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_ARRAY_SET_ITER, 1); } @Ignore @Test public void testArrayList() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_ARRAY_LIST, 1); } @Test public void testLinkedList() throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { doPointsToSizeTest(TestInfo.TEST_LINKED_LIST, 1); } @Override protected StateMachineFactory<IFlowLabel> getStateMachineFactory() { return new ContextSensitiveStateMachine.Factory(); } @Override protected DemandRefinementPointsTo makeDemandPointerAnalysis(String mainClass) throws ClassHierarchyException, IllegalArgumentException, CancelException, IOException { DemandRefinementPointsTo dmp = super.makeDemandPointerAnalysis(mainClass); dmp.setRefinementPolicyFactory(new TunedRefinementPolicy.Factory(dmp.getClassHierarchy())); return dmp; } }