Reviewed By: jberdine Differential Revision: D3811191 fbshipit-source-id: 9d967f2master
							parent
							
								
									f6636c6d41
								
							
						
					
					
						commit
						f2487513c5
					
				| @ -0,0 +1,200 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2016 - present Facebook, Inc. | ||||||
|  |  * All rights reserved. | ||||||
|  |  * | ||||||
|  |  * This source code is licensed under the BSD style license found in the | ||||||
|  |  * LICENSE file in the root directory of this source tree. An additional grant | ||||||
|  |  * of patent rights can be found in the PATENTS file in the same directory. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | package codetoanalyze.java.quandary; | ||||||
|  | 
 | ||||||
|  | import com.facebook.infer.models.InferTaint; | ||||||
|  | 
 | ||||||
|  | /** testing basic intraprocedural functionality: assignment, ifs, loops, casts */ | ||||||
|  | 
 | ||||||
|  | public class Basics { | ||||||
|  | 
 | ||||||
|  |   native Object notASource(); | ||||||
|  |   native void notASink(Object o); | ||||||
|  | 
 | ||||||
|  |   /** should report on these tests */ | ||||||
|  | 
 | ||||||
|  |   void directBad() { | ||||||
|  |     InferTaint.inferSensitiveSink(InferTaint.inferSecretSource()); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaVarBad1() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaVarBad2() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     Object alias = src; | ||||||
|  |     InferTaint.inferSensitiveSink(alias); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaVarBad3() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     Object alias = src; | ||||||
|  |     src = null; | ||||||
|  |     InferTaint.inferSensitiveSink(alias); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaCastBad1() { | ||||||
|  |     InferTaint.inferSensitiveSink((String) InferTaint.inferSecretSource()); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaCastBad2() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     InferTaint.inferSensitiveSink((String) src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void ifBad1(boolean b) { | ||||||
|  |     Object src = null; | ||||||
|  |     if (b) { | ||||||
|  |       src = InferTaint.inferSecretSource(); | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void ifBad2(boolean b) { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     if (b) { | ||||||
|  |       src = null; | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void ifBad3(boolean b) { | ||||||
|  |     Object src; | ||||||
|  |     if (b) { | ||||||
|  |       src = new Object(); | ||||||
|  |     } else { | ||||||
|  |       src = InferTaint.inferSecretSource(); | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void ifBad4(boolean b1, boolean b2) { | ||||||
|  |     Object src; | ||||||
|  |     if (b1) { | ||||||
|  |       src = new Object(); | ||||||
|  |     } else if (b2) { | ||||||
|  |       src = InferTaint.inferSecretSource(); | ||||||
|  |     } else { | ||||||
|  |       src = null; | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void ifBad5(boolean b) { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     if (b) { | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void switchBad1(int i) { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     switch (i) { | ||||||
|  |     case 1: | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |       break; | ||||||
|  |     case 2: | ||||||
|  |       break; | ||||||
|  |     default: | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void switchBad2(int i) { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     switch (i) { | ||||||
|  |     case 1: | ||||||
|  |       break; | ||||||
|  |     case 2: | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |       break; | ||||||
|  |     default: | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void switchBad3(int i) { | ||||||
|  |     Object src = null; | ||||||
|  |     switch (i) { | ||||||
|  |     case 1: | ||||||
|  |       src = InferTaint.inferSecretSource(); | ||||||
|  |       // fallthrough
 | ||||||
|  |     case 2: | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |       break; | ||||||
|  |     default: | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void whileBad1(int i) { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     while (i < 10) { | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |       i++; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void whileBad2(int i) { | ||||||
|  |     Object src = null; | ||||||
|  |     while (i < 10) { | ||||||
|  |       src = InferTaint.inferSecretSource(); | ||||||
|  |       i++; | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   /** should not report on these tests */ | ||||||
|  | 
 | ||||||
|  |   void directOk1() { | ||||||
|  |     notASink(notASource()); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void directOk2() { | ||||||
|  |     notASink(InferTaint.inferSecretSource()); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void directOk3() { | ||||||
|  |     InferTaint.inferSensitiveSink(notASource()); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaVarOk() { | ||||||
|  |     Object src = new Object(); | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void viaVarStrongUpdateOk() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     src = null; | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   /** "known false positive" tests demonstrating limitations. an ideal analysis would not report on | ||||||
|  |       these tests, but we do. */ | ||||||
|  | 
 | ||||||
|  |   void FP_deadCodeOk() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     boolean b = false; | ||||||
|  |     if (b) { | ||||||
|  |       InferTaint.inferSensitiveSink(src); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   void FP_loopInvariantOk() { | ||||||
|  |     Object src = InferTaint.inferSecretSource(); | ||||||
|  |     for (int i = 0; i < 10; i++) { | ||||||
|  |       src = null; | ||||||
|  |     } | ||||||
|  |     InferTaint.inferSensitiveSink(src); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -1,2 +1,20 @@ | |||||||
|  | Basics.java:103: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 100]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 103]) via {  } | ||||||
|  | Basics.java:118: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 113]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 118]) via {  } | ||||||
|  | Basics.java:132: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 129]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 132]) via {  } | ||||||
|  | Basics.java:142: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 140]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 142]) via {  } | ||||||
|  | Basics.java:153: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 150]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 153]) via {  } | ||||||
|  | Basics.java:188: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 185]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 188]) via {  } | ||||||
|  | Basics.java:197: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 193]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 197]) via {  } | ||||||
|  | Basics.java:24: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 24]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 24]) via {  } | ||||||
|  | Basics.java:29: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 28]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 29]) via {  } | ||||||
|  | Basics.java:35: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 33]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 35]) via {  } | ||||||
|  | Basics.java:42: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 39]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 42]) via {  } | ||||||
|  | Basics.java:46: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 46]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 46]) via {  } | ||||||
|  | Basics.java:51: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 50]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 51]) via {  } | ||||||
|  | Basics.java:59: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 57]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 59]) via {  } | ||||||
|  | Basics.java:67: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 63]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 67]) via {  } | ||||||
|  | Basics.java:77: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 75]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 77]) via {  } | ||||||
|  | Basics.java:89: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 85]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 89]) via {  } | ||||||
|  | Basics.java:95: ERROR: QUANDARY_TAINT_ERROR Error: Other(Object InferTaint.inferSecretSource() at [line 93]) -> Other(void InferTaint.inferSensitiveSink(Object) at [line 95]) via {  } | ||||||
| LoggingPrivateData.java:18: ERROR: QUANDARY_TAINT_ERROR Error: SharedPreferences(String SharedPreferences.getString(String,String) at [line 18]) -> Logging(int Log.d(String,String) at [line 18]) via {  } | LoggingPrivateData.java:18: ERROR: QUANDARY_TAINT_ERROR Error: SharedPreferences(String SharedPreferences.getString(String,String) at [line 18]) -> Logging(int Log.d(String,String) at [line 18]) via {  } | ||||||
| LoggingPrivateData.java:22: ERROR: QUANDARY_TAINT_ERROR Error: SharedPreferences(String SharedPreferences.getString(String,String) at [line 22]) -> Logging(int Log.d(String,String) at [line 22]) via {  } | LoggingPrivateData.java:22: ERROR: QUANDARY_TAINT_ERROR Error: SharedPreferences(String SharedPreferences.getString(String,String) at [line 22]) -> Logging(int Log.d(String,String) at [line 22]) via {  } | ||||||
|  | |||||||
					Loading…
					
					
				
		Reference in new issue