X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=tests%2Forg%2Fcacert%2Fgigi%2FTestUser.java;h=93deebaa4fe4af245148cf3a133d98e0d02c49a0;hb=b9e921fcf985e5feb48dbcb56af9f6274c21d2cb;hp=9e4a115cc1398158672155e615db44f94467f6f9;hpb=e409ba881965634f63f0b67824bc93dda4ec4327;p=gigi.git diff --git a/tests/org/cacert/gigi/TestUser.java b/tests/org/cacert/gigi/TestUser.java index 9e4a115c..93deebaa 100644 --- a/tests/org/cacert/gigi/TestUser.java +++ b/tests/org/cacert/gigi/TestUser.java @@ -1,8 +1,12 @@ package org.cacert.gigi; +import static org.junit.Assert.*; + +import java.sql.Date; import java.sql.SQLException; import java.util.Locale; +import org.cacert.gigi.dbObjects.Assurance; import org.cacert.gigi.dbObjects.Domain; import org.cacert.gigi.dbObjects.EmailAddress; import org.cacert.gigi.dbObjects.User; @@ -10,43 +14,43 @@ import org.cacert.gigi.localisation.Language; import org.cacert.gigi.testUtils.ManagedTest; import org.junit.Test; -import static org.junit.Assert.*; - public class TestUser extends ManagedTest { @Test public void testStoreAndLoad() throws SQLException { User u = new User(); - u.setFname("user"); - u.setLname("last"); - u.setMname(""); + u.setFName("user"); + u.setLName("last"); + u.setMName(""); u.setSuffix(""); u.setPreferredLocale(Locale.ENGLISH); long dob = System.currentTimeMillis(); dob -= dob % (1000 * 60 * 60 * 24); - u.setDob(new java.sql.Date(dob)); + u.setDoB(new java.sql.Date(dob)); u.setEmail(createUniqueName() + "a@email.org"); u.insert("password"); int id = u.getId(); - User u2 = new User(id); - assertEquals(u, u2); + User u2 = User.getById(id); + assertEquals(u.getName(), u2.getName()); + assertEquals(u.getDoB().toString(), u2.getDoB().toString()); + assertEquals(u.getEmail(), u2.getEmail()); } @Test public void testWebStoreAndLoad() throws SQLException { int id = createVerifiedUser("aä", "b", createUniqueName() + "a@email.org", TEST_PASSWORD); - User u = new User(id); - assertEquals("aä", u.getFname()); - assertEquals("b", u.getLname()); - assertEquals("", u.getMname()); + User u = User.getById(id); + assertEquals("aä", u.getFName()); + assertEquals("b", u.getLName()); + assertEquals("", u.getMName()); } @Test public void testAssurerUtilMethods() throws SQLException { int id = createAssuranceUser("aä", "b", createUniqueName() + "a@email.org", TEST_PASSWORD); - User u = new User(id); + User u = User.getById(id); assertTrue(u.canAssure()); int assurancePoints = u.getAssurancePoints(); int expPoints = u.getExperiencePoints(); @@ -55,9 +59,9 @@ public class TestUser extends ManagedTest { assertTrue(u.hasPassedCATS()); assertEquals(10, u.getMaxAssurePoints()); - assertEquals("aä", u.getFname()); - assertEquals("b", u.getLname()); - assertEquals("", u.getMname()); + assertEquals("aä", u.getFName()); + assertEquals("b", u.getLName()); + assertEquals("", u.getMName()); } @Test @@ -65,21 +69,21 @@ public class TestUser extends ManagedTest { String uq = createUniqueName(); int id = createVerifiedUser("aä", "b", uq + "a@email.org", TEST_PASSWORD); - User u = new User(id); - new EmailAddress(uq + "b@email.org", u).insert(Language.getInstance(Locale.ENGLISH)); - new EmailAddress(uq + "c@email.org", u).insert(Language.getInstance(Locale.ENGLISH)); - new Domain(u, uq + "a.testdomain.org").insert(); - new Domain(u, uq + "b.testdomain.org").insert(); - new Domain(u, uq + "c.testdomain.org").insert(); + User u = User.getById(id); + new EmailAddress(u, uq + "b@email.org").insert(Language.getInstance(Locale.ENGLISH)); + new EmailAddress(u, uq + "c@email.org").insert(Language.getInstance(Locale.ENGLISH)); + new Domain(u, uq + "a-testdomain.org").insert(); + new Domain(u, uq + "b-testdomain.org").insert(); + new Domain(u, uq + "c-testdomain.org").insert(); assertEquals(3, u.getEmails().length); assertEquals(3, u.getDomains().length); - assertTrue(u.isValidDomain(uq + "a.testdomain.org")); - assertTrue(u.isValidDomain(uq + "b.testdomain.org")); - assertTrue(u.isValidDomain(uq + "c.testdomain.org")); - assertTrue(u.isValidDomain("a." + uq + "a.testdomain.org")); - assertTrue(u.isValidDomain("*." + uq + "a.testdomain.org")); - assertFalse(u.isValidDomain("a" + uq + "a.testdomain.org")); - assertFalse(u.isValidDomain("b" + uq + "a.testdomain.org")); + assertTrue(u.isValidDomain(uq + "a-testdomain.org")); + assertTrue(u.isValidDomain(uq + "b-testdomain.org")); + assertTrue(u.isValidDomain(uq + "c-testdomain.org")); + assertTrue(u.isValidDomain("a." + uq + "a-testdomain.org")); + assertTrue(u.isValidDomain("*." + uq + "a-testdomain.org")); + assertFalse(u.isValidDomain("a" + uq + "a-testdomain.org")); + assertFalse(u.isValidDomain("b" + uq + "a-testdomain.org")); assertTrue(u.isValidEmail(uq + "a@email.org")); assertTrue(u.isValidEmail(uq + "b@email.org")); @@ -92,4 +96,43 @@ public class TestUser extends ManagedTest { } + @Test + public void testDoubleInsert() { + User u = new User(); + u.setFName("f"); + u.setLName("l"); + u.setMName("m"); + u.setSuffix("s"); + u.setEmail(createUniqueName() + "@example.org"); + u.setDoB(new Date(System.currentTimeMillis() + 1000 * 60 * 60 * 24 * 365)); + u.setPreferredLocale(Locale.ENGLISH); + u.insert(TEST_PASSWORD); + try { + u.insert(TEST_PASSWORD); + fail("Error expected"); + } catch (Error e) { + // expected + } + Assurance[] ma = u.getMadeAssurances(); + Assurance[] ma2 = u.getMadeAssurances(); + Assurance[] ra = u.getReceivedAssurances(); + Assurance[] ra2 = u.getReceivedAssurances(); + assertEquals(0, u.getCertificates(false).length); + assertEquals(0, ma.length); + assertEquals(0, ma2.length); + assertEquals(0, ra.length); + assertEquals(0, ra2.length); + assertSame(ma, ma2); + assertSame(ra, ra2); + } + + @Test + public void testGetByMail() { + String email = createUniqueName() + "a@email.org"; + int id = createVerifiedUser("aä", "b", email, TEST_PASSWORD); + User emailUser = User.getByEmail(email); + User u = User.getById(id); + assertSame(u, emailUser); + } + }