/* * 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.data.tests; import de.unikassel.android.sdcframework.data.independent.AbstractSampleData; import de.unikassel.android.sdcframework.data.independent.AccelerometerSampleData; import de.unikassel.android.sdcframework.data.independent.GlobalSerializer; import de.unikassel.android.sdcframework.data.independent.SampleData; import junit.framework.TestCase; /** * Tests for the accelerometer samples. * * @author Katy Hilgenberg * */ public class TestAccelerometerSampleData extends TestCase { /** * Test method for construction, setter and getter. */ public final void testAccelerometerSampleData() { AccelerometerSampleData sampleData = new AccelerometerSampleData(); assertEquals( "Expected acceleration X uninitialized ", 0.0, sampleData.getAccelerationX(), 0.000000001 ); assertEquals( "Expected acceleration Y uninitialized ", 0.0, sampleData.getAccelerationY(), 0.000000001 ); assertEquals( "Expected acceleration Z uninitialized ", 0.0, sampleData.getAccelerationZ(), 0.000000001 ); assertNull( "Expected no related data", sampleData.getRelatedData() ); // test setter with getter float accX = 0.2F; sampleData.setAccelerationX( accX ); assertEquals( "Expected acceleration X set", accX, sampleData.getAccelerationX() ); float accY = 0.3F; sampleData.setAccelerationY( accY ); assertEquals( "Expected acceleration X set", accY, sampleData.getAccelerationY(), 0.000000001 ); float accZ = 0.4F; sampleData.setAccelerationZ( accZ ); assertEquals( "Expected acceleration X set", accZ, sampleData.getAccelerationZ() ); // test copy construction assertEquals( "Expected equal sample", sampleData, new AccelerometerSampleData( sampleData ) ); } /** * Test method for equal comparison */ public final void testEquals() { AbstractSampleData sampleData = createInitializedAccelerometerSampleData(); assertEquals( "Expected object equal to itself", sampleData, sampleData ); assertFalse( "Expected object not equal to an uninitialized sample", sampleData.equals( new AccelerometerSampleData() ) ); } /** * Test method for serialization. */ public final void testSerialization() { // create the test sample AccelerometerSampleData accSampleData = createInitializedAccelerometerSampleData(); SampleData sampleData = accSampleData; String sResult; try { // serialize to String sResult = sampleData.toXML(); // serialize to object sampleData = GlobalSerializer.fromXML( AccelerometerSampleData.class, sResult ); } catch ( Exception e ) { e.printStackTrace(); fail( "Unexpected exception during serialization to string" ); } assertEquals( "Expected object serialized from string equal to the original source", accSampleData, sampleData ); } /** * Does create initialized accelerometer sample * * @return the initialized accelerometer sample */ public static AccelerometerSampleData createInitializedAccelerometerSampleData() { AccelerometerSampleData sample = new AccelerometerSampleData(); sample.setAccelerationX( 1.5F ); sample.setAccelerationY( -0.5F ); sample.setAccelerationZ( 8.91F ); return sample; } }