| 1 |
|
package net.technearts; |
| 2 |
|
|
| 3 |
|
import java.util.ArrayList; |
| 4 |
|
import java.util.Arrays; |
| 5 |
|
import java.util.Collection; |
| 6 |
|
import java.util.Deque; |
| 7 |
|
import java.util.LinkedList; |
| 8 |
|
import java.util.List; |
| 9 |
|
import java.util.Map; |
| 10 |
|
import java.util.Map.Entry; |
| 11 |
|
import java.util.NavigableSet; |
| 12 |
|
import java.util.Optional; |
| 13 |
|
import java.util.Queue; |
| 14 |
|
import java.util.Set; |
| 15 |
|
import java.util.SortedSet; |
| 16 |
|
import java.util.TreeSet; |
| 17 |
|
import java.util.function.Predicate; |
| 18 |
|
|
| 19 |
|
import org.apache.commons.beanutils.PropertyUtils; |
| 20 |
|
import org.apache.commons.lang3.StringUtils; |
| 21 |
|
import org.slf4j.Logger; |
| 22 |
|
import org.slf4j.LoggerFactory; |
| 23 |
|
|
| 24 |
|
import com.google.common.collect.HashBasedTable; |
| 25 |
|
import com.google.common.collect.Table; |
| 26 |
|
|
| |
|
| 79.1% |
Uncovered Elements: 19 (91) |
Complexity: 35 |
Complexity Density: 0.64 |
|
| 27 |
|
public class Repository { |
| 28 |
|
private static final Logger LOG = LoggerFactory.getLogger("Marshaller"); |
| 29 |
|
private Table<Mapping, Integer, Object> table = HashBasedTable.create(); |
| 30 |
|
private Table<Member, Integer, String> nonMappedMembers = HashBasedTable.create(); |
| 31 |
|
private List<Predicate<Object>> entityPredicates = new ArrayList<>(); |
| 32 |
|
|
| |
|
| 75% |
Uncovered Elements: 1 (4) |
Complexity: 2 |
Complexity Density: 1 |
|
| 33 |
65 |
public void put(Mapping mapping, int line, Object value) {... |
| 34 |
65 |
if (entityPredicates.stream().allMatch(predicate -> predicate.test(value))) { |
| 35 |
65 |
table.put(mapping, line, value); |
| 36 |
|
} |
| 37 |
|
} |
| 38 |
|
|
| |
|
| 60% |
Uncovered Elements: 2 (5) |
Complexity: 2 |
Complexity Density: 0.67 |
|
| 39 |
40 |
public Object get(String name, int line) {... |
| 40 |
40 |
if (name == null) { |
| 41 |
0 |
throw new IllegalArgumentException("Nome não pode ser nulo"); |
| 42 |
|
} |
| 43 |
40 |
return table.column(line).entrySet().stream() |
| 44 |
|
.filter(entry -> name.equals(entry.getKey().getName())).findFirst().orElse(null); |
| 45 |
|
} |
| 46 |
|
|
| |
|
| 83.3% |
Uncovered Elements: 1 (6) |
Complexity: 2 |
Complexity Density: 0.5 |
|
| 47 |
15 |
public Map<Integer, Object> get(String name) {... |
| 48 |
15 |
for (Entry<Mapping, Map<Integer, Object>> entry : table.rowMap().entrySet()) { |
| 49 |
45 |
if (name.equals(entry.getKey().getName())) { |
| 50 |
15 |
return entry.getValue(); |
| 51 |
|
} |
| 52 |
|
} |
| 53 |
0 |
return null; |
| 54 |
|
} |
| 55 |
|
|
| |
|
| 83.3% |
Uncovered Elements: 1 (6) |
Complexity: 2 |
Complexity Density: 0.5 |
|
| 56 |
5 |
public Map<Integer, Object> get(Class<?> klazz) {... |
| 57 |
5 |
for (Entry<Mapping, Map<Integer, Object>> entry : table.rowMap().entrySet()) { |
| 58 |
15 |
if (klazz.getName().equals(entry.getKey().getClassName())) { |
| 59 |
5 |
return entry.getValue(); |
| 60 |
|
} |
| 61 |
|
} |
| 62 |
0 |
return null; |
| 63 |
|
} |
| 64 |
|
|
| |
|
| 0% |
Uncovered Elements: 1 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 65 |
0 |
public void addFilter(Predicate<Object> predicate) {... |
| 66 |
0 |
entityPredicates.add(predicate); |
| 67 |
|
} |
| 68 |
|
|
| |
|
| 81.2% |
Uncovered Elements: 9 (48) |
Complexity: 11 |
Complexity Density: 0.34 |
|
| 69 |
155 |
@SuppressWarnings("unchecked")... |
| 70 |
|
public final <T, V> void set(final T bean, final Member member, final V value, String separator, |
| 71 |
|
List<Mapping> mappings) { |
| 72 |
155 |
final String name = member.getProperty(); |
| 73 |
155 |
final String mappedBy = member.getMappedBy(); |
| 74 |
155 |
final String converter = member.getConverter(); |
| 75 |
155 |
try { |
| 76 |
155 |
Class<T> klass = (Class<T>) PropertyUtils.getPropertyType(bean, name); |
| 77 |
155 |
if (Arrays.asList(klass.getInterfaces()).contains(Collection.class)) { |
| 78 |
30 |
Collection<V> c = (Collection<V>) PropertyUtils.getProperty(bean, name); |
| 79 |
30 |
if (c == null) { |
| 80 |
30 |
c = (Collection<V>) newCollectionInstance(klass); |
| 81 |
30 |
PropertyUtils.setProperty(bean, name, c); |
| 82 |
|
} |
| 83 |
30 |
if (value == null) { |
| 84 |
10 |
return; |
| 85 |
|
} |
| 86 |
|
|
| 87 |
20 |
if (!member.isReferenceBased()) { |
| 88 |
0 |
c.add(value); |
| 89 |
0 |
return; |
| 90 |
|
} |
| 91 |
|
|
| 92 |
20 |
for (String o : value.toString().split(separator)) { |
| 93 |
30 |
if (StringUtils.isBlank(mappedBy)) { |
| 94 |
15 |
c.add((V) o); |
| 95 |
|
} else { |
| 96 |
15 |
for (Object v : this.get(converter).values()) { |
| 97 |
30 |
try { |
| 98 |
30 |
String property = mappedBy; |
| 99 |
30 |
Optional<Mapping> optionalMapping = mappings.stream() |
| 100 |
|
.filter(mapping -> mapping.getName().equals(converter)).findFirst(); |
| 101 |
30 |
if (optionalMapping.isPresent()) { |
| 102 |
30 |
Member m = optionalMapping.get().getMember(mappedBy); |
| 103 |
30 |
if (m != null) { |
| 104 |
0 |
property = m.getProperty(); |
| 105 |
|
} else { |
| 106 |
|
|
| 107 |
|
} |
| 108 |
|
} else { |
| 109 |
|
|
| 110 |
|
} |
| 111 |
30 |
String element = PropertyUtils.getProperty(v, property).toString().trim(); |
| 112 |
30 |
if (o.trim().equals(element)) { |
| 113 |
15 |
c.add((V) v); |
| 114 |
|
} |
| 115 |
|
} catch (NullPointerException e) { |
| 116 |
0 |
throw new IllegalArgumentException( |
| 117 |
|
"Mapeamento " + mappedBy + " da classe " + converter + " não encontrado."); |
| 118 |
|
} |
| 119 |
|
} |
| 120 |
|
} |
| 121 |
|
} |
| 122 |
|
} else { |
| 123 |
125 |
PropertyUtils.setProperty(bean, name, value); |
| 124 |
|
} |
| 125 |
|
} catch (ReflectiveOperationException e) { |
| 126 |
0 |
LOG.error( |
| 127 |
|
"A propriedade " + name + " não foi encontrada em " + bean.getClass().getSimpleName()); |
| 128 |
|
} |
| 129 |
|
} |
| 130 |
|
|
| |
|
| 75% |
Uncovered Elements: 3 (12) |
Complexity: 14 |
Complexity Density: 1.75 |
|
| 131 |
60 |
@SuppressWarnings("unchecked")... |
| 132 |
|
private <T> T newCollectionInstance(Class<T> klass) { |
| 133 |
60 |
T t = null; |
| 134 |
60 |
try { |
| 135 |
60 |
t = (T) klass.newInstance(); |
| 136 |
|
} catch (NullPointerException | InstantiationException | IllegalAccessException e) { |
| 137 |
30 |
if (NavigableSet.class.equals(klass) || Set.class.equals(klass) |
| 138 |
|
|| SortedSet.class.equals(klass) |
| 139 |
|
|| Arrays.asList(klass.getInterfaces()).contains(NavigableSet.class) |
| 140 |
|
|| Arrays.asList(klass.getInterfaces()).contains(Set.class) |
| 141 |
|
|| Arrays.asList(klass.getInterfaces()).contains(SortedSet.class)) { |
| 142 |
0 |
t = (T) newCollectionInstance(TreeSet.class); |
| 143 |
30 |
} else if (List.class.equals(klass) || Queue.class.equals(klass) || Deque.class.equals(klass) |
| 144 |
|
|| Arrays.asList(klass.getInterfaces()).contains(List.class) |
| 145 |
|
|| Arrays.asList(klass.getInterfaces()).contains(Queue.class) |
| 146 |
|
|| Arrays.asList(klass.getInterfaces()).contains(Deque.class)) { |
| 147 |
30 |
t = (T) newCollectionInstance(LinkedList.class); |
| 148 |
|
} |
| 149 |
|
} |
| 150 |
60 |
return t; |
| 151 |
|
} |
| 152 |
|
|
| |
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
| 153 |
10 |
public <T, V> void set(Member member, int line, V value) {... |
| 154 |
10 |
nonMappedMembers.put(member, line, value.toString()); |
| 155 |
|
} |
| 156 |
|
} |