]> WPIA git - gigi.git/blobdiff - tests/org/cacert/gigi/util/TestNotary.java
Remove Test-debugoutput
[gigi.git] / tests / org / cacert / gigi / util / TestNotary.java
index 9af8ccc46f69fe601380f90fc441511091f797e6..ec143d2427a2d40b848c18f3f96d5471c8342852 100644 (file)
@@ -1,72 +1,67 @@
 package org.cacert.gigi.util;
 
+import java.sql.PreparedStatement;
 import java.sql.SQLException;
 
 import org.cacert.gigi.User;
+import org.cacert.gigi.database.DatabaseConnection;
 import org.cacert.gigi.testUtils.ManagedTest;
+import org.cacert.gigi.util.Notary.AssuranceResult;
 import org.junit.Test;
 
 import static org.junit.Assert.*;
 
 public class TestNotary extends ManagedTest {
        @Test
-       public void testSigning() throws SQLException {
-               User[] users = new User[10];
+       public void testNormalAssurance() throws SQLException {
+               User[] users = new User[30];
                for (int i = 0; i < users.length; i++) {
-                       int id = createVerifiedUser("fn" + i, "ln" + i, createUniqueName()
-                                       + "@email.org", "xvXV12°§");
+                       int id = createVerifiedUser("fn" + i, "ln" + i, createUniqueName() + "@email.org", "xvXV12°§");
                        users[i] = new User(id);
                }
-               User assurer = new User(createAssuranceUser("fn", "ln",
-                               createUniqueName() + "@email.org", "xvXV12°§"));
-               assertEquals(10, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[1], 10, "test-notary",
-                               "2014-01-01"));
-               assertEquals(10, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[2], 10, "test-notary",
-                               "2014-01-01"));
-               assertEquals(10, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[3], 10, "test-notary",
-                               "2014-01-01"));
-               assertEquals(10, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[4], 10, "test-notary",
-                               "2014-01-01"));
-               assertEquals(15, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[5], 15, "test-notary",
-                               "2014-01-01"));
-               // Assure someone again
-               assertTrue(!Notary.assure(assurer, users[5], 15, "test-notary",
-                               "2014-01-01"));
+               User assurer = new User(createAssuranceUser("fn", "ln", createUniqueName() + "@email.org", "xvXV12°§"));
+               int[] result = new int[] { 10, 10, 10, 10, 15, 15, 15, 15, 15, 20, 20, 20, 20, 20, 25, 25, 25, 25, 25, 30, 30,
+                               30, 30, 30, 35, 35, 35, 35, 35, 35 };
 
-               // Assure too much
-               assertTrue(!Notary.assure(assurer, users[6], 20, "test-notary",
-                               "2014-01-01"));
-               assertTrue(!Notary.assure(assurer, users[6], 16, "test-notary",
-                               "2014-01-01"));
-
-               assertTrue(Notary.assure(assurer, users[6], 15, "test-notary",
-                               "2014-01-01"));
-               assertEquals(15, assurer.getMaxAssurePoints());
-
-               // Assure self
-               assertTrue(!Notary.assure(assurer, assurer, 10, "test-notary",
-                               "2014-01-01"));
+               assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                       Notary.assure(assurer, users[0], -1, "test-notary", "2014-01-01"));
+               for (int i = 0; i < result.length; i++) {
+                       assertEquals(result[i], assurer.getMaxAssurePoints());
+                       assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], result[i] + 1, "test-notary", "2014-01-01"));
+                       assertEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], result[i], "test-notary", "2014-01-01"));
+                       assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], result[i], "test-notary", "2014-01-01"));
+               }
 
-               assertTrue(Notary.assure(assurer, users[7], 15, "test-notary",
-                               "2014-01-01"));
-               assertEquals(15, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[8], 15, "test-notary",
-                               "2014-01-01"));
-               assertEquals(15, assurer.getMaxAssurePoints());
-               assertTrue(Notary.assure(assurer, users[9], 15, "test-notary",
-                               "2014-01-01"));
-               assertEquals(20, assurer.getMaxAssurePoints());
+               assertEquals(35, assurer.getMaxAssurePoints());
 
-               assertTrue(Notary.assure(assurer, users[0], 15, "test-notary",
-                               "2014-01-01"));
-               assertEquals(20, assurer.getMaxAssurePoints());
+               assertEquals(2 + 60, assurer.getExperiencePoints());
 
-               assertEquals(2 + 20, assurer.getExperiencePoints());
+       }
 
+       @Test
+       public void testPoJam() throws SQLException {
+               User[] users = new User[30];
+               for (int i = 0; i < users.length; i++) {
+                       int id = createVerifiedUser("fn" + i, "ln" + i, createUniqueName() + "@email.org", "xvXV12°§");
+                       users[i] = new User(id);
+               }
+               int id = createAssuranceUser("fn", "ln", createUniqueName() + "@email.org", "xvXV12°§");
+               PreparedStatement ps = DatabaseConnection.getInstance().prepare("UPDATE users SET dob=NOW() WHERE id=?");
+               ps.setInt(1, id);
+               ps.execute();
+               User assurer = new User(id);
+               for (int i = 0; i < users.length; i++) {
+                       assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], -1, "test-notary", "2014-01-01"));
+                       assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], 11, "test-notary", "2014-01-01"));
+                       assertEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], 10, "test-notary", "2014-01-01"));
+                       assertNotEquals(AssuranceResult.ASSURANCE_SUCCEDED,
+                               Notary.assure(assurer, users[i], 10, "test-notary", "2014-01-01"));
+               }
        }
 }