/* * Copyright (C) 2012, Katy Hilgenberg. * Special acknowledgments to: Knowledge & Data Engineering Group, University of Kassel (http://www.kde.cs.uni-kassel.de). * Contact: sdcf@cs.uni-kassel.de * * This file is part of the SDCFramework (Sensor Data Collection Framework) project. * * The SDCFramework is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * The SDCFramework 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with the SDCFramework. If not, see <http://www.gnu.org/licenses/>. */ package de.unikassel.android.sdcframework.devices.tests; import de.unikassel.android.sdcframework.data.Sample; import de.unikassel.android.sdcframework.data.independent.TimeProviderSampleData; import de.unikassel.android.sdcframework.devices.TimeProviderDevice; import de.unikassel.android.sdcframework.devices.TimeProviderDeviceScanner; import de.unikassel.android.sdcframework.devices.facade.SensorDeviceIdentifier; import de.unikassel.android.sdcframework.test.DelegatingMockContext; import de.unikassel.android.sdcframework.test.TestUtils; import de.unikassel.android.sdcframework.util.TimeProvider; import de.unikassel.android.sdcframework.util.tests.SampleEventObserverForTest; import android.test.AndroidTestCase; /** * Test for the sensor device scanner for time synchronization changes * * @author Katy Hilgenberg * */ public class TestTimeProviderDeviceScanner extends AndroidTestCase { /* * (non-Javadoc) * * @see android.test.ProviderTestCase2#setUp() */ @Override protected void setUp() throws Exception { super.setUp(); setContext( new DelegatingMockContext( getContext() ) ); super.setUp(); } /* * (non-Javadoc) * * @see android.test.AndroidTestCase#tearDown() */ @Override public void tearDown() throws Exception { super.tearDown(); } /** * Test for device and scanner creation */ public void testDeviceAndScannerCreation() { // create device and scanner and link with each other TimeProviderDevice device = new TimeProviderDevice(); TimeProviderDeviceScanner scanner = new TimeProviderDeviceScanner(); device.setScanner( scanner, getContext() ); assertFalse( "Expected device scanning disabled initally", device.isDeviceScanningEnabled() ); assertEquals( "Wrong device type", SensorDeviceIdentifier.TimeSyncStateChanges, device.getDeviceIdentifier() ); assertNull( "Expected sample initially null", device.getSample() ); assertEquals( "Expected device associated with scanner", scanner, device.getScanner() ); assertEquals( "Expected scanner associated with device", device, scanner.getDevice() ); assertFalse( "Expected scanner disabled initally", scanner.isEnabled() ); device.onDestroy( getContext() ); } /** * Test for device and scanner enable/disable */ public void testEnableDisableDeviceScanning() { // create device and scanner and link with each other TimeProviderDevice device = new TimeProviderDevice(); TimeProviderDeviceScanner scanner = new TimeProviderDeviceScanner(); device.setScanner( scanner, getContext() ); assertFalse( "Expected device scanning disabled", device.isDeviceScanningEnabled() ); assertFalse( "Expected scanner disabled", scanner.isEnabled() ); device.getConfiguration().setEnabled( true ); device.enableDeviceScanning( true, getContext() ); assertTrue( "Expected device scanning enabled", device.isDeviceScanningEnabled() ); assertTrue( "Expected scanner enabled", scanner.isEnabled() ); device.getConfiguration().setEnabled( false ); device.enableDeviceScanning( false, getContext() ); assertFalse( "Expected device scanning disabled", device.isDeviceScanningEnabled() ); assertFalse( "Expected scanner disabled", scanner.isEnabled() ); device.onDestroy( getContext() ); } /** * Test for device and scanner sample performance */ public void testSampling() { final int scanFrequency = 3000; // create a sample observer final SampleEventObserverForTest observer = new SampleEventObserverForTest(); // create and configure a device final TimeProviderDevice device = new TimeProviderDevice(); device.getConfiguration().setFrequency( scanFrequency ); device.getConfiguration().setEnabled( true ); // create scanner in looper thread to allow asynchronous event handling /** * Internal looper test thread * * @author Katy Hilgenberg * */ class LooperThread extends LooperThreadForTest { /* * (non-Javadoc) * * @see * de.unikassel.android.sdcframework.devices.tests.LooperThreadForTest# * doPrepareTest() */ @Override public void doPrepareTest() { // create the scanner in the looper thread context to implicitly // associate handler with the threads looper TimeProviderDeviceScanner scanner = new TimeProviderDeviceScanner(); // attach scanner to device device.setScanner( scanner, getContext() ); // add the event observer to the scanner scanner.registerEventObserver( observer ); } } // create a looper thread instance LooperThread looperThread = new LooperThread(); // start the looper thread and wait for preparation finished looperThread.start(); while ( !looperThread.hasPreparationDone.get() ) { TestUtils.sleep( scanFrequency / 2 ); } assertTrue( "NTP Update of time failed, enable network access for test", TimeProvider.getInstance().updateTime( getContext() ) ); TimeProvider.getInstance().updateTime( getContext() ); // disable device scanning device.enableDeviceScanning( false, getContext() ); // test for samples taken int sampleCount = observer.observedEvents.size(); assertTrue( "Expected more samples taken", sampleCount >= 1 ); Sample lastSample = null; for ( Sample sample : observer.observedEvents ) { assertEquals( "Unexpected device identifier", SensorDeviceIdentifier.TimeSyncStateChanges.toString(), sample.getDeviceIdentifier() ); assertTrue( "Unexpected sample data type", sample.getData() instanceof TimeProviderSampleData ); if ( lastSample != null ) { assertNotSame( "Expected different samples", lastSample, sample ); } lastSample = sample; } // stop looper thread device.onDestroy( getContext() ); looperThread.interrupt(); } }