/** * Revenue Settlement and Sharing System GE * Copyright (C) 2011-2014, Javier Lucio - lucio@tid.es * Telefonica Investigacion y Desarrollo, S.A. * * 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.controller; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.junit.After; import org.junit.Assert; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.Mockito; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.util.ReflectionTestUtils; import org.springframework.ui.ModelMap; import es.upm.fiware.rss.common.test.DatabaseLoader; import es.upm.fiware.rss.oauth.model.OauthLoginWebSessionData; import es.upm.fiware.rss.service.SettlementManager; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; public class SettlementControllerTest { /*** * Logging system. */ private final Logger logger = LoggerFactory.getLogger(SettlementControllerTest.class); /** * */ @Autowired private DatabaseLoader databaseLoader; /** * */ private SettlementManager settlementManager; /** * */ @Autowired private SettlementController controller; /** * */ private HttpServletResponse response; /** * */ private HttpServletRequest request; /** * */ private HttpSession session; /** * */ private ModelMap model; /** * */ private OauthLoginWebSessionData sessionData; /** * User session attribute. */ private final String USER_SESSION = "userSession"; /** * */ private ServletOutputStream output; /** * Method to insert data before test. * * @throws Exception * from dbb */ @Before public void setUp() throws Exception { model = new ModelMap(); sessionData = new OauthLoginWebSessionData(); // prepare mockito request = Mockito.mock(HttpServletRequest.class); response = Mockito.mock(HttpServletResponse.class); session = Mockito.mock(HttpSession.class); output = Mockito.mock(ServletOutputStream.class); Mockito.when(request.getSession()).thenReturn(session); settlementManager = Mockito.mock(SettlementManager.class); ReflectionTestUtils.setField(controller, "settlementManager", settlementManager); } /** * */ @Transactional(propagation = Propagation.SUPPORTS) public void testSettlement() { logger.debug("into testLogout method"); String response = controller.settlement(null, model); Assert.assertEquals("error", response); logger.debug("Correct logout"); response = controller.settlement(request, model); Assert.assertEquals("settlement", response); logger.debug("Correct logout with session data"); Mockito.when(session.getAttribute(USER_SESSION)).thenReturn(sessionData); response = controller.settlement(request, model); Assert.assertEquals("settlement", response); } /** * */ public void testViewTransactions() throws Exception { logger.debug("into viewTransactions method"); ReflectionTestUtils.setField(controller, "settlementManager", null); String response = controller.viewTransactions(null, model); Assert.assertEquals("error", response); logger.debug("Correct logout"); ReflectionTestUtils.setField(controller, "settlementManager", settlementManager); response = controller.viewTransactions("aggregatorId", model); Assert.assertEquals("viewTransactions", response); } }