1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
package at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.service;
import static org.junit.Assert.assertEquals;
import at.ac.tuwien.sepm.assignment.groupphase.exception.InvalidOperationException;
import at.ac.tuwien.sepm.assignment.groupphase.exception.ServiceException;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.EmployeeDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.EmployeeDatabaseDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.OperationDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.OperationDatabaseDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.RegistrationDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.RegistrationDatabaseDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.VehicleDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dao.VehicleDatabaseDAO;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dto.Operation;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dto.Operation.Status;
import at.ac.tuwien.sepm.assignment.groupphase.missioncontrol.dto.Vehicle;
import at.ac.tuwien.sepm.assignment.groupphase.util.Helper;
import at.ac.tuwien.sepm.assignment.groupphase.util.JdbcTestCase;
import java.util.Set;
import org.dbunit.Assertion;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.ITable;
import org.junit.Test;
public class OperationServiceIntegrationTest extends JdbcTestCase {
private OperationService operationService;
private Operation o;
public OperationServiceIntegrationTest() {
EmployeeDAO employeeDAO = new EmployeeDatabaseDAO(getJdbcConnectionManager());
RegistrationDAO registrationDAO =
new RegistrationDatabaseDAO(getJdbcConnectionManager(), employeeDAO);
VehicleDAO vehicleDAO =
new VehicleDatabaseDAO(
getJdbcConnectionManager(), (RegistrationDatabaseDAO) registrationDAO);
OperationDAO operationDAO =
new OperationDatabaseDAO(
getJdbcConnectionManager(),
vehicleDAO,
(RegistrationDatabaseDAO) registrationDAO);
VehicleService vehicleService = new VehicleServiceImpl(vehicleDAO);
operationService = new OperationServiceImpl(operationDAO, vehicleDAO, vehicleService);
Vehicle v1 =
Vehicle.builder()
.id(1)
.name("RTW-1")
.constructionType(Vehicle.ConstructionType.HOCHDACH)
.type(Vehicle.VehicleType.RTW)
.status(Vehicle.Status.FREI_FUNK)
.hasNef(true)
.build();
Vehicle v2 = v1.toBuilder().id(2).build();
Vehicle v3 = v1.toBuilder().id(3).build();
o =
Operation.builder()
.opCode("RD-2B0M")
.status(Status.ACTIVE)
.vehicles(Set.of(v1, v2, v3))
.destination("New destination")
.additionalInfo("New information")
.build();
}
@Override
protected IDataSet getDataSet() throws Exception {
return getDataSet("operationDAOUpdateSetup.xml");
}
@Test
public void addValidOperation() throws Exception {
long id = operationService.add(o);
assertEquals(2, id);
String tableName = "Operation";
String[] excludedColumns = new String[] {"created"};
ITable actual =
Helper.getActualFilteredTableData(getConnection(), tableName, excludedColumns);
ITable expected =
Helper.getExpectedFilteredTableData(
tableName, excludedColumns, "operationDAOAddOperation.xml");
Assertion.assertEquals(expected, actual);
}
@Test(expected = InvalidOperationException.class)
public void addInvalidOperation() throws InvalidOperationException, ServiceException {
operationService.add(o.toBuilder().opCode("").build());
}
}
|