package org.cacert.gigi.util;
-import java.sql.PreparedStatement;
+import static org.junit.Assert.*;
+
import java.sql.SQLException;
import java.util.Date;
import org.cacert.gigi.GigiApiException;
-import org.cacert.gigi.database.DatabaseConnection;
+import org.cacert.gigi.database.GigiPreparedStatement;
+import org.cacert.gigi.dbObjects.Assurance.AssuranceType;
+import org.cacert.gigi.dbObjects.CountryCode;
+import org.cacert.gigi.dbObjects.CountryCode.CountryCodeType;
+import org.cacert.gigi.dbObjects.ObjectCache;
import org.cacert.gigi.dbObjects.User;
import org.cacert.gigi.output.DateSelector;
-import org.cacert.gigi.testUtils.ManagedTest;
+import org.cacert.gigi.testUtils.BusinessTest;
import org.junit.Test;
-import static org.junit.Assert.*;
+public class TestNotary extends BusinessTest {
-public class TestNotary extends ManagedTest {
+ public final CountryCode DE = CountryCode.getCountryCode("DE", CountryCodeType.CODE_2_CHARS);
+
+ public TestNotary() throws GigiApiException {}
@Test
public void testNormalAssurance() throws SQLException, GigiApiException {
};
try {
- Notary.assure(assurer, users[0], users[0].getName(), users[0].getDob(), -1, "test-notary", "2014-01-01");
+ Notary.assure(assurer, users[0], users[0].getPreferredName(), users[0].getDoB(), -1, "test-notary", validVerificationDateString(), AssuranceType.FACE_TO_FACE, DE);
fail("This shouldn't have passed");
} catch (GigiApiException e) {
// expected
for (int i = 0; i < result.length; i++) {
assertEquals(result[i], assurer.getMaxAssurePoints());
- assuranceFail(assurer, users[i], result[i] + 1, "test-notary", "2014-01-01");
- Notary.assure(assurer, users[i], users[i].getName(), users[i].getDob(), result[i], "test-notary", "2014-01-01");
- assuranceFail(assurer, users[i], result[i], "test-notary", "2014-01-01");
+ assuranceFail(assurer, users[i], result[i] + 1, "test-notary", validVerificationDateString());
+ Notary.assure(assurer, users[i], users[i].getPreferredName(), users[i].getDoB(), result[i], "test-notary", validVerificationDateString(), AssuranceType.FACE_TO_FACE, DE);
+ assuranceFail(assurer, users[i], result[i], "test-notary", validVerificationDateString());
}
assertEquals(35, assurer.getMaxAssurePoints());
- assertEquals(2 + 60, assurer.getExperiencePoints());
+ assertEquals(User.EXPERIENCE_POINTS + (30 * User.EXPERIENCE_POINTS), assurer.getExperiencePoints());
}
private void assuranceFail(User assurer, User user, int i, String location, String date) throws SQLException {
try {
- Notary.assure(assurer, user, user.getName(), user.getDob(), i, location, date);
+ Notary.assure(assurer, user, user.getPreferredName(), user.getDoB(), i, location, date, AssuranceType.FACE_TO_FACE, DE);
fail("This shouldn't have passed");
} catch (GigiApiException e) {
// expected
users[i] = User.getById(id);
}
int id = createAssuranceUser("fn", "ln", createUniqueName() + "@email.org", TEST_PASSWORD);
- PreparedStatement ps = DatabaseConnection.getInstance().prepare("UPDATE users SET dob=NOW() WHERE id=?");
- ps.setInt(1, id);
- ps.execute();
+ try (GigiPreparedStatement ps = new GigiPreparedStatement("UPDATE `users` SET dob=NOW() - interval '15 years' WHERE id=?")) {
+ ps.setInt(1, id);
+ ps.execute();
+ }
+ ObjectCache.clearAllCaches(); // reload values from db
User assurer = User.getById(id);
for (int i = 0; i < users.length; i++) {
- assuranceFail(assurer, users[i], -1, "test-notary", "2014-01-01");
- assuranceFail(assurer, users[i], 11, "test-notary", "2014-01-01");
- Notary.assure(assurer, users[i], users[i].getName(), users[i].getDob(), 10, "test-notary", "2014-01-01");
- assuranceFail(assurer, users[i], 10, "test-notary", "2014-01-01");
+ assuranceFail(assurer, users[i], -1, "test-notary", validVerificationDateString());
+ assuranceFail(assurer, users[i], 11, "test-notary", validVerificationDateString());
+ if (User.POJAM_ENABLED) {
+ Notary.assure(assurer, users[i], users[i].getPreferredName(), users[i].getDoB(), 10, "test-notary", validVerificationDateString(), AssuranceType.FACE_TO_FACE, DE);
+ }
+ assuranceFail(assurer, users[i], 10, "test-notary", validVerificationDateString());
}
}
// null date
assuranceFail(assuranceUser, assuree, 10, "notary-junit-test", null);
// null location
- assuranceFail(assuranceUser, assuree, 10, null, "2014-01-01");
+ assuranceFail(assuranceUser, assuree, 10, null, validVerificationDateString());
// empty location
- assuranceFail(assuranceUser, assuree, 10, "", "2014-01-01");
+ assuranceFail(assuranceUser, assuree, 10, "", validVerificationDateString());
// date in the future
assuranceFail(assuranceUser, assuree, 10, "notary-junit-test", DateSelector.getDateFormat().format(new Date(System.currentTimeMillis() + 2 * 24 * 60 * 60 * 1000)));
// location too short
- assuranceFail(assuranceUser, assuree, 10, "n", "2014-01-01");
+ assuranceFail(assuranceUser, assuree, 10, "n", validVerificationDateString());
// points too low
- assuranceFail(assuranceUser, assuree, -1, "notary-junit-test", "2014-01-01");
+ assuranceFail(assuranceUser, assuree, -1, "notary-junit-test", validVerificationDateString());
// points too high
- assuranceFail(assuranceUser, assuree, 11, "notary-junit-test", "2014-01-01");
+ assuranceFail(assuranceUser, assuree, 11, "notary-junit-test", validVerificationDateString());
- // assure oneself
- assuranceFail(assuranceUser, assuranceUser, 10, "notary-junit-test", "2014-01-01");
+ // verify oneself
+ assuranceFail(assuranceUser, assuranceUser, 10, "notary-junit-test", validVerificationDateString());
// not an assurer
- assuranceFail(assuree, assuranceUser, 10, "notary-junit-test", "2014-01-01");
+ assuranceFail(assuree, assuranceUser, 10, "notary-junit-test", validVerificationDateString());
// valid
- Notary.assure(assuranceUser, assuree, assuree.getName(), assuree.getDob(), 10, "notary-junit-test", "2014-01-01");
+ Notary.assure(assuranceUser, assuree, assuree.getPreferredName(), assuree.getDoB(), 10, "notary-junit-test", validVerificationDateString(), AssuranceType.FACE_TO_FACE, DE);
- // assure double
- assuranceFail(assuranceUser, assuree, 10, "notary-junit-test", "2014-01-01");
+ // verify double
+ assuranceFail(assuranceUser, assuree, 10, "notary-junit-test", validVerificationDateString());
}
}