Skip to content

Package: MergeManagerImpl

MergeManagerImpl

nameinstructionbranchcomplexitylinemethod
MergeManagerImpl(UnitOfWorkImpl)
M: 0 C: 10
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 4
100%
M: 0 C: 1
100%
deleteObjectFromCache(ObjectChangeSet)
M: 4 C: 13
76%
M: 1 C: 1
50%
M: 1 C: 1
50%
M: 0 C: 4
100%
M: 0 C: 1
100%
mergeChangesFromChangeSet(UnitOfWorkChangeSet)
M: 0 C: 30
100%
M: 0 C: 2
100%
M: 0 C: 2
100%
M: 0 C: 7
100%
M: 0 C: 1
100%
mergeChangesOnObject(ObjectChangeSet)
M: 16 C: 20
56%
M: 4 C: 2
33%
M: 3 C: 1
25%
M: 4 C: 7
64%
M: 0 C: 1
100%
mergeNewObject(ObjectChangeSet)
M: 0 C: 15
100%
M: 0 C: 2
100%
M: 0 C: 2
100%
M: 0 C: 6
100%
M: 0 C: 1
100%
static {...}
M: 0 C: 1
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
updateCache(ObjectChangeSet)
M: 0 C: 43
100%
M: 0 C: 4
100%
M: 0 C: 3
100%
M: 0 C: 9
100%
M: 0 C: 1
100%

Coverage

1: /**
2: * Copyright (C) 2020 Czech Technical University in Prague
3: *
4: * This program is free software: you can redistribute it and/or modify it under
5: * the terms of the GNU General Public License as published by the Free Software
6: * Foundation, either version 3 of the License, or (at your option) any
7: * later version.
8: *
9: * This program is distributed in the hope that it will be useful, but WITHOUT
10: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11: * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
12: * details. You should have received a copy of the GNU General Public License
13: * along with this program. If not, see <http://www.gnu.org/licenses/>.
14: */
15: package cz.cvut.kbss.jopa.sessions;
16:
17: import cz.cvut.kbss.jopa.exceptions.OWLPersistenceException;
18: import cz.cvut.kbss.jopa.utils.EntityPropertiesUtils;
19:
20: import java.util.Objects;
21:
22: public class MergeManagerImpl implements MergeManager {
23:
24: protected UnitOfWorkImpl uow;
25:
26: protected CloneBuilder builder;
27:
28: MergeManagerImpl(UnitOfWorkImpl session) {
29: this.uow = session;
30: this.builder = session.getCloneBuilder();
31: }
32:
33: private void deleteObjectFromCache(ObjectChangeSet changeSet) {
34: Object toDelete = changeSet.getChangedObject();
35:• assert toDelete != null;
36: uow.removeObjectFromCache(toDelete, changeSet.getEntityContext());
37: }
38:
39: @Override
40: public Object mergeChangesOnObject(ObjectChangeSet changeSet) {
41: Objects.requireNonNull(changeSet);
42: final Object clone = changeSet.getCloneObject();
43:• if (clone == null) {
44: return null;
45: }
46:• if (changeSet.getChangedObject() == null) {
47: // If the original is null, then we may have a new object
48: // but this should not happen since new objects are handled separately
49:• if (uow.isObjectNew(clone)) {
50: mergeNewObject(changeSet);
51: } else {
52: throw new OWLPersistenceException("Cannot find the original object.");
53: }
54: } else {
55: builder.mergeChanges(changeSet);
56: updateCache(changeSet);
57: }
58: return clone;
59: }
60:
61: private void updateCache(ObjectChangeSet changeSet) {
62: final Object changedObject = changeSet.getChangedObject();
63: final Object identifier = EntityPropertiesUtils.getIdentifier(changedObject, uow.getMetamodel());
64:• if (changeSet.isNew()) {
65: uow.putObjectIntoCache(identifier, changedObject, changeSet.getEntityDescriptor());
66: } else {
67: boolean preventCaching = changeSet.getChanges().stream().anyMatch(ChangeRecord::doesPreventCaching);
68:• if (preventCaching) {
69: uow.removeObjectFromCache(changedObject, changeSet.getEntityContext());
70: } else {
71: uow.putObjectIntoCache(identifier, changedObject, changeSet.getEntityDescriptor());
72: }
73: }
74: }
75:
76: @Override
77: public void mergeChangesFromChangeSet(UnitOfWorkChangeSet changeSet) {
78: Objects.requireNonNull(changeSet);
79:• for (ObjectChangeSet objectChangeSet : changeSet.getExistingObjectsChanges()) {
80: mergeChangesOnObject(objectChangeSet);
81: }
82: changeSet.getNewObjects().forEach(this::mergeNewObject);
83: changeSet.getDeletedObjects().forEach(this::deleteObjectFromCache);
84:
85: }
86:
87: @Override
88: public void mergeNewObject(ObjectChangeSet changeSet) {
89: Objects.requireNonNull(changeSet);
90:• if (!changeSet.isNew()) {
91: mergeChangesOnObject(changeSet);
92: return;
93: }
94: // Put the original object into the shared session cache
95: updateCache(changeSet);
96: }
97: }