/** * Copyright (c) 2011, SOCIETIES Consortium (WATERFORD INSTITUTE OF TECHNOLOGY (TSSG), HERIOT-WATT UNIVERSITY (HWU), SOLUTA.NET * (SN), GERMAN AEROSPACE CENTRE (Deutsches Zentrum fuer Luft- und Raumfahrt e.V.) (DLR), Zavod za varnostne tehnologije * informacijske družbe in elektronsko poslovanje (SETCCE), INSTITUTE OF COMMUNICATION AND COMPUTER SYSTEMS (ICCS), LAKE * COMMUNICATIONS (LAKE), INTEL PERFORMANCE LEARNING SOLUTIONS LTD (INTEL), PORTUGAL TELECOM INOVAÇÃO, SA (PTIN), IBM Corp., * INSTITUT TELECOM (ITSUD), AMITEC DIACHYTI EFYIA PLIROFORIKI KAI EPIKINONIES ETERIA PERIORISMENIS EFTHINIS (AMITEC), TELECOM * ITALIA S.p.a.(TI), TRIALOG (TRIALOG), Stiftelsen SINTEF (SINTEF), NEC EUROPE LTD (NEC)) * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following * conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT * SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package org.societies.android.tester; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.societies.api.identity.INetworkNode; import org.societies.comm.xmpp.client.impl.ClientCommunicationMgr; import android.app.Activity; import android.content.Context; import android.os.AsyncTask; import android.os.Bundle; import android.widget.TextView; /** * Activity to test the login/logout in android comms. * * @author Edgar Domingues (PTIN) * */ public class LoginTestActivity extends Activity { private static final Logger log = LoggerFactory.getLogger(TesterActivity.class); private ClientCommunicationMgr ccm; private TextView textView; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); log.debug("onCreate"); textView = new TextView(this); setContentView(textView); LoginTask task = new LoginTask(this); task.execute(); } @Override public void onDestroy() { super.onDestroy(); } private class LoginTask extends AsyncTask<Void, Void, AssertionError> { private static final String IDENTIFIER = "android", DOMAIN = "societies.local", PASSWORD = "android", INVALID_PASSWORD = "androidpass"; private Context context; public LoginTask(Context context) { this.context = context; } protected AssertionError doInBackground(Void... args) { ccm = new ClientCommunicationMgr(context); try { testLoginFromConfig(); testLogin(); testInvalidLogin(); } catch (AssertionError e) { return e; } return null; } protected void onPostExecute(AssertionError result) { if(result == null) { String text = "Test Success."; textView.setText(text); textView.setTextColor(0xFF00FF00); log.debug(text); } else { String text = "Test Failure: "+result.getMessage(); textView.setText(text); textView.setTextColor(0xFFFF0000); log.debug(text); } } private void testLoginFromConfig() { log.debug("Starting testLoginFromConfig."); if(ccm.loginFromConfig() == null) throw new AssertionError("loginFromConfig returned null."); if(!ccm.logout()) throw new AssertionError("logout returned false."); log.debug("testLoginFromConfig success."); } private void testLogin() { log.debug("Starting testLogin."); INetworkNode node = ccm.login(IDENTIFIER, DOMAIN, PASSWORD); if(node == null) throw new AssertionError("login returned null."); if(!node.getIdentifier().equals(IDENTIFIER)) throw new AssertionError("login returned node invalid identifier."); if(!node.getDomain().equals(DOMAIN)) throw new AssertionError("login returned node invalid domain."); if(!ccm.logout()) throw new AssertionError("logout returned false."); log.debug("testLogin success."); } private void testInvalidLogin() { log.debug("Starting testInvalidLogin."); INetworkNode node = ccm.login(IDENTIFIER, DOMAIN, INVALID_PASSWORD); if(node != null) throw new AssertionError("login did not return null as expected."); log.debug("testInvalidLogin success."); } } }