From e1cb486848a9c96557c3cea88c1aabff6d4d98f4 Mon Sep 17 00:00:00 2001 From: IlCommittatoreCasa Date: Mon, 2 Dec 2024 21:34:26 +0100 Subject: [PATCH] bug fix issue #2769 --- .../com/google/gson/stream/JsonReader.java | 1 + .../google/gson/stream/JsonReaderTest.java | 27 +++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/gson/src/main/java/com/google/gson/stream/JsonReader.java b/gson/src/main/java/com/google/gson/stream/JsonReader.java index 30876109a5..edd9d73004 100644 --- a/gson/src/main/java/com/google/gson/stream/JsonReader.java +++ b/gson/src/main/java/com/google/gson/stream/JsonReader.java @@ -1172,6 +1172,7 @@ private String nextUnquotedValue() throws IOException { while (true) { for (; pos + i < limit; i++) { switch (buffer[pos + i]) { + case '"': case '/': case '\\': case ';': diff --git a/gson/src/test/java/com/google/gson/stream/JsonReaderTest.java b/gson/src/test/java/com/google/gson/stream/JsonReaderTest.java index f8a33be0df..58a9e220a1 100644 --- a/gson/src/test/java/com/google/gson/stream/JsonReaderTest.java +++ b/gson/src/test/java/com/google/gson/stream/JsonReaderTest.java @@ -29,11 +29,17 @@ import static org.junit.Assert.assertThrows; import com.google.gson.Strictness; +import com.google.gson.internal.bind.TypeAdapters; + import java.io.EOFException; import java.io.IOException; import java.io.Reader; import java.io.StringReader; +import java.io.StringWriter; import java.util.Arrays; +import java.util.Iterator; +import java.util.stream.Stream; + import org.junit.Ignore; import org.junit.Test; @@ -2189,4 +2195,25 @@ private static Reader reader(String s) { } }; */ } + + @Test + public void testJsonReaderWithStrictnessSetToLenientAndNullValue() throws IOException { + Iterator iterator = Stream.of(null, "value1", "value2").iterator(); + StringWriter str = new StringWriter(); + + try (JsonWriter writer = new JsonWriter(str)) { + writer.setStrictness(Strictness.LENIENT); + while (iterator.hasNext()) { + TypeAdapters.STRING.write(writer, iterator.next()); + } + writer.flush(); + } + + JsonReader reader = new JsonReader(new StringReader(str.toString())); + reader.setStrictness(Strictness.LENIENT); + + assertThat(TypeAdapters.STRING.read(reader)).isEqualTo("null"); + assertThat(TypeAdapters.STRING.read(reader)).isEqualTo("value1"); + assertThat(TypeAdapters.STRING.read(reader)).isEqualTo("value2"); + } }