use of BasicCommonClasses.Ingredient in project SmartCity-Market by TechnionYP5777.
the class CommandExecuter method forceRemoveIngredient.
private void forceRemoveIngredient(SQLDatabaseConnection c) {
Ingredient ingredient = null;
log.info("Force remove ingredient from serderID " + inCommandWrapper.getSenderID() + " command called");
try {
ingredient = Serialization.deserialize(inCommandWrapper.getData(), Ingredient.class);
} catch (java.lang.RuntimeException e) {
log.fatal("Failed to parse data for Force Remove Ingredient command");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
return;
}
log.info("Trying to force remove ingredient " + ingredient + " from system");
try {
//TODO noam call here to force remove ingredient
c.removeIngredient(inCommandWrapper.getSenderID(), ingredient);
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_OK);
} catch (CriticalError e) {
log.fatal("Force Remove ingredient command failed, critical error occured from SQL Database connection");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
} catch (ClientNotConnected e) {
log.info("Force Remove ingredient customer command failed, client is not connected");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_SENDER_IS_NOT_CONNECTED);
} catch (IngredientNotExist e) {
log.info("Force Remove ingredient customer command failed, ingredient does not exist");
outCommandWrapper = new CommandWrapper(ResultDescriptor.PARAM_ID_IS_NOT_EXIST);
} catch (IngredientStillUsed e) {
log.info("Force Remove ingredient customer command failed, ingredient still in use");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_INGREDIENT_STILL_IN_USE);
}
log.info("Force Remove ingredient " + ingredient + " from system finished");
}
use of BasicCommonClasses.Ingredient in project SmartCity-Market by TechnionYP5777.
the class CommandExecuter method editIngredient.
private void editIngredient(SQLDatabaseConnection c) {
Ingredient ingredient = null;
log.info("Edit ingredient from serderID " + inCommandWrapper.getSenderID() + " command called");
try {
ingredient = Serialization.deserialize(inCommandWrapper.getData(), Ingredient.class);
} catch (java.lang.RuntimeException e) {
log.fatal("Failed to parse data for Edit Ingredient command");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
return;
}
log.info("Trying to edit ingredient " + ingredient);
try {
c.editIngredient(inCommandWrapper.getSenderID(), ingredient);
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_OK);
} catch (CriticalError e) {
log.fatal("Edit ingredient command failed, critical error occured from SQL Database connection");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
} catch (ClientNotConnected e) {
log.info("Edit ingredient customer command failed, client is not connected");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_SENDER_IS_NOT_CONNECTED);
} catch (IngredientNotExist e) {
log.info("Edit ingredient customer command failed, ingredient does not exist");
outCommandWrapper = new CommandWrapper(ResultDescriptor.PARAM_ID_IS_NOT_EXIST);
}
log.info("Edit ingredient " + ingredient + " from system finished");
}
use of BasicCommonClasses.Ingredient in project SmartCity-Market by TechnionYP5777.
the class CommandExecuter method removeIngredient.
private void removeIngredient(SQLDatabaseConnection c) {
Ingredient ingredient = null;
log.info("Remove ingredient from serderID " + inCommandWrapper.getSenderID() + " command called");
try {
ingredient = Serialization.deserialize(inCommandWrapper.getData(), Ingredient.class);
} catch (java.lang.RuntimeException e) {
log.fatal("Failed to parse data for Remove Ingredient command");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
return;
}
log.info("Trying to remove ingredient " + ingredient + " from system");
try {
c.removeIngredient(inCommandWrapper.getSenderID(), ingredient);
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_OK);
} catch (CriticalError e) {
log.fatal("Remove ingredient command failed, critical error occured from SQL Database connection");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_ERR);
} catch (ClientNotConnected e) {
log.info("Remove ingredient customer command failed, client is not connected");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_SENDER_IS_NOT_CONNECTED);
} catch (IngredientNotExist e) {
log.info("Remove ingredient customer command failed, ingredient does not exist");
outCommandWrapper = new CommandWrapper(ResultDescriptor.PARAM_ID_IS_NOT_EXIST);
} catch (IngredientStillUsed e) {
log.info("Remove ingredient customer command failed, ingredient still in use");
outCommandWrapper = new CommandWrapper(ResultDescriptor.SM_INGREDIENT_STILL_IN_USE);
}
log.info("Remove ingredient " + ingredient + " from system finished");
}
use of BasicCommonClasses.Ingredient in project SmartCity-Market by TechnionYP5777.
the class SQLDatabaseConnectionTest method testAddRemoveIngredient.
@Test
public void testAddRemoveIngredient() {
SQLDatabaseConnection sqlConnection = new SQLDatabaseConnection();
final String ingredientName = "glotendebug";
String result = null;
Ingredient ingredient = null;
//test add ingredient
try {
String tempID = sqlConnection.addIngredient(null, ingredientName);
ingredient = Serialization.deserialize(tempID, Ingredient.class);
result = sqlConnection.getIngredientsList();
} catch (CriticalError | ClientNotConnected e) {
fail();
}
assert result != null;
HashSet<Ingredient> set = Serialization.deserializeIngredientHashSet(result);
assert set != null;
assert set.contains(ingredient);
//test remove ingredient
try {
sqlConnection.removeIngredient(null, ingredient);
result = sqlConnection.getIngredientsList();
} catch (CriticalError | ClientNotConnected | IngredientNotExist | IngredientStillUsed e) {
fail();
}
assert result != null;
set = Serialization.deserializeIngredientHashSet(result);
assert set != null;
assert !set.contains(ingredient);
}
use of BasicCommonClasses.Ingredient in project SmartCity-Market by TechnionYP5777.
the class SQLDatabaseConnectionTest method testGetEmptyIngredientsList.
public void testGetEmptyIngredientsList() {
SQLDatabaseConnection sqlConnection = new SQLDatabaseConnection();
String result = null;
try {
result = sqlConnection.getIngredientsList();
} catch (CriticalError e) {
fail();
}
assert result != null;
HashSet<Ingredient> set = Serialization.deserializeIngredientHashSet(result);
assert set != null;
assert set.isEmpty();
}
Aggregations