/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
// www.projectforge.org
//
// Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de)
//
// ProjectForge is dual-licensed.
//
// This community edition is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published
// by the Free Software Foundation; version 3 of the License.
//
// This community edition 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 General
// Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, see http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////
package org.projectforge.web.meb;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNull;
import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.reset;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import org.junit.Test;
import org.projectforge.common.TestHelper;
import org.projectforge.core.ConfigXml;
import org.projectforge.meb.MebDao;
import org.projectforge.meb.MebEntryDO;
import org.projectforge.test.TestBase;
import org.projectforge.user.PFUserDO;
public class SMSReceiverServletTest extends TestBase
{
private static Logger loggerSpy;
private MebDao mebDao;
@Test
public void receiveSMS() throws Exception
{
final String origKey = (String)TestHelper.getDeclaredFieldValue(ConfigXml.getInstance(), "receiveSmsKey");
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", "otieZae9Aiphai5o");
init();
logon(TEST_ADMIN_USER);
PFUserDO user = new PFUserDO();
user.setUsername("MebTestUser");
user.setPersonalMebMobileNumbers("(0170) 12345678, 0170/987654");
user = userDao.getById(userDao.save(user));
reset(loggerSpy);
SMSReceiverServlet servlet = new SMSReceiverServlet();
HttpServletRequest request = mockRequest("otieZae9Aiphai5o", "20100521172833", "0170 12345678", "Hello world.");
final HttpServletResponse response = mockResponse("");
servlet.doGet(request, response);
verify(loggerSpy, never()).warn(anyString());
List<MebEntryDO> list = mebDao.internalLoadAll();
assertEquals(1, list.size());
assertEquals(user.getId(), list.get(0).getOwnerId());
servlet.doGet(request, response);
assertEquals(1, mebDao.internalLoadAll().size());
request = mockRequest("otieZae9Aiphai5o", "20100521172833", "0170 987654", "Hello world.");
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "20100521172833", "034567890", "Unknown sender.");
servlet.doGet(request, response);
list = mebDao.internalLoadAll();
assertEquals(3, list.size());
for (final MebEntryDO entry : list) {
if (entry.getMessage().equals("Hello world.") == true) {
assertEquals(user.getId(), entry.getOwnerId());
} else {
assertNull(entry.getOwnerId());
}
}
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", origKey);
}
@Test
public void receiveSMSWithWrongRequest() throws Exception
{
final String origKey = (String)TestHelper.getDeclaredFieldValue(ConfigXml.getInstance(), "receiveSmsKey");
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", null);
init();
final Logger mebDaoLoggerSpy = spy(Logger.getLogger(MebDao.class));
TestHelper.setDeclaredStaticField(MebDao.class, "log", mebDaoLoggerSpy);
SMSReceiverServlet servlet = new SMSReceiverServlet();
HttpServletRequest request = mockRequest("wrongKey", null, null, null);
final HttpServletResponse response = mockResponse("");
servlet.doGet(request, response);
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", "otieZae9Aiphai5o");
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", null, null, null);
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "date", null, null);
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "date", "0170m123456", null);
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "date", "0170m123456", "Hello");
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "1274480915", "0170m123456", "Hello");
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "3000000000", "0170m123456", "Hello");
servlet.doGet(request, response);
request = mockRequest("otieZae9Aiphai5o", "20sjhj4567", "0170m123456", "Hello");
servlet.doGet(request, response);
verify(loggerSpy).warn("Servlet call for receiving sms ignored because receiveSmsKey is not given in config.xml file.");
verify(loggerSpy).warn("Servlet call for receiving sms ignored because receiveSmsKey does not match given key: wrongKey");
verify(loggerSpy).warn("Servlet call for receiving sms ignored because parameter 'date' is not given.");
verify(loggerSpy).warn("Servlet call for receiving sms ignored because parameter 'sender' is not given.");
verify(loggerSpy).warn("Servlet call for receiving sms ignored because parameter 'msg' is not given.");
final String logMsg1 = "Servlet call for receiving sms ignored because date string is not parseable (format '"
+ MebDao.DATE_FORMAT
+ "' expected): ";
final String logMsg2 = "Servlet call for receiving sms ignored because date string is not parseable (millis since 01/01/1970 or format '"
+ MebDao.DATE_FORMAT
+ "' expected): ";
final String logMsg3 = "Servlet call for receiving sms ignored because date string is not parseable (format '"
+ MebDao.DATE_FORMAT
+ "' expected): ";
verify(mebDaoLoggerSpy).warn(logMsg1 + "date");
verify(mebDaoLoggerSpy).warn(logMsg2 + "1274480915");
verify(mebDaoLoggerSpy).warn(logMsg2 + "3000000000");
verify(mebDaoLoggerSpy).warn(logMsg3 + "20sjhj4567");
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", origKey);
}
private HttpServletRequest mockRequest(final String key, final String date, final String sender, final String msg)
{
final HttpServletRequest request = mock(HttpServletRequest.class);
when(request.getParameter("key")).thenReturn(key);
when(request.getParameter("date")).thenReturn(date);
when(request.getParameter("sender")).thenReturn(sender);
when(request.getParameter("msg")).thenReturn(msg);
return request;
}
private HttpServletResponse mockResponse(final String result)
{
final HttpServletResponse response = mock(HttpServletResponse.class);
try {
when(response.getWriter()).thenReturn(new PrintWriter(new StringWriter()));
} catch (IOException ex) {
throw new RuntimeException(ex);
}
return response;
}
public void init()
{
if (loggerSpy == null) {
loggerSpy = spy(Logger.getLogger(SMSReceiverServlet.class));
TestHelper.setDeclaredField(ConfigXml.getInstance(), "receiveSmsKey", "otieZae9Aiphai5o");
TestHelper.setDeclaredStaticField(SMSReceiverServlet.class, "log", loggerSpy);
}
}
public void setMebDao(MebDao mebDao)
{
this.mebDao = mebDao;
}
}