diff options
author | Abyss777 <abyss@fox5.ru> | 2017-05-10 13:27:49 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2017-05-12 17:55:01 +0500 |
commit | 6c17f85d04b224ff2a09265918765c9f4fc8cf94 (patch) | |
tree | 5bbebd7f66b5af547267751fdb4de21283489716 /test/org/traccar | |
parent | 4ce5dd893d3b95fc759fd1d0e0dbf09d0d559936 (diff) | |
download | traccar-server-6c17f85d04b224ff2a09265918765c9f4fc8cf94.tar.gz traccar-server-6c17f85d04b224ff2a09265918765c9f4fc8cf94.tar.bz2 traccar-server-6c17f85d04b224ff2a09265918765c9f4fc8cf94.zip |
Implement computed attributes
Diffstat (limited to 'test/org/traccar')
-rw-r--r-- | test/org/traccar/processing/ComputedAttributesTest.java | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/test/org/traccar/processing/ComputedAttributesTest.java b/test/org/traccar/processing/ComputedAttributesTest.java new file mode 100644 index 000000000..432f1b9ad --- /dev/null +++ b/test/org/traccar/processing/ComputedAttributesTest.java @@ -0,0 +1,37 @@ +package org.traccar.processing; + +import org.junit.Assert; +import org.junit.Test; +import org.traccar.model.Attribute; +import org.traccar.model.Position; + +public class ComputedAttributesTest { + + @Test + public void testComputedAttributes() { + Position position = new Position(); + ComputedAttributesHandler computedAttributesHandler = new ComputedAttributesHandler(); + position.set("adc1", 128); + position.set("booleanFlag", true); + position.set("adc2", 100); + position.set("bitFlag", 7); + position.set("event", 42); + Attribute attribute = new Attribute(); + + attribute.setExpression("position.getInteger(\"adc1\")"); + Assert.assertEquals(128, computedAttributesHandler.computeAttribute(attribute, position)); + + attribute.setExpression("!position.getBoolean(\"booleanFlag\")"); + Assert.assertEquals(false, computedAttributesHandler.computeAttribute(attribute, position)); + + attribute.setExpression("position.getInteger(\"adc2\") * 2 + 50"); + Assert.assertEquals(250, computedAttributesHandler.computeAttribute(attribute, position)); + + attribute.setExpression("(position.getLong(\"bitFlag\") & 4) != 0"); + Assert.assertEquals(true, computedAttributesHandler.computeAttribute(attribute, position)); + + attribute.setExpression("if (position.getLong(\"event\") == 42) \"lowBattery\""); + Assert.assertEquals("lowBattery", computedAttributesHandler.computeAttribute(attribute, position)); + } + +} |