]> git.basschouten.com Git - openhab-addons.git/blob
d159dd5416f903680563fa93f28c625fff618d85
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2021 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.miele.internal;
14
15 import static org.junit.jupiter.api.Assertions.*;
16
17 import org.junit.jupiter.api.Test;
18 import org.openhab.core.library.types.QuantityType;
19 import org.openhab.core.library.unit.SIUnits;
20 import org.openhab.core.test.java.JavaTest;
21 import org.openhab.core.types.UnDefType;
22
23 /**
24  * This class provides test cases for {@link
25  * org.openhab.binding.miele.internal.DeviceUtil}
26  *
27  * @author Jacob Laursen - Initial contribution
28  */
29
30 public class DeviceUtilTest extends JavaTest {
31
32     @Test
33     public void bytesToHexWhenTopBitIsUsedReturnsCorrectString() {
34         String actual = DeviceUtil.bytesToHex(new byte[] { (byte) 0xde, (byte) 0xad, (byte) 0xbe, (byte) 0xef });
35         assertEquals("DEADBEEF", actual);
36     }
37
38     /**
39      * This test guards that the UTF-16 returned by the RPC-JSON API will be
40      * considered as a sequence of 8-bit characters and converted into bytes
41      * accordingly. Default behaviour of String.getBytes() assumes UTF-8
42      * and adds a 0xc2 byte before any character out of ASCII range.
43      */
44     @Test
45     public void stringToBytesWhenTopBitIsUsedReturnsSingleByte() {
46         byte[] expected = new byte[] { (byte) 0x00, (byte) 0x80, (byte) 0x00 };
47         byte[] actual = DeviceUtil.stringToBytes("\u0000\u0080\u0000");
48         assertArrayEquals(expected, actual);
49     }
50
51     @Test
52     public void getTemperatureStateWellFormedValueReturnsQuantityType() throws NumberFormatException {
53         assertEquals(new QuantityType<>(42, SIUnits.CELSIUS), DeviceUtil.getTemperatureState("42"));
54     }
55
56     @Test
57     public void getTemperatureStateMagicValueReturnsUndefined() throws NumberFormatException {
58         assertEquals(UnDefType.UNDEF, DeviceUtil.getTemperatureState("32768"));
59     }
60
61     @Test
62     public void getTemperatureStateNonNumericValueThrowsNumberFormatException() {
63         assertThrows(NumberFormatException.class, () -> DeviceUtil.getTemperatureState("A"));
64     }
65
66     @Test
67     public void getTemperatureStateNullValueThrowsNumberFormatException() {
68         assertThrows(NumberFormatException.class, () -> DeviceUtil.getTemperatureState(null));
69     }
70 }