X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=tests%2Forg%2Fcacert%2Fgigi%2Futil%2FTestNotary.java;h=ec143d2427a2d40b848c18f3f96d5471c8342852;hb=c252e6d9cd5b6f76cfa5bd85eb5df37b15b811ba;hp=9af8ccc46f69fe601380f90fc441511091f797e6;hpb=0b42a09bd0d23bfde15ed66058918f8c7c762621;p=gigi.git diff --git a/tests/org/cacert/gigi/util/TestNotary.java b/tests/org/cacert/gigi/util/TestNotary.java index 9af8ccc4..ec143d24 100644 --- a/tests/org/cacert/gigi/util/TestNotary.java +++ b/tests/org/cacert/gigi/util/TestNotary.java @@ -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")); + } } }