Difference between revisions of "Assertions"

From Suhrid.net Wiki
Jump to navigationJump to search
(Created page with "== Introduction == * Assertions allow the testing of assumptions about a program. * Using assertions allow easy detection of bugs during development without writing exception h...")
 
 
(16 intermediate revisions by the same user not shown)
Line 2: Line 2:
  
 
* Assertions allow the testing of assumptions about a program.  
 
* Assertions allow the testing of assumptions about a program.  
* Using assertions allow easy detection of bugs during development without writing exception handlers etc.
+
* Using assertions allow easy detection of bugs during development without writing exception handlers etc.
 +
* We "assert" that something will be true at some point in the code. If it is, code keeps running, if it is false, an AssertionError will be thrown.
  
 +
Example:
 +
<syntaxhighlight lang="java5">
 +
 +
//Without assertions
 +
 +
private static void processAge1(int age) {
 +
if(age > 0) {
 +
System.out.println("Processing age ...");
 +
} else {
 +
System.out.println("Age < 0 !");
 +
}
 +
}
 +
 +
//With assertions
 +
 +
private static void processAge2(int age) {
 +
assert age > 0;
 +
System.out.println("Processing age ...");
 +
}
 +
 +
</syntaxhighlight>
 +
 +
* Second version of assert takes a second expression which must return a value (primtive/object). The return value can be anything.
 +
* This object's string value is added to the assertion error stack trace.
 +
 +
<syntaxhighlight lang="java5">
 +
 +
private static void processAge2(int age) {
 +
assert age > 0 : errorCode();
 +
System.out.println("Processing age ...");
 +
}
 +
 +
private static List<String> errorCode() {
 +
return Arrays.asList("oops");
 +
}
 +
 +
</syntaxhighlight>
 +
 +
== Compiling with assertions ==
 +
 +
* Assertions were introduced as a keyword in java 1.4.
 +
* Using the source flag - 1.4 onwards trying to use assert as an identifier will result in a compile failure.
 +
* Trying to use -source 1.3 with assert as an identifier will produce warnings and compilation will fail with assert as a keyword.
 +
 +
== Running with assertions ==
 +
 +
* Assertions are disabled by default.
 +
* '''IMPORTANT:''' If Assertions are disabled - it's not only that AssertionErrors will not be thrown, the assert statement itself will not be executed.
 +
* To enable use the -ea flag.
 +
* To disable use the -da flag. This is useful to disable assertions for specific classes/packages.
 +
 +
Examples:
 +
 +
* java -ea -da:net.suhrid.Foo //Enable for all exception of the net.suhrid.Foo class ('''NOTE THE ':'''')
 +
* java -ea:net.suhrid.Bar //Enable only for the net.suhrid.Bar class
 +
* java -ea -da:net.suhrid.util...  //Enable assertions in general, but disable assertions for the net.suhrid.util and all packages below it in the hierarchy.
 +
* java -ea -da:net.suhrid.util... -ea:net.suhrid.util.Test2 //Disable assertions for the net.suhrid.util and all packages below it in the hierarchy, but enable it for net.suhrid.util.Test2 class.
 +
* java -da -ea:... Test1 //Disable assertions in general but enable assertions in the unnamed package in the current working directory.
 +
* -esa enables assertions in system classes (java.lang). This '''has to be specifically used''', with only -ea systemassertions will still be disabled.
 +
* -dsa disables system assertions
 +
* For packages the ... notation '''has''' to be used.
 +
* The full form can also be used, all the below are valid:
 +
** -enableassertions.-disableassertions
 +
** -enablesystemassertions, -disablesystemassertions
 +
 +
== Correctly using Assertions ==
 +
 +
* Use assertions to validate arguments to a private method.
 +
* But not to a public one! Use IllegalArgumentException instead. This is because assertions are optional, so it may or may not work.
 +
* Similarly dont use assertions to validate command line arguments.
 +
* Can use assertions in public methods to check for cases that are never supposed to happen. e.g. if we know a switch default must never be reached.
 +
* Don't use asserts that causes values of variables to change - side effects!
  
 
[[Category:OCPJP]]
 
[[Category:OCPJP]]

Latest revision as of 09:27, 9 September 2011

Introduction

  • Assertions allow the testing of assumptions about a program.
  • Using assertions allow easy detection of bugs during development without writing exception handlers etc.
  • We "assert" that something will be true at some point in the code. If it is, code keeps running, if it is false, an AssertionError will be thrown.

Example:

//Without assertions

private static void processAge1(int age) {
		if(age > 0) {
			System.out.println("Processing age ...");
		} else {
			System.out.println("Age < 0 !");
		}
	}

//With assertions
	
private static void processAge2(int age) {
		assert age > 0;
		System.out.println("Processing age ...");
}
  • Second version of assert takes a second expression which must return a value (primtive/object). The return value can be anything.
  • This object's string value is added to the assertion error stack trace.
private static void processAge2(int age) {
	assert age > 0 : errorCode();
	System.out.println("Processing age ...");
}
	
private static List<String> errorCode() {
	return Arrays.asList("oops");
}

Compiling with assertions

  • Assertions were introduced as a keyword in java 1.4.
  • Using the source flag - 1.4 onwards trying to use assert as an identifier will result in a compile failure.
  • Trying to use -source 1.3 with assert as an identifier will produce warnings and compilation will fail with assert as a keyword.

Running with assertions

  • Assertions are disabled by default.
  • IMPORTANT: If Assertions are disabled - it's not only that AssertionErrors will not be thrown, the assert statement itself will not be executed.
  • To enable use the -ea flag.
  • To disable use the -da flag. This is useful to disable assertions for specific classes/packages.

Examples:

  • java -ea -da:net.suhrid.Foo //Enable for all exception of the net.suhrid.Foo class (NOTE THE ':')
  • java -ea:net.suhrid.Bar //Enable only for the net.suhrid.Bar class
  • java -ea -da:net.suhrid.util... //Enable assertions in general, but disable assertions for the net.suhrid.util and all packages below it in the hierarchy.
  • java -ea -da:net.suhrid.util... -ea:net.suhrid.util.Test2 //Disable assertions for the net.suhrid.util and all packages below it in the hierarchy, but enable it for net.suhrid.util.Test2 class.
  • java -da -ea:... Test1 //Disable assertions in general but enable assertions in the unnamed package in the current working directory.
  • -esa enables assertions in system classes (java.lang). This has to be specifically used, with only -ea systemassertions will still be disabled.
  • -dsa disables system assertions
  • For packages the ... notation has to be used.
  • The full form can also be used, all the below are valid:
    • -enableassertions.-disableassertions
    • -enablesystemassertions, -disablesystemassertions

Correctly using Assertions

  • Use assertions to validate arguments to a private method.
  • But not to a public one! Use IllegalArgumentException instead. This is because assertions are optional, so it may or may not work.
  • Similarly dont use assertions to validate command line arguments.
  • Can use assertions in public methods to check for cases that are never supposed to happen. e.g. if we know a switch default must never be reached.
  • Don't use asserts that causes values of variables to change - side effects!