You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@johnzon.apache.org by sa...@apache.org on 2014/09/11 20:29:24 UTC

[08/22] renamed fleece to johnzon

http://git-wip-us.apache.org/repos/asf/incubator-johnzon/blob/6e86a53e/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectBuilderImplTest.java
----------------------------------------------------------------------
diff --git a/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectBuilderImplTest.java b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectBuilderImplTest.java
new file mode 100644
index 0000000..098967e
--- /dev/null
+++ b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectBuilderImplTest.java
@@ -0,0 +1,35 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.johnzon.core;
+
+import static org.junit.Assert.assertEquals;
+
+import javax.json.Json;
+import javax.json.JsonObjectBuilder;
+
+import org.junit.Test;
+
+public class JsonObjectBuilderImplTest {
+    @Test
+    public void build() {
+        final JsonObjectBuilder builder = Json.createObjectBuilder();
+        builder.add("a", "b");
+        assertEquals("{\"a\":\"b\"}", builder.build().toString());
+    }
+}

http://git-wip-us.apache.org/repos/asf/incubator-johnzon/blob/6e86a53e/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectImplTest.java
----------------------------------------------------------------------
diff --git a/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectImplTest.java b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectImplTest.java
new file mode 100644
index 0000000..6f4ba86
--- /dev/null
+++ b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonObjectImplTest.java
@@ -0,0 +1,35 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.johnzon.core;
+
+import static org.junit.Assert.assertEquals;
+
+import javax.json.Json;
+import javax.json.JsonObjectBuilder;
+
+import org.junit.Test;
+
+public class JsonObjectImplTest {
+    @Test
+    public void objectToString() {
+        final JsonObjectBuilder ob = Json.createObjectBuilder();
+        ob.add("a", new JsonStringImpl("b"));
+        assertEquals("{\"a\":\"b\"}", ob.build().toString());
+    }
+}

http://git-wip-us.apache.org/repos/asf/incubator-johnzon/blob/6e86a53e/johnzon-core/src/test/java/org/apache/johnzon/core/JsonParserTest.java
----------------------------------------------------------------------
diff --git a/johnzon-core/src/test/java/org/apache/johnzon/core/JsonParserTest.java b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonParserTest.java
new file mode 100644
index 0000000..745132b
--- /dev/null
+++ b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonParserTest.java
@@ -0,0 +1,1419 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.johnzon.core;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertTrue;
+import static org.junit.Assert.fail;
+
+import java.io.ByteArrayInputStream;
+import java.io.CharArrayReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.math.BigDecimal;
+import java.nio.charset.Charset;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.NoSuchElementException;
+
+import javax.json.Json;
+import javax.json.JsonArray;
+import javax.json.JsonArrayBuilder;
+import javax.json.JsonException;
+import javax.json.JsonObjectBuilder;
+import javax.json.JsonReader;
+import javax.json.stream.JsonParser;
+import javax.json.stream.JsonParser.Event;
+import javax.json.stream.JsonParsingException;
+
+import org.junit.Test;
+
+public class JsonParserTest {
+    
+    
+    static final Charset UTF_8 = Charset.forName("UTF-8");
+    static final Charset UTF_16BE = Charset.forName("UTF-16BE");
+    static final Charset UTF_16LE = Charset.forName("UTF-16LE");
+    static final Charset UTF_16 = Charset.forName("UTF-16");
+    static final Charset UTF_32LE = Charset.forName("UTF-32LE");
+    static final Charset UTF_32BE = Charset.forName("UTF-32BE");
+    
+    public JsonParserTest() {
+        super();
+        if (!Charset.defaultCharset().equals(Charset.forName("UTF-8"))) {
+            throw new RuntimeException("Default charset is " + Charset.defaultCharset() + ", must must be UTF-8");
+        }
+    }
+
+    private void assertSimple(final JsonParser parser) {
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("a", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_STRING, event);
+            assertEquals("b", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("c", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(4, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("d", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_ARRAY, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(1, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(-2, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_ARRAY, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_OBJECT, event);
+        }
+        {
+            assertFalse(parser.hasNext());
+        }
+        parser.close();
+    }
+
+    @Test
+    public void array() {
+        final JsonReader loadInMemReader = Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/array.json"));
+        assertNotNull(loadInMemReader);
+        final JsonArray array = loadInMemReader.readArray();
+        assertNotNull(array);
+
+        final JsonParser parser = Json.createParserFactory(Collections.<String, Object>emptyMap()).createParser(array);
+        assertNotNull(parser);
+
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_ARRAY, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_STRING, event);
+            assertEquals("a", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(1, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("b", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_STRING, event);
+            assertEquals("c", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(5, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_ARRAY, event);
+        }
+        {
+            assertFalse(parser.hasNext());
+        }
+    }
+
+    @Test
+    public void simpleInMemory() {
+        final JsonObjectBuilder ob = Json.createObjectBuilder();
+        ob.add("a", new JsonStringImpl("b"));
+        ob.add("c", new JsonNumberImpl(new BigDecimal(4)));
+        JsonArrayBuilder ab = Json.createArrayBuilder();
+        ab.add(new JsonNumberImpl(new BigDecimal(1)));
+        ab.add(new JsonNumberImpl(new BigDecimal(-2)));
+        
+        ob.add("d", ab);
+
+        final JsonParser parser = Json.createParserFactory(Collections.<String, Object>emptyMap()).createParser(ob.build());
+        assertNotNull(parser);
+        assertSimple(parser);
+    }
+
+    @Test
+    public void simple() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple.json"));
+        assertNotNull(parser);
+        assertSimple(parser);
+    }
+    
+    @Test
+    public void simpleUTF16LE() {
+        final JsonParser parser = Json.createParserFactory(null).createParser(Thread.currentThread()
+                .getContextClassLoader().getResourceAsStream("json/simple_utf16le.json"),UTF_16LE);
+        assertNotNull(parser);
+        assertSimple(parser);
+    }
+    
+    @Test
+    public void simpleUTF16LEAutoDetect() {
+        final JsonParser parser = Json.createParserFactory(null).createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple_utf16le.json"));
+        assertNotNull(parser);
+        assertSimple(parser);
+    }
+    
+
+    @Test
+    public void nested() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/nested.json"));
+        assertNotNull(parser);
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("a", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_STRING, event);
+            assertEquals("b", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("c", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("d", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_ARRAY, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(1, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertEquals(2, parser.getInt());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_ARRAY, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_OBJECT, event);
+        }
+        {
+            assertFalse(parser.hasNext());
+        }
+        parser.close();
+    }
+
+    
+    @Test
+    public void numbers() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/numbers.json"));
+        assertNotNull(parser);
+        parser.next();
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(0, parser.getInt());
+            assertEquals(0, parser.getLong());
+            assertEquals(new BigDecimal(0), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(0, parser.getInt());
+            assertEquals(0, parser.getLong());
+            assertEquals(new BigDecimal(0), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(1, parser.getInt());
+            assertEquals(1, parser.getLong());
+            assertEquals(new BigDecimal(1), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(-1, parser.getInt());
+            assertEquals(-1L, parser.getLong());
+            assertEquals(new BigDecimal(-1), parser.getBigDecimal());
+        }
+
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(9, parser.getInt());
+            assertEquals(9L, parser.getLong());
+            assertEquals(new BigDecimal(9), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(-9, parser.getInt());
+            assertEquals(-9, parser.getLong());
+            assertEquals(new BigDecimal(-9), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(10, parser.getInt());
+            assertEquals(10, parser.getLong());
+            assertEquals(new BigDecimal(10), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(-10, parser.getInt());
+            assertEquals(-10, parser.getLong());
+            assertEquals(new BigDecimal(-10), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(100, parser.getInt());
+            assertEquals(100, parser.getLong());
+            assertEquals(new BigDecimal(100), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(-100, parser.getInt());
+            assertEquals(-100, parser.getLong());
+            assertEquals(new BigDecimal(-100), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(456, parser.getInt());
+            assertEquals(456, parser.getLong());
+            assertEquals(new BigDecimal(456), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            assertEquals(-456, parser.getInt());
+            assertEquals(-456, parser.getLong());
+            assertEquals(new BigDecimal(-456), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(!parser.isIntegralNumber());
+            assertEquals(123, parser.getInt());
+            assertEquals(123, parser.getLong());
+            assertEquals(new BigDecimal("123.12345"), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(!parser.isIntegralNumber());
+            assertEquals(-123, parser.getInt());
+            assertEquals(-123, parser.getLong());
+            assertEquals(new BigDecimal("-123.12345"), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            //assertEquals(Integer.MAX_VALUE, parser.getInt());
+            //assertEquals(Long.MAX_VALUE, parser.getLong());
+            assertEquals(new BigDecimal("999999999999999999999999999999"), parser.getBigDecimal());
+        }
+        parser.next();
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertTrue(parser.isIntegralNumber());
+            //assertEquals(Integer.MIN_VALUE, parser.getInt());
+            //assertEquals(Long.MIN_VALUE, parser.getLong());
+            assertEquals(new BigDecimal("-999999999999999999999999999999"), parser.getBigDecimal());
+        }
+        parser.next();
+        
+        {
+            assertFalse(parser.hasNext());
+        }
+        parser.close();
+    }
+    
+    
+    @Test
+    public void bigdecimal() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/bigdecimal.json"));
+        assertNotNull(parser);
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.START_OBJECT, event);
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("a", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertFalse(parser.isIntegralNumber());
+            assertEquals(new BigDecimal("1.23E3"), parser.getBigDecimal());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("b", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertFalse(parser.isIntegralNumber());
+            assertEquals(new BigDecimal("1.23E-3"), parser.getBigDecimal());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.KEY_NAME, event);
+            assertEquals("c", parser.getString());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.VALUE_NUMBER, event);
+            assertFalse(parser.isIntegralNumber());
+            assertEquals(new BigDecimal("1.23E+3"), parser.getBigDecimal());
+        }
+        {
+            assertTrue(parser.hasNext());
+            final JsonParser.Event event = parser.next();
+            assertNotNull(event);
+            assertEquals(JsonParser.Event.END_OBJECT, event);
+        }
+        {
+            assertFalse(parser.hasNext());
+        }
+        parser.close();
+    }
+    
+    @Test(expected=IllegalStateException.class)
+    public void isIntegralThrowsISE() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/bigdecimal.json"));
+        assertNotNull(parser);
+        assertTrue(parser.hasNext());
+        final JsonParser.Event event = parser.next();
+        assertNotNull(event);
+        assertEquals(JsonParser.Event.START_OBJECT, event);
+        assertFalse(parser.isIntegralNumber());
+            
+    }
+    
+    @Test
+    public void escaping() {
+        final JsonParser parser = Json.createParser(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/escaping.json"));
+        parser.next();
+        parser.next();
+        assertEquals("\"", parser.getString());
+        parser.next();
+        assertEquals("\\", parser.getString());
+        parser.next();
+        assertEquals("/", parser.getString());
+        parser.next();
+        assertEquals("\b", parser.getString());
+        parser.next();
+        assertEquals("\f", parser.getString());
+        parser.next();
+        assertEquals("\n", parser.getString());
+        parser.next();
+        assertEquals("\r", parser.getString());
+        parser.next();
+        assertEquals("\t", parser.getString());
+        parser.next();
+        assertEquals("D", parser.getString());
+        parser.next();
+        assertFalse(parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void escapedStringAwareParser() {
+        final JsonParser parser = Json.createParser(Thread.currentThread()
+                .getContextClassLoader().getResourceAsStream("json/stringescape.json"));
+        parser.next();
+        parser.next();
+        parser.next();
+        assertEquals("s\"mit\"", parser.getString());
+        assertEquals("\"s\\\"mit\\\"\"", new JsonStringImpl(parser.getString()).toString());
+        parser.close();
+    }
+
+    @Test
+    public void dosProtected() {
+        // strings
+        {
+            final JsonParser parser = Json.createParserFactory(new HashMap<String, Object>() {{
+                        put(JsonParserFactoryImpl.MAX_STRING_LENGTH, 10);
+                    }}).createParser(new InputStream() {
+                private int index = 0;
+
+                @Override
+                public int read() throws IOException {
+                    switch (index) {
+                        case 0:
+                            index++;
+                            return '{';
+                        case 1:
+                            index++;
+                            return '"';
+                        default: break;
+                    }
+                    return 'a'; // infinite key
+                }
+            });
+            assertEquals(JsonParser.Event.START_OBJECT, parser.next());
+            try {
+                parser.next(); // should fail cause we try to make a OOME
+                fail();
+            } catch (final JsonParsingException expected) {
+                // no-op
+            }
+            parser.close();
+        }
+        
+        
+        // spaces
+        {
+            final JsonParser parser = Json.createParserFactory(new HashMap<String, Object>() {{
+                        put(JsonParserFactoryImpl.MAX_STRING_LENGTH, 10);
+                    }}).createParser(new InputStream() {
+                private int index = 0;
+
+                @Override
+                public int read() throws IOException {
+                    switch (index) {
+                        case 0:
+                            index++;
+                            return '{';
+                        default: break;
+                    }
+                    return ' '; // infinite spaces
+                }
+            });
+            assertEquals(JsonParser.Event.START_OBJECT, parser.next());
+            try { // should fail cause we try to make a OOME
+                while (parser.hasNext()) {
+                    parser.next();
+                }
+                fail();
+            } catch (final JsonParsingException expected) {
+                // no-op
+            }
+            parser.close();
+        }
+    }
+
+    @Test
+    public void hasNext() {
+        final JsonParser parser = Json.createParserFactory(new HashMap<String, Object>() {{
+            put(JsonParserFactoryImpl.MAX_STRING_LENGTH, 10);
+        }}).createParser(new ByteArrayInputStream("{}".getBytes()));
+        assertTrue(parser.hasNext());
+        assertTrue(parser.hasNext());
+        assertTrue(parser.hasNext());
+        assertTrue(parser.hasNext());
+        assertEquals(JsonParser.Event.START_OBJECT, parser.next());
+        parser.close();
+    }
+
+    @Test(expected = JsonParsingException.class)
+    public void commaChecks() {
+        // using a reader as wrapper of parser
+  
+        Json.createReader(new ByteArrayInputStream("{\"z\":\"b\"\"j\":\"d\"}".getBytes())).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void literalFailChecksTrue() {
+        // using a reader as wrapper of parser
+  
+        Json.createReader(new ByteArrayInputStream("{\"z\":truet}".getBytes())).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void literalFailChecksNull() {
+        // using a reader as wrapper of parser
+  
+        Json.createReader(new ByteArrayInputStream("{\"z\":nulll}".getBytes())).read();
+    }
+    
+    @Test(expected = JsonException.class)
+    public void zeroByteInput() {
+        // using a reader as wrapper of parser
+  
+        Json.createReader(new ByteArrayInputStream(new byte[]{})).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void zeroCharInput() {
+        // using a reader as wrapper of parser
+  
+        Json.createReader(new CharArrayReader(new char[]{})).read();
+    }
+    
+    @Test
+    public void testUTF32LEStream() {
+        ByteArrayInputStream bin = new ByteArrayInputStream("[\"UTF32LE\"]".getBytes(UTF_32LE));
+        JsonParser parser = Json.createParser(bin);
+        parser.next();
+        parser.next();
+        assertEquals("UTF32LE", parser.getString());
+        parser.next();
+        assertTrue(!parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void testUTF32BEStream() {
+        ByteArrayInputStream bin = new ByteArrayInputStream("[\"UTF32BE\"]".getBytes(UTF_32BE));
+        JsonParser parser = Json.createParser(bin);
+        parser.next();
+        parser.next();
+        assertEquals("UTF32BE", parser.getString());
+        parser.next();
+        assertTrue(!parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void testUTF16BEStream() {
+        ByteArrayInputStream bin = new ByteArrayInputStream("[\"UTF16BE\"]".getBytes(UTF_16BE));
+        JsonParser parser = Json.createParser(bin);
+        parser.next();
+        parser.next();
+        assertEquals("UTF16BE", parser.getString());
+        parser.next();
+        assertTrue(!parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void testUTF16LEStream() {
+        ByteArrayInputStream bin = new ByteArrayInputStream("[\"UTF16LE\"]".getBytes(UTF_16LE));
+        JsonParser parser = Json.createParser(bin);
+        parser.next();
+        parser.next();
+        assertEquals("UTF16LE", parser.getString());
+        parser.next();
+        assertTrue(!parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void testUTF8Stream() {
+        ByteArrayInputStream bin = new ByteArrayInputStream("[\"UTF8\"]".getBytes(UTF_8));
+        JsonParser parser = Json.createParser(bin);
+        parser.next();
+        parser.next();
+        assertEquals("UTF8", parser.getString());
+        parser.next();
+        assertTrue(!parser.hasNext());
+        parser.close();
+    }
+    
+    @Test
+    public void shortestNonEmtyJsonFile() {
+        // using a reader as wrapper of parser
+  
+        assertEquals(0L, Json.createReader(new ByteArrayInputStream("[0]".getBytes())).readArray().getJsonNumber(0).longValue());
+    }
+    
+    
+    @Test
+    public void shortestNonEmtyJsonFileWithWhiteSpaceChars() {
+        // using a reader as wrapper of parser
+  
+        assertEquals(0L, Json.createReader(new ByteArrayInputStream("  \n\n   [   0  ]  \n\n".getBytes())).readArray().getJsonNumber(0).longValue());
+    }
+    
+    @Test
+    public void escapeStart() {
+        // using a reader as wrapper of parser
+  
+        assertEquals("\\abcdef", Json.createReader(new ByteArrayInputStream("[\"\\\\abcdef\"]".getBytes())).readArray().getString(0));
+    }
+    
+    @Test
+    public void escapeStart2() {
+        // using a reader as wrapper of parser
+  
+        assertEquals("\"abcdef", Json.createReader(new ByteArrayInputStream("[\"\\\"abcdef\"]".getBytes())).readArray().getString(0));
+    }
+    
+    @Test
+    public void threeLiterals() {
+        final JsonParser parser = Json.createParserFactory(new HashMap<String, Object>() {{
+            put(JsonParserFactoryImpl.MAX_STRING_LENGTH, 10);
+        }}).createParser(new ByteArrayInputStream("{\"a\":true,\"b\":null,\"c\":false,\"arr\":[false, true, null]}".getBytes()));
+        parser.next();
+        parser.next();
+        assertEquals(JsonParser.Event.VALUE_TRUE, parser.next());
+        parser.next();
+        assertEquals(JsonParser.Event.VALUE_NULL, parser.next());
+        parser.next();
+        assertEquals(JsonParser.Event.VALUE_FALSE, parser.next());
+        parser.next();
+        parser.next();
+        assertEquals(JsonParser.Event.VALUE_FALSE, parser.next());
+        assertEquals(JsonParser.Event.VALUE_TRUE, parser.next());
+        assertEquals(JsonParser.Event.VALUE_NULL, parser.next());
+        parser.close();
+    }
+    
+    @Test
+    public void maxStringStringOK() {
+        // using a reader as wrapper of parser
+        Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.max-string-length", "5");
+            }
+        }).createReader(new ByteArrayInputStream("[\"abcde\"]".getBytes())).read();
+       
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void maxStringStringFail() {
+        // using a reader as wrapper of parser
+        Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.max-string-length", "5");
+            }
+        }).createReader(new ByteArrayInputStream("[\"abcdef\"]".getBytes())).read();
+       
+    }
+    
+    @Test
+    public void maxStringNumberOK() {
+        // using a reader as wrapper of parser
+        Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.max-string-length", "5");
+            }
+        }).createReader(new ByteArrayInputStream("[12.3]".getBytes())).read();
+       
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void maxStringNumberFail() {
+        // using a reader as wrapper of parser
+        Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.max-string-length", "5");
+            }
+        }).createReader(new ByteArrayInputStream("[12.333]".getBytes())).read();
+       
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void maxStringWhitespace() {
+        // using a reader as wrapper of parser
+        Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.max-string-length", "5");
+            }
+        }).createReader(new ByteArrayInputStream("[\"12\"           ]".getBytes())).read();
+       
+    }
+    
+    
+    @Test
+    public void testEmptyArray() {
+       JsonParser parser = Json.createParser(new ByteArrayInputStream("[]".getBytes()));
+        assertEquals(Event.START_ARRAY, parser.next());
+        assertEquals(Event.END_ARRAY, parser.next());
+        assertEquals(false, parser.hasNext());
+        try {
+            parser.next();
+            fail("Should have thrown a NoSuchElementException");
+        } catch (NoSuchElementException ne) {
+            //expected
+        }
+    }
+    
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail1() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail1.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail2() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail2.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail3() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail3.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail4() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail4.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail5() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail5.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail6() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail6.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail7() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail7.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail8() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail8.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail9() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail9.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail10() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail10.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail11() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail11.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail12() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail12.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail13() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail13.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail14() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail14.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail15() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail15.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail16() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail16.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail17() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail17.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail18() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail18.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail19() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail19.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail20() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail20.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail21() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail21.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail22() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail22.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail23() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail23.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail24() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail24.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail25() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail25.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail26() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail26.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail27() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail27.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail28() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail28.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail29() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail29.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail30() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail30.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail31() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail31.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail32() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail32.json")).read();
+    }
+    
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail33() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail33.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail34() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail34.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail35() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail35.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail36() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail36.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail37() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail37.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail38() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail38.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail39() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail39.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail40() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail40.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail41() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail41.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail42() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail42.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail43() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail43.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail44() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail44.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail45() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail45.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail46() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail46.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail47() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail47.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail48() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail48.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail49() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail49.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail50() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail50.json")).read();
+    }
+    
+    //@Test(expected = JsonParsingException.class)
+    public void fail51() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail51.json")).read();
+    }
+    
+    //@Test(expected = JsonParsingException.class)
+    public void fail52() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail52.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail53() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail53.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail54() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail54.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail55() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail55.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail56() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail56.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail57() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail57.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail58() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail58.json")).read();
+    }
+    
+    @Test(expected = JsonException.class)
+    public void fail59() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail59.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail60() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail60.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail61() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail61.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail62() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail62.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail63() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail63.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail64() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail64.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail65() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail65.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail66() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail66.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail67() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail67.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail68() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail68.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail69() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail69.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail70() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail70.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail71() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail71.json")).read();
+    }
+    
+    @Test(expected = JsonParsingException.class)
+    public void fail72() {
+        
+        Json.createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/fails/fail72.json")).read();
+    }
+    
+    
+    @Test
+    public void stringescapeVariousBufferSizesBogus() {
+        
+
+        StringBuilder sb = new StringBuilder();
+        sb.append("\t\"special-\":" + "\"" + "\\\\f\\n\\r\\t\\u6565\uDC00\uD800" + "\",\n");
+        sb.append("\t\"unicode-\\u0000- \":\"\\u5656\uDC00\uD800\"\n");
+        String s = "{"+sb.toString()+"}";
+       
+        for (int i = 1; i < s.length()+100; i++) {
+            final String value = String.valueOf(i);
+
+            final JsonParser parser = Json.createParserFactory(new HashMap<String, Object>() {
+                {
+                    put("org.apache.johnzon.default-char-buffer", value);
+                }
+            }).createParser(new ByteArrayInputStream(s.getBytes()));
+            assertNotNull(parser);
+            
+            while(parser.hasNext()) {
+                Event e = parser.next();
+                if(e==null) {
+                    fail();
+                }
+            }
+            
+            assertTrue(!parser.hasNext());
+            parser.close();
+            
+        }
+    }
+    
+    
+    
+}

http://git-wip-us.apache.org/repos/asf/incubator-johnzon/blob/6e86a53e/johnzon-core/src/test/java/org/apache/johnzon/core/JsonReaderImplTest.java
----------------------------------------------------------------------
diff --git a/johnzon-core/src/test/java/org/apache/johnzon/core/JsonReaderImplTest.java b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonReaderImplTest.java
new file mode 100644
index 0000000..465945e
--- /dev/null
+++ b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonReaderImplTest.java
@@ -0,0 +1,453 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.johnzon.core;
+
+import static org.hamcrest.CoreMatchers.instanceOf;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertThat;
+import static org.junit.Assert.assertTrue;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStreamReader;
+import java.io.Reader;
+import java.nio.charset.Charset;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.json.Json;
+import javax.json.JsonArray;
+import javax.json.JsonObject;
+import javax.json.JsonReader;
+import javax.json.JsonStructure;
+
+import org.junit.Test;
+
+public class JsonReaderImplTest {
+    
+    
+    
+    public JsonReaderImplTest() {
+        super();
+        if (!Charset.defaultCharset().equals(Charset.forName("UTF-8"))) {
+            throw new RuntimeException("Default charset is " + Charset.defaultCharset() + ", must must be UTF-8");
+        }
+    }
+
+    protected static Charset utf8Charset = Charset.forName("UTF8");
+    protected static Charset asciiCharset = Charset.forName("ASCII");
+
+    @SuppressWarnings("unchecked")
+    protected Map<String, ?> getFactoryConfig() {
+        return Collections.EMPTY_MAP;
+    }
+
+    @Test
+    public void simple() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(3, object.size());
+        assertEquals("b", object.getString("a"));
+        assertEquals(4, object.getInt("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(2, array.size());
+        assertEquals(1, array.getInt(0));
+        assertEquals(-2, array.getInt(1));
+        reader.close();
+    }
+
+    @Test
+    public void unicode() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("json/unicode.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(String.valueOf('\u6565'), object.getString("a"));
+        assertEquals("", object.getString("z"));
+        assertEquals(String.valueOf('\u0000'), object.getString("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(3, array.size());
+        assertEquals(-2, array.getInt(0));
+        assertEquals(" ", array.getString(1));
+        assertEquals("", array.getString(2));
+        assertEquals(5, object.size());
+        reader.close();
+    }
+
+    @Test
+    public void unicodeWithIoReader() {
+        final Reader ioReader = new InputStreamReader(Thread.currentThread().getContextClassLoader()
+                .getResourceAsStream("json/unicode.json"), utf8Charset);
+        final JsonReader reader = Json.createReader(ioReader);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(String.valueOf('\u6565'), object.getString("a"));
+        assertEquals("", object.getString("z"));
+        assertEquals(String.valueOf('\u0000'), object.getString("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(3, array.size());
+        assertEquals(-2, array.getInt(0));
+        assertEquals(" ", array.getString(1));
+        assertEquals("", array.getString(2));
+        assertEquals(5, object.size());
+        reader.close();
+    }
+
+    @Test
+    public void special() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("json/special.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(9, object.size());
+        assertEquals("b,,", object.getString("a{"));
+        assertEquals(":4::,[{", object.getString("c::::"));
+        assertTrue(object.getJsonNumber("w").doubleValue() > 4 && object.getJsonNumber("w").doubleValue() < 5);
+        assertEquals(110, object.getInt("1.4312"));
+        assertEquals("\"", object.getString("\""));
+        assertTrue(object.isNull("\u0044"));
+        assertEquals("ন:4::,[{", object.getString("থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#"));
+        reader.close();
+    }
+
+    @Test
+    public void specialWithIoReader() {
+        final Reader ioReader = new InputStreamReader(Thread.currentThread().getContextClassLoader()
+                .getResourceAsStream("json/special.json"), utf8Charset);
+        final JsonReader reader = Json.createReader(ioReader);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(9, object.size());
+        assertEquals("b,,", object.getString("a{"));
+        assertEquals(":4::,[{", object.getString("c::::"));
+        assertTrue(object.getJsonNumber("w").doubleValue() > 4 && object.getJsonNumber("w").doubleValue() < 5);
+        assertEquals(110, object.getInt("1.4312"));
+        assertEquals("\"", object.getString("\""));
+        assertEquals("ন:4::,[{", object.getString("থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#"));
+        reader.close();
+    }
+
+    @Test
+    public void specialWithStringAsByteArrayInputStream() {
+        final String s = "{\"নa\":\"hallo\u20acö\uffff \u08a5 থ?ߧ$%&´'`*+#\udbff\udfff\"}";
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new ByteArrayInputStream(s.getBytes(utf8Charset)), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(1, object.size());
+        assertEquals("hallo\u20acö\uffff \u08a5 থ?ߧ$%&´'`*+#\udbff\udfff", object.getString("নa"));
+        reader.close();
+    }
+    
+    @Test
+    public void specialKeysWithStringAsByteArrayInputStream() {
+        final String s = "{\"\\\"a\":\"\u0055\",\"\u0055\":\"test2\"}";
+        System.out.println(s);
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new ByteArrayInputStream(s.getBytes(utf8Charset)), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(2, object.size());
+        assertEquals("U", object.getString("\"a"));
+        assertEquals("test2", object.getString("U"));
+        reader.close();
+    }
+
+    @Test
+    public void specialWithStringReader() {
+        final String s = "{\"ন:4::,[{\u08a5\":\"থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#\ua5a5\"}";
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new InputStreamReader(new ByteArrayInputStream(s.getBytes(utf8Charset)), utf8Charset));
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(1, object.size());
+        assertEquals("থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#\ua5a5", object.getString("ন:4::,[{\u08a5"));
+        reader.close();
+    }
+
+    @Test
+    public void unicode4Bytes() {
+        final int codepoint = 128149;
+        final char[] charPair = Character.toChars(codepoint);
+        assertNotNull(charPair);
+        assertEquals(2, charPair.length);
+        assertTrue(Character.isHighSurrogate(charPair[0]));
+        assertTrue(Character.isLowSurrogate(charPair[1]));
+        assertTrue(Character.isSurrogatePair(charPair[0], charPair[1]));
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                (new ByteArrayInputStream(("{\"\":\"Ö" + charPair[0] + charPair[1] + "\"}").getBytes(utf8Charset))),
+                utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+
+        assertEquals(codepoint, object.getString("").codePointAt(1));
+        assertEquals("Ö" + new String(charPair), object.getString(""));
+        assertEquals(1, object.size());
+        reader.close();
+    }
+
+    @Test
+    public void unicode3Bytes() {
+        final char[] charPair = Character.toChars("\uffff".codePointAt(0));
+        assertNotNull(charPair);
+        assertEquals(1, charPair.length);
+        assertTrue(!Character.isLowSurrogate(charPair[0]));
+        assertTrue(!Character.isHighSurrogate(charPair[0]));
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new ByteArrayInputStream(("{\"\":\"\uffff\"}").getBytes(utf8Charset)), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(String.valueOf('\uffff'), object.getString(""));
+        assertEquals(1, object.size());
+        reader.close();
+    }
+
+    @Test
+    public void unicode2Bytes() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new ByteArrayInputStream(("{\"\":\"Ö\u00d6\"}").getBytes(utf8Charset)), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals("Ö\u00d6", object.getString(""));
+        assertEquals(1, object.size());
+        reader.close();
+    }
+
+    @Test(expected = NullPointerException.class)
+    public void unicodeFailAscii() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                new ByteArrayInputStream(
+                        "{\"ন:4::,[{\udbff\udfff\":\"থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#\udbff\udfff\"}".getBytes(asciiCharset)),
+                utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(1, object.size());
+        assertEquals("থii:üäöÖ.,;.-<>!§$%&()=?ß´'`*+#\udbff\udfff", object.getString("ন:4::,[{\udbff\udfff"));
+        reader.close();
+    }
+
+    @Test
+    public void parseHuge1MbJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/huge_1mb.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void parseBig600KbJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/big_600kb.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void parseLarge130KbJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/large_130kb.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void parseMedium11KbJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/medium_11kb.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void parseSmall3KbJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/small_3kb.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void parseTiny50BJsonFile() {
+        final JsonReader reader = Json.createReaderFactory(getFactoryConfig()).createReader(
+                Thread.currentThread().getContextClassLoader().getResourceAsStream("bench/tiny_50b.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonStructure object = reader.read();
+        assertNotNull(object);
+        reader.close();
+    }
+
+    @Test
+    public void simpleBadBufferSize8() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "8");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(3, object.size());
+        assertEquals("b", object.getString("a"));
+        assertEquals(4, object.getInt("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(2, array.size());
+        assertEquals(1, array.getInt(0));
+        assertEquals(-2, array.getInt(1));
+        reader.close();
+    }
+    
+    @Test
+    public void simple2BadBufferSize8() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "8");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple2.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(3, object.size());
+        assertEquals("b", object.getString("a"));
+        assertEquals(4, object.getInt("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(2, array.size());
+        assertEquals(1, array.getInt(0));
+        assertEquals(-2, array.getInt(1));
+        reader.close();
+    }
+
+    @Test
+    public void simpleBadBufferSize9() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "9");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/simple.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(3, object.size());
+        assertEquals("b", object.getString("a"));
+        assertEquals(4, object.getInt("c"));
+        assertThat(object.get("d"), instanceOf(JsonArray.class));
+        final JsonArray array = object.getJsonArray("d");
+        assertNotNull(array);
+        assertEquals(2, array.size());
+        assertEquals(1, array.getInt(0));
+        assertEquals(-2, array.getInt(1));
+        reader.close();
+    }
+
+    @Test(expected = IllegalArgumentException.class)
+    public void emptyZeroCharBuffersize() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "0");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/empty.json"), utf8Charset);
+        assertNotNull(reader);
+        reader.readObject();
+        reader.close();
+    }
+
+    @Test
+    public void emptyOneCharBufferSize() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "1");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/empty.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonObject object = reader.readObject();
+        assertNotNull(object);
+        assertEquals(0, object.size());
+        reader.close();
+    }
+
+    @Test
+    public void emptyArrayOneCharBufferSize() {
+        final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+            {
+                put("org.apache.johnzon.default-char-buffer", "1");
+            }
+        }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/emptyarray.json"), utf8Charset);
+        assertNotNull(reader);
+        final JsonArray array = reader.readArray();
+        assertNotNull(array);
+        assertEquals(0, array.size());
+        reader.close();
+    }
+
+    @Test
+    public void stringescapeVariousBufferSizes() {
+        final int[] buffersizes = new int[] { 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, 32, 64, 128, 1024, 8192 };
+
+        for (int i = 0; i < buffersizes.length; i++) {
+            final String value = String.valueOf(buffersizes[i]);
+            final JsonReader reader = Json.createReaderFactory(new HashMap<String, Object>() {
+                {
+                    put("org.apache.johnzon.default-char-buffer", value);
+                }
+            }).createReader(Thread.currentThread().getContextClassLoader().getResourceAsStream("json/stringescape.json"),
+                    utf8Charset);
+            assertNotNull(reader);
+            final JsonObject object = reader.readObject();
+            assertNotNull(object);
+            assertEquals(1, object.size());
+            assertEquals("s\"mit\"", object.getString("name"));
+            reader.close();
+        }
+    }
+}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/incubator-johnzon/blob/6e86a53e/johnzon-core/src/test/java/org/apache/johnzon/core/JsonWriterImplTest.java
----------------------------------------------------------------------
diff --git a/johnzon-core/src/test/java/org/apache/johnzon/core/JsonWriterImplTest.java b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonWriterImplTest.java
new file mode 100644
index 0000000..d9b2ecd
--- /dev/null
+++ b/johnzon-core/src/test/java/org/apache/johnzon/core/JsonWriterImplTest.java
@@ -0,0 +1,42 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.johnzon.core;
+
+import static org.junit.Assert.assertEquals;
+
+import java.io.ByteArrayOutputStream;
+
+import javax.json.Json;
+import javax.json.JsonObjectBuilder;
+import javax.json.JsonWriter;
+
+import org.junit.Test;
+
+public class JsonWriterImplTest {
+    @Test
+    public void writer() {
+        final ByteArrayOutputStream out = new ByteArrayOutputStream();
+        final JsonWriter writer = Json.createWriter(out);
+        final JsonObjectBuilder ob = Json.createObjectBuilder();
+        ob.add("a", new JsonStringImpl("b"));
+        writer.write(ob.build());
+        writer.close();
+        assertEquals("{\"a\":\"b\"}", new String(out.toByteArray()));
+    }
+}