2016-01-30 05:30:12 -05:00
|
|
|
import com.google.protobuf.InvalidProtocolBufferException;
|
2016-01-16 09:57:12 -05:00
|
|
|
import junit.framework.TestCase;
|
2016-01-30 05:30:12 -05:00
|
|
|
import meerkat.RegistryCallBack;
|
2016-01-23 12:16:57 -05:00
|
|
|
import meerkat.SimpleRegistry;
|
2016-01-30 05:30:12 -05:00
|
|
|
import meerkat.VoterRegistryMessage;
|
2016-01-23 12:16:57 -05:00
|
|
|
import meerkat.bulletinboard.SimpleBulletinBoardClient;
|
|
|
|
import meerkat.crypto.concrete.ECElGamalEncryption;
|
|
|
|
import meerkat.crypto.concrete.ECElGamalUtils;
|
2016-01-30 05:30:12 -05:00
|
|
|
import meerkat.protobuf.BulletinBoardAPI;
|
2016-01-23 12:16:57 -05:00
|
|
|
import meerkat.protobuf.ConcreteCrypto;
|
|
|
|
import meerkat.protobuf.Voting;
|
|
|
|
import org.factcenter.qilin.primitives.concrete.ECElGamal;
|
|
|
|
import org.factcenter.qilin.primitives.concrete.ECGroup;
|
|
|
|
import util.RegistryTags;
|
|
|
|
import util.SimpleRegistryCallBackHandler;
|
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
import java.lang.reflect.InvocationTargetException;
|
2016-01-23 12:16:57 -05:00
|
|
|
import java.math.BigInteger;
|
2016-01-30 05:30:12 -05:00
|
|
|
import java.security.SecureRandom;
|
2016-01-23 12:16:57 -05:00
|
|
|
import java.security.spec.InvalidKeySpecException;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.List;
|
2016-01-30 05:30:12 -05:00
|
|
|
|
|
|
|
import static util.CollectionMessagesUtils.ConvertToVoterRegistryMessages;
|
|
|
|
import static util.CollectionMessagesUtils.GetUnsignedBulletinBoardMessages;
|
2016-01-16 09:57:12 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Created by Vladimir Eliezer Tokarev on 1/16/2016.
|
|
|
|
* Tests the Simple Registry contents
|
2016-01-23 12:16:57 -05:00
|
|
|
* NOTE: for most of this tests to pass there should run BulletinBoardServer
|
2016-01-30 05:30:12 -05:00
|
|
|
* that should be reachable on BULLETIN_BOARD_SERVER_ADDRESS
|
2016-01-16 09:57:12 -05:00
|
|
|
*/
|
2016-01-30 05:30:12 -05:00
|
|
|
public class SimpleRegistryTest extends TestCase {
|
2016-01-16 09:57:12 -05:00
|
|
|
|
2016-01-23 12:16:57 -05:00
|
|
|
private ECElGamalEncryption signatory;
|
|
|
|
private SimpleBulletinBoardClient communicator;
|
2016-01-30 05:30:12 -05:00
|
|
|
private static String BULLETIN_BOARD_SERVER_ADDRESS = "http://localhost:8081";
|
|
|
|
private SecureRandom random = new SecureRandom();
|
2016-01-30 12:19:25 -05:00
|
|
|
private List<List<String>> votersData;
|
2016-01-23 12:16:57 -05:00
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
/**
|
|
|
|
* Creates the ElGamal encryption object
|
|
|
|
*/
|
|
|
|
private void ElGamalSetup() {
|
2016-01-23 12:16:57 -05:00
|
|
|
try {
|
|
|
|
ECGroup group = new ECGroup("secp256k1");
|
|
|
|
BigInteger sk = ECElGamal.generateSecretKey(group, random);
|
|
|
|
ECElGamal.SK key = new ECElGamal.SK(group, sk);
|
|
|
|
ConcreteCrypto.ElGamalPublicKey serializedPk = ECElGamalUtils.serializePk(group, key);
|
|
|
|
signatory = new ECElGamalEncryption();
|
|
|
|
signatory.init(serializedPk);
|
|
|
|
} catch (InvalidKeySpecException e) {
|
2016-01-30 05:30:12 -05:00
|
|
|
assertTrue(false);
|
2016-01-23 12:16:57 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
/**
|
|
|
|
* Creates the communication object (the bulletinBoardClient)
|
|
|
|
*/
|
|
|
|
private void CommunicatorSetup() {
|
2016-01-23 12:16:57 -05:00
|
|
|
communicator = new SimpleBulletinBoardClient();
|
|
|
|
communicator.init(Voting.BulletinBoardClientParams.newBuilder()
|
|
|
|
.addBulletinBoardAddress(BULLETIN_BOARD_SERVER_ADDRESS)
|
|
|
|
.setMinRedundancy((float) 1.0)
|
|
|
|
.build());
|
|
|
|
}
|
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
|
|
|
|
private SimpleRegistryCallBackHandler RegistryAnswersHandlerSetup() {
|
|
|
|
return new SimpleRegistryCallBackHandler();
|
2016-01-23 12:16:57 -05:00
|
|
|
}
|
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
/**
|
2016-01-16 09:57:12 -05:00
|
|
|
* Initialize SimpleRegistry object
|
|
|
|
*/
|
2016-01-30 05:30:12 -05:00
|
|
|
public void setUp() {
|
2016-01-23 12:16:57 -05:00
|
|
|
ElGamalSetup();
|
|
|
|
CommunicatorSetup();
|
2016-01-30 12:19:25 -05:00
|
|
|
votersData = null;
|
2016-01-23 12:16:57 -05:00
|
|
|
}
|
2016-01-16 09:57:12 -05:00
|
|
|
|
2016-01-23 12:16:57 -05:00
|
|
|
/**
|
|
|
|
* Checks if the creation of the registry have been successful
|
|
|
|
*/
|
2016-01-30 05:30:12 -05:00
|
|
|
public void testSimpleRegistryCreation() {
|
2016-01-23 12:16:57 -05:00
|
|
|
try {
|
2016-01-30 05:30:12 -05:00
|
|
|
new SimpleRegistry(signatory, communicator);
|
|
|
|
} catch (Exception e) {
|
2016-01-23 12:16:57 -05:00
|
|
|
assert false : "While creating the SimpleRegistry exception have been thrown " + e;
|
|
|
|
}
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-30 05:30:12 -05:00
|
|
|
* Creates list of lists of strings for different testing purposes
|
|
|
|
* @param actionDataNumber number of string in a list
|
|
|
|
* @param numberOfInstances number of lists in a list
|
2016-01-30 12:19:25 -05:00
|
|
|
* @return
|
2016-01-16 09:57:12 -05:00
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
private void setActionsData(int actionDataNumber, int numberOfInstances)
|
2016-01-30 05:30:12 -05:00
|
|
|
{
|
|
|
|
System.out.println("- Creating "+ numberOfInstances +" ids and personal data strings for adding different voters.");
|
2016-01-30 12:19:25 -05:00
|
|
|
if (votersData != null){
|
|
|
|
return;
|
|
|
|
}
|
2016-01-23 12:16:57 -05:00
|
|
|
|
2016-01-30 12:19:25 -05:00
|
|
|
votersData = new ArrayList<>();
|
2016-01-30 05:30:12 -05:00
|
|
|
for (int i = 0 ; i < numberOfInstances ; i++ ){
|
|
|
|
List<String> data = new ArrayList<>();
|
|
|
|
for (int j = 0 ; j < actionDataNumber ; j++){
|
|
|
|
data.add(new BigInteger(130, random).toString(32));
|
|
|
|
}
|
2016-01-30 12:19:25 -05:00
|
|
|
votersData.add(data);
|
2016-01-23 12:16:57 -05:00
|
|
|
}
|
2016-01-30 05:30:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Counts the amount of posted messaages that have their tags in voterData
|
|
|
|
* @param votersData List<List<String>> of information about voters (tags etc...)
|
|
|
|
* @param tags List<String> of tags
|
|
|
|
* @return int
|
|
|
|
* @throws InvalidProtocolBufferException
|
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
private int countActualAddedMessages(List<List<String>> votersData, List<String> tags, SimpleRegistry registry) throws InvalidProtocolBufferException {
|
2016-01-30 05:30:12 -05:00
|
|
|
System.out.println("- Check that the server have the new voters data:");
|
|
|
|
|
2016-01-30 12:19:25 -05:00
|
|
|
BulletinBoardAPI.MessageFilterList filters = registry.GetRelevantMessages(tags);
|
2016-01-30 05:30:12 -05:00
|
|
|
List<VoterRegistryMessage> messages =
|
|
|
|
ConvertToVoterRegistryMessages(GetUnsignedBulletinBoardMessages(communicator.readMessages(filters)));
|
|
|
|
|
2016-01-30 12:19:25 -05:00
|
|
|
assert messages.size() > 0 : " The filtered messages are empty ( wrong filtering or server down)";
|
2016-01-30 05:30:12 -05:00
|
|
|
int addedMessagesCounter = 0;
|
2016-01-23 12:16:57 -05:00
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
for (List<String> voterData : votersData) {
|
|
|
|
for (VoterRegistryMessage message : messages) {
|
|
|
|
String addedVoterId = message.GetWantedTagFromBasicMessage(RegistryTags.ID_TAG);
|
|
|
|
String addedVoterData = new String(message.base.getData().toByteArray());
|
2016-01-23 12:16:57 -05:00
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
if (voterData.size() == 2 && addedVoterId.contains(voterData.get(0)) && addedVoterData.contains(voterData.get(1))) {
|
|
|
|
addedMessagesCounter++;
|
|
|
|
}
|
|
|
|
else if (addedVoterId.contains(voterData.get(0)) ){
|
|
|
|
addedMessagesCounter++;
|
|
|
|
}
|
|
|
|
}
|
2016-01-23 12:16:57 -05:00
|
|
|
}
|
2016-01-30 05:30:12 -05:00
|
|
|
return addedMessagesCounter;
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
2016-01-30 05:30:12 -05:00
|
|
|
/**
|
|
|
|
* Call methodToCheck voterData as list of params
|
|
|
|
* @param methodToCheck the name of the wanted method
|
|
|
|
* @param numberOfParamsWithoutHandler the amount of params to pass to the wanted method
|
|
|
|
* @param handler object which method will be called as callback from SimpleRegistry
|
|
|
|
* @param registry the simpleRegistry object
|
|
|
|
* @param voterData List of string which is the params to pass to the wantedMethod
|
|
|
|
*/
|
|
|
|
private void CallWantedMethod(String methodToCheck, int numberOfParamsWithoutHandler,
|
|
|
|
SimpleRegistryCallBackHandler handler, SimpleRegistry registry,
|
|
|
|
List<String> voterData) {
|
|
|
|
try {
|
|
|
|
if (numberOfParamsWithoutHandler == 1)
|
|
|
|
{
|
|
|
|
java.lang.reflect.Method method =
|
|
|
|
registry.getClass().getMethod(methodToCheck,String.class, RegistryCallBack.class);
|
|
|
|
method.invoke(registry, voterData.get(0), handler);
|
|
|
|
assertTrue(handler.ActionSucceed);
|
|
|
|
}else {
|
|
|
|
java.lang.reflect.Method method =
|
|
|
|
registry.getClass().getMethod( methodToCheck, String.class, String.class, RegistryCallBack.class);
|
|
|
|
method.invoke(registry, voterData.get(0), voterData.get(1), handler);
|
|
|
|
assertTrue(handler.ActionSucceed);
|
|
|
|
}
|
|
|
|
} catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates new Registry information then sends it to the server then checks the server
|
|
|
|
* have all sent data
|
|
|
|
* @param methodToCheck the name of the method we want to call in SimpleRegistry
|
|
|
|
* @param numberOfParamsToPass the number of params to pass to the methodToCheck
|
|
|
|
* @param numberOfChecks the amount of checks to run
|
|
|
|
* @param tags list of String that represent the tags to filter on the messages
|
2016-01-30 12:19:25 -05:00
|
|
|
* @return Returns the information that was send in the created messages
|
2016-01-30 05:30:12 -05:00
|
|
|
* @throws InvalidProtocolBufferException
|
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
private List<List<String>> checkMessagesPostedSuccessfully(String methodToCheck, int numberOfParamsToPass, int numberOfChecks, List<String> tags) throws InvalidProtocolBufferException {
|
2016-01-30 05:30:12 -05:00
|
|
|
SimpleRegistryCallBackHandler handler = RegistryAnswersHandlerSetup();
|
|
|
|
System.out.println("Starting testing the " + methodToCheck + " capability.");
|
2016-01-30 12:19:25 -05:00
|
|
|
setActionsData(numberOfParamsToPass, numberOfChecks);
|
2016-01-30 05:30:12 -05:00
|
|
|
|
|
|
|
SimpleRegistry registry = new SimpleRegistry(signatory, communicator);
|
|
|
|
|
|
|
|
System.out.println("- Check that all the callbacks have been called successfully after voters adding:");
|
|
|
|
for (List<String> voterData : votersData) {
|
|
|
|
CallWantedMethod(methodToCheck, numberOfParamsToPass, handler, registry, voterData);
|
|
|
|
}
|
|
|
|
|
2016-01-30 12:19:25 -05:00
|
|
|
System.out.println("- Check that for every data added, the callback have been called:");
|
2016-01-30 05:30:12 -05:00
|
|
|
assertEquals(numberOfChecks, handler.counter);
|
2016-01-30 12:19:25 -05:00
|
|
|
int addedMessagesCounter = countActualAddedMessages(votersData, tags, registry);
|
2016-01-30 05:30:12 -05:00
|
|
|
|
|
|
|
assert addedMessagesCounter == numberOfChecks : "The number of added messages actually is " + addedMessagesCounter;
|
|
|
|
System.out.println("Ended addVoter testing.");
|
2016-01-30 12:19:25 -05:00
|
|
|
return votersData;
|
2016-01-30 05:30:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test that add voter creates new correct bulletin board message and adds the voter
|
|
|
|
*/
|
|
|
|
public void testAddVoter() throws InvalidProtocolBufferException {
|
|
|
|
checkMessagesPostedSuccessfully("AddVoter", 2, 3,
|
|
|
|
new ArrayList<String>(){{add(RegistryTags.VOTER_ENTRY_TAG.toString());}});
|
|
|
|
}
|
2016-01-23 12:16:57 -05:00
|
|
|
|
2016-01-16 09:57:12 -05:00
|
|
|
/**
|
|
|
|
* Test that set voted posts creates correct bulletin board message and sets that the user have been voted
|
|
|
|
*/
|
2016-01-30 05:30:12 -05:00
|
|
|
public void testSetVoted() throws InvalidProtocolBufferException {
|
|
|
|
checkMessagesPostedSuccessfully("SetVoted", 1, 3,
|
|
|
|
new ArrayList<String>(){{add(RegistryTags.VOTE_ACTION_TAG.toString());}});
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test that add to group creates correct bulletin board message and adds a user to a group
|
|
|
|
*/
|
2016-01-30 05:30:12 -05:00
|
|
|
public void testRemoveFromGroup() throws InvalidProtocolBufferException {
|
|
|
|
checkMessagesPostedSuccessfully("RemoveFromGroup", 2, 3, null);
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-30 12:19:25 -05:00
|
|
|
* Test that get groups retrieves the right groups the user are in
|
2016-01-16 09:57:12 -05:00
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
public void testAddToGroup() throws InvalidProtocolBufferException {
|
|
|
|
checkMessagesPostedSuccessfully("AddToGroup", 2, 4, null);
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-30 12:19:25 -05:00
|
|
|
* Test that remove from group creates correct bulletin board message and removes the user from a group
|
2016-01-16 09:57:12 -05:00
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
public void testGetGroups() throws InvalidProtocolBufferException, InterruptedException {
|
|
|
|
System.out.println("Starting testing the GetGroups capability.");
|
|
|
|
List<List<String>> votersData = checkMessagesPostedSuccessfully("AddToGroup", 2, 3, null);
|
|
|
|
|
|
|
|
SimpleRegistry registry = new SimpleRegistry(signatory, communicator);
|
|
|
|
SimpleRegistryCallBackHandler handler = RegistryAnswersHandlerSetup();
|
|
|
|
|
|
|
|
System.out.println("- Checks that every group id we added to every voter really exists:");
|
|
|
|
for (List<String> voterData : votersData){
|
|
|
|
registry.GetGroups(voterData.get(1), handler);
|
|
|
|
|
|
|
|
assert handler.ActionSucceed : " The SimpleRegistry could not complete the GetGroups action ";
|
|
|
|
assert handler.WantedInformation.contains(RegistryTags.GROUP_ID_TAG + voterData.get(1))
|
|
|
|
: " The SimpleRegistry cloud not get the right group of the user " + voterData.get(1);
|
|
|
|
}
|
|
|
|
System.out.println("Ended GetGroups testing.");
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
|
2016-01-30 12:19:25 -05:00
|
|
|
|
|
|
|
|
2016-01-16 09:57:12 -05:00
|
|
|
/**
|
|
|
|
* Test that the personal data outputted about the user is right
|
|
|
|
*/
|
2016-01-30 12:19:25 -05:00
|
|
|
public void testGetPersonalIDDetails() throws InvalidProtocolBufferException, InterruptedException {
|
|
|
|
System.out.println("Starting testing the GetPersonIDDetails capability:");
|
|
|
|
List<List<String>> addedVotersInformation = checkMessagesPostedSuccessfully("AddVoter", 2, 3,
|
|
|
|
new ArrayList<String>(){{add(RegistryTags.VOTER_ENTRY_TAG.toString());}});
|
|
|
|
|
|
|
|
SimpleRegistry registry = new SimpleRegistry(signatory, communicator);
|
|
|
|
SimpleRegistryCallBackHandler handler = RegistryAnswersHandlerSetup();
|
|
|
|
|
|
|
|
System.out.println("- Check that every added voter can be retrieved by SimpleRegistry:");
|
|
|
|
|
|
|
|
for (List<String> voterInformation : addedVotersInformation) {
|
|
|
|
registry.GetPersonIDDetails(voterInformation.get(0), handler);
|
|
|
|
|
|
|
|
assert handler.ActionSucceed : " Getting personal data for voter with id : "
|
|
|
|
+ voterInformation.get(0) + " failed";
|
|
|
|
assert handler.WantedInformation.get(0).contains(voterInformation.get(0))
|
|
|
|
: " Voter with id " + voterInformation.get(0) + " have bot been added to the voter db.";
|
|
|
|
}
|
|
|
|
assert handler.counter == 3 : " The callback method have not been called 3 times";
|
|
|
|
System.out.println("Ended the GetPersonIDDetails capability");
|
2016-01-16 09:57:12 -05:00
|
|
|
}
|
|
|
|
}
|