All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.srang.datafactory.BaseFieldPopulationStrategyImpl Maven / Gradle / Ivy

There is a newer version: 1.0.1
Show newest version
package com.github.srang.datafactory;

/*-
 * #%L
 * Data Factory
 * %%
 * Copyright (C) 2017 srang
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */

import com.github.javafaker.Faker;
import com.github.srang.datafactory.util.DateUtil;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.text.ParseException;
import java.util.*;

/**
 * 

BaseFieldPopulationStrategyImpl class.

* * @author srang */ public class BaseFieldPopulationStrategyImpl extends BaseFieldPopulationStrategy { /** *

Constructor for BaseFieldPopulationStrategyImpl.

* * @param faker a {@link com.github.javafaker.Faker} object. */ public BaseFieldPopulationStrategyImpl(Faker faker) { super(faker); ignoreField("serialversionuid"); addBaseFilters(); } /** {@inheritDoc} */ @Override public boolean populateField(Object obj, Field field) throws ObjectFieldGenerationException,MalformedFilterException { return this.doFilter(obj, field); } /** {@inheritDoc} */ @Override public void addFilter(Method filter) throws MalformedFilterException { if ((filter.getReturnType().equals(Boolean.class) || filter.getReturnType().equals(boolean.class)) && filter.getParameterCount() == 3 && filter.getParameterTypes()[0].equals(Faker.class) && filter.getParameterTypes()[1].equals(Field.class) && filter.getParameterTypes()[2].equals(Object.class)) { addFilter(new Filter(new FilterProcessorImpl(filter))); } else { throw new MalformedFilterException("Provided filter method did not match the required signature. No filter added"); } } /** {@inheritDoc} */ @Override public void ignoreField(String ignoredField) { this.ignoredFields.add(ignoredField.toLowerCase()); } /** {@inheritDoc} */ @Override public void addFilter(FilterProcessor processor) { addFilter(new Filter(processor)); } private void addBaseFilters() { //base string this.addFilter( (Field field) -> field.getType().equals(String.class), () -> faker.lorem().word() ); // base integer this.addFilter( (Field field) -> field.getType().equals(Integer.class), () -> faker.number().numberBetween(0, Integer.MAX_VALUE) ); // base big decimal this.addFilter( (Field field) -> field.getType().equals(BigDecimal.class), () -> new BigDecimal(faker.number().randomDouble(2, 1, 5000)) ); // base big decimal this.addFilter( (Field field) -> field.getType().equals(Long.class), () -> new Long(faker.number().numberBetween(Integer.MAX_VALUE, Long.MAX_VALUE)) ); // baseDate this.addFilter( (Field field) -> field.getType().equals(Date.class), () -> { Date date; try { date = faker.date().between(DateUtil.getDateOnlyFromString("1901-01-01"), DateUtil.getDateOnlyFromString("2016-01-01")); } catch (ParseException e) { date = new Date(); } return date; } ); // birthDate this.addFilter( (Field field) -> field.getType().equals(Date.class) && field.getName().toLowerCase().contains("birthdate"), () -> { Date date; try { date = faker.date().between(DateUtil.getDateOnlyFromString("1901-01-01"), DateUtil.getDateOnlyFromString("2006-01-01")); } catch (ParseException e) { date = new Date(); } return date; } ); // lastName this.addFilter( (Field field) -> field.getType().equals(String.class) && field.getName().toLowerCase().contains("lastname"), () -> faker.name().lastName() ); // firstName this.addFilter( (Field field) -> field.getType().equals(String.class) && field.getName().toLowerCase().contains("firstname"), () -> faker.name().firstName() ); String[] filters = { "organization", // "address" // }; } /** *

doFilter.

* * @param obj a {@link java.lang.Object} object. * @param field a {@link java.lang.reflect.Field} object. * @return a boolean. * @throws com.github.srang.datafactory.ObjectFieldGenerationException if any. * @throws com.github.srang.datafactory.MalformedFilterException if any. */ protected boolean doFilter(Object obj, Field field) throws ObjectFieldGenerationException,MalformedFilterException { for (Filter filter : filters) { if (filter.apply(faker, field, obj)) { return true; } } return false; } protected class FilterProcessorImpl implements FilterProcessor { private Method filter; public FilterProcessorImpl(Method filter) { this.filter = filter; } public boolean process(Faker faker, Field field, Object obj) throws ObjectFieldGenerationException,MalformedFilterException { try { if ((Boolean) filter.invoke("", faker, field, obj)) { return true; } } catch (IllegalAccessException | InvocationTargetException e) { if (e.getCause() instanceof ObjectFieldGenerationException) { throw (ObjectFieldGenerationException) e.getCause(); } throw new MalformedFilterException("Failed to invoke filter with provided method " + filter.getName(), e); } return false; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy