/**
* Revenue Settlement and Sharing System GE
* Copyright (C) 2011-2014, Javier Lucio - lucio@tid.es
* Telefonica Investigacion y Desarrollo, S.A.
*
* Copyright (C) 2015, CoNWeT Lab., Universidad Politécnica de Madrid
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package es.upm.fiware.rss.expenditureLimit.manager.test;
import java.math.BigDecimal;
import javax.sql.DataSource;
import org.junit.After;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import es.upm.fiware.rss.common.test.DatabaseLoader;
import es.upm.fiware.rss.exception.RSSException;
import es.upm.fiware.rss.expenditureLimit.api.LimitBean;
import es.upm.fiware.rss.expenditureLimit.server.service.ExpenditureLimitDataChecker;
import es.upm.fiware.rss.expenditureLimit.test.ExpenditureLimitBeanConstructor;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
public class ExpenditureLimitDataCheckerTest {
/**
* Logging system.
*/
private static Logger logger = LoggerFactory.getLogger(ExpenditureLimitDataCheckerTest.class);
@Autowired
private DataSource dataSource;
@Autowired
private DatabaseLoader databaseLoader;
@Autowired
private ExpenditureLimitDataChecker checker;
@Rule
public ExpectedException thrown = ExpectedException.none();
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkChargeRequiredParametersTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkChargeRequiredParametersTest mehtod");
thrown.expect(RSSException.class);
thrown
.expectMessage("Required parameters not found:enUserId, service, appProvider, currency, chargeType, amount.");
checker.checkChargeRequiredParameters("urlEndUserId", "service", "aggId","appPorviderId", "currency", "chargeType",
new BigDecimal(10));
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkChargeRequiredParameters(null, "service", "aggId","appPorviderId", "currency", "chargeType",
new BigDecimal(10));
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkRequiredParametersTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkChargeRequiredParametersTest mehtod");
thrown.expect(RSSException.class);
thrown
.expectMessage("Required parameters not found:enUserId, service, appProvider, currency.");
checker.checkRequiredParameters("urlEndUserId", "service", "aggId", "appPorviderId", "currency");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkRequiredParameters(null, "service", "aggId", "appPorviderId", "currency");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkRequiredSearchParametersTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkRequiredSearchParametersTest mehtod");
thrown.expect(RSSException.class);
thrown
.expectMessage("Required parameters not found:enUserId, service, appProvider.");
checker.checkRequiredSearchParameters("urlEndUserId", "service", "aggId", "appPorviderId");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkRequiredSearchParameters(null, "service", "aggId", "appPorvider");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkCurrencyTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkCurrencyTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("Currency Not found.");
checker.checkCurrency("EUR");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkCurrency("dbc");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkServiceTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkServiceTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("Service Not found.");
//checker.checkService("ServiceTest1");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
//checker.checkService("bluevia");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkDbeAppProviderTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkDbeAppProviderTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("AppProvider Not found.");
checker.checkDbeAppProvider("agg123", "app123456");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkDbeAppProvider("agg123", "newone");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkElTypeTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkElTypeTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("eltype Not found.");
checker.checkElType("monthly");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkElType("bbb");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkChargeTypeTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkChargeTypeTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("chageType Not found.");
checker.checkChargeType("C");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkChargeType("N");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkMandatoryDatumExistenceTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkMandatoryDatumExistenceTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("datumName");
checker.checkMandatoryDatumExistence("datum", "datumName");
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
checker.checkMandatoryDatumExistence(null, "datumName");
}
/**
*
*/
@Transactional(propagation = Propagation.SUPPORTS)
public void checkExpLimitDataTest() throws RSSException {
ExpenditureLimitDataCheckerTest.logger.debug("Into checkExpLimitDataTest mehtod");
thrown.expect(RSSException.class);
thrown.expectMessage("Missing mandatory parameter: Limit Currency");
LimitBean limitBean = ExpenditureLimitBeanConstructor.createExpCtrlBean();
checker.checkExpLimitData(limitBean);
ExpenditureLimitDataCheckerTest.logger.debug("No exception expected");
limitBean.setCurrency(null);
checker.checkExpLimitData(limitBean);
}
}