001/** 002 * This is part of HW0: Environment Setup and Java Introduction for CSE 331. 003 */ 004package hw0.test; 005import hw0.*; 006 007import org.junit.Test; 008import org.junit.BeforeClass; 009import static org.junit.Assert.*; 010 011/** 012 * FibonacciTest is a glassbox test of the Fibonacci class. 013 * 014 * Recall that the Fibonacci sequence is a recursive 015 * sequence where the first two terms of the sequence are 1 and all subsequent 016 * terms are the sum of the previous two terms. 017 * 018 * Thus, the Fibonacci sequence starts out as 1, 1, 2, 3, 5, 8, 13... 019 * The first 1 in the sequence is considered the "0th" term, 020 * so the indices that <code>hw0.Fibonacci</code> uses are 0-based. 021 * 022 * @see hw0.Fibonacci 023 * 024 * @author mbolin 025 */ 026public class FibonacciTest { 027 028 private static Fibonacci fib = null; 029 030 @BeforeClass 031 public static void setupBeforeTests() throws Exception { 032 fib = new Fibonacci(); 033 } 034 035 /** 036 * Tests that Fibonacci throws an IllegalArgumentException 037 * for a negative number. 038 */ 039 @Test(expected=IllegalArgumentException.class) 040 public void expectedIllegalArgumentException() { 041 fib.getFibTerm(-1); 042 } 043 044 045 /** 046 * Tests that Fibonacci throws no IllegalArgumentException 047 * for zero or for a positive number. 048 */ 049 @Test 050 public void testThrowsIllegalArgumentException() { 051 052 // test 0 053 try { 054 fib.getFibTerm(0); 055 } catch (IllegalArgumentException ex) { 056 fail("Threw IllegalArgumentException for 0 but 0 is nonnegative: " 057 + ex); 058 } 059 060 // test 1 061 try { 062 fib.getFibTerm(1); 063 } catch (IllegalArgumentException ex) { 064 fail("Threw IllegalArgumentException for 1 but 1 is nonnegative: " 065 + ex); 066 } 067 } 068 069 /** Tests to see that Fibonacci returns the correct value for the base cases, n=0 and n=1 */ 070 @Test 071 public void testBaseCase() { 072 assertEquals("getFibTerm(0)", 1, fib.getFibTerm(0)); 073 assertEquals("getFibTerm(1)", 1, fib.getFibTerm(1)); 074 } 075 076 /** Tests inductive cases of the Fibonacci sequence */ 077 @Test 078 public void testInductiveCase() { 079 int[][] cases = new int[][] { 080 { 2, 2 }, 081 { 3, 3 }, 082 { 4, 5 }, 083 { 5, 8 }, 084 { 6, 13 }, 085 { 7, 21 } 086 }; 087 for (int i = 0; i < cases.length; i++) { 088 assertEquals("getFibTerm(" + cases[i][0] + ")", 089 cases[i][1], fib.getFibTerm(cases[i][0])); 090 } 091 } 092 093}