Skip to main content
summaryrefslogtreecommitdiffstats
blob: 395b5dd8f4c1dc5ee59995fd485d12f1d9a9388f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*******************************************************************************
 * Copyright (c) 2004, 2007 Boeing.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     Boeing - initial API and implementation
 *******************************************************************************/
package org.eclipse.osee.ote.message.test.element;

import java.util.Random;
import junit.framework.Assert;
import org.eclipse.osee.ote.message.data.HeaderData;
import org.eclipse.osee.ote.message.data.MemoryResource;
import org.eclipse.osee.ote.message.elements.Float64Element;
import org.junit.Test;

public class Float64ElementTest {

   @Test
   public void testFloat64() {
      final HeaderData hd = new HeaderData("test_data", new MemoryResource(new byte[64], 0, 64));
      Float64Element[] e = new Float64Element[8];
      for (int i = 0; i < e.length; i++) {
         e[i] = new Float64Element(null, "Float64@" + i, hd, i * 8, 0, 63);
      }
      Random r = new Random(System.currentTimeMillis());
      double[] vals = new double[e.length];
      for (int i = 0; i < 1000; i++) {
         generateAscending(r, e, vals, e.length);
         check(e, vals, e.length);

         generateDescending(r, e, vals, e.length);
         check(e, vals, e.length);

         // zeroize test
         for (int z = 0; z < e.length; z += 2) {
            e[z].zeroize();
            vals[z] = 0;
         }

         check(e, vals, e.length);
      }
   }

   private void generateAscending(Random r, Float64Element[] e, double[] expectedVals, int length) {
      for (int i = 0; i < length; i++) {
         double val = r.nextDouble();
         Float64Element el = e[i];
         el.setValue(val);
         expectedVals[i] = val;
         if (el.getValue() != expectedVals[i]) {
            Assert.failNotEquals(
               String.format("set/get fail on %s: msb=%d, lsb=%d", el.getName(), el.getMsb(), el.getLsb()),
               expectedVals[i], el.getValue());
         }

      }
   }

   private void generateDescending(Random r, Float64Element[] e, double[] expectedVals, int length) {
      for (int i = length - 1; i >= 0; i--) {
         double val = r.nextDouble();
         Float64Element el = e[i];
         el.setValue(val);
         expectedVals[i] = val;
         if (el.getValue() != expectedVals[i]) {
            Assert.failNotEquals(
               String.format("set/get fail on %s: msb=%d, lsb=%d", el.getName(), el.getMsb(), el.getLsb()),
               Double.toHexString(expectedVals[i]), Double.toHexString(el.getValue()));
         }
      }
   }

   private void check(Float64Element[] e, double[] expectedVals, int length) {
      for (int i = 0; i < length; i++) {
         Float64Element el = e[i];
         if (el.getValue() != expectedVals[i]) {
            Assert.failNotEquals(
               String.format("corruption detect on %s: msb=%d, lsb=%d", el.getName(), el.getMsb(), el.getLsb()),
               expectedVals[i], e[i].getValue());
         }

         String v = Double.toString(expectedVals[i]);
         if (!el.valueOf().equals(v)) {
            Assert.failNotEquals(
               String.format("set/get fail on %s: msb=%d, lsb=%d", el.getName(), el.getMsb(), el.getLsb()), v,
               el.valueOf());
         }
      }
   }
}

Back to the top