2 * Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.yangtools.yang.data.codec.gson;
10 import static org.opendaylight.yangtools.yang.data.codec.gson.TestUtils.loadTextFile;
12 import com.google.gson.stream.JsonReader;
14 import java.io.IOException;
15 import java.io.StringReader;
16 import java.io.StringWriter;
17 import java.net.URISyntaxException;
18 import org.junit.AfterClass;
19 import org.junit.BeforeClass;
20 import org.junit.Test;
21 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
22 import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild;
23 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
24 import org.opendaylight.yangtools.yang.data.api.schema.stream.LoggingNormalizedNodeStreamWriter;
25 import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeStreamWriter;
26 import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeWriter;
27 import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNormalizedNodeStreamWriter;
28 import org.opendaylight.yangtools.yang.data.impl.schema.NormalizedNodeResult;
29 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
30 import org.slf4j.Logger;
31 import org.slf4j.LoggerFactory;
33 public class StreamToNormalizedNodeTest extends AbstractComplexJsonTest {
34 private static final Logger LOG = LoggerFactory.getLogger(StreamToNormalizedNodeTest.class);
35 private static String streamAsString;
38 public static void initialization() throws IOException, URISyntaxException {
39 streamAsString = loadTextFile(new File(StreamToNormalizedNodeTest.class.getResource(
40 "/complexjson/complex-json.json").toURI()));
44 public static void cleanup() {
45 streamAsString = null;
49 * Demonstrates how to log events produced by a {@link JsonReader}.
52 public void ownStreamWriterImplementationDemonstration() throws IOException {
53 // GSON's JsonReader reading from the loaded string (our event source)
54 final JsonReader reader = new JsonReader(new StringReader(streamAsString));
56 // StreamWriter which outputs SLF4J events
57 final LoggingNormalizedNodeStreamWriter logWriter = new LoggingNormalizedNodeStreamWriter();
59 // JSON -> StreamWriter parser
60 try (JsonParserStream jsonHandler = JsonParserStream.create(logWriter, lhotkaCodecFactory)) {
61 // Process multiple readers, flush()/close() as needed
62 jsonHandler.parse(reader);
67 * Demonstrates how to create an immutable NormalizedNode tree from a {@link JsonReader} and
68 * then writes the data back into string representation.
71 public void immutableNormalizedNodeStreamWriterDemonstration() throws IOException {
73 * This is the parsing part
75 // This is where we will output the nodes
76 NormalizedNodeResult result = new NormalizedNodeResult();
78 // StreamWriter which attaches NormalizedNode under parent
79 final NormalizedNodeStreamWriter streamWriter = ImmutableNormalizedNodeStreamWriter.from(result);
81 // JSON -> StreamWriter parser
82 try (JsonParserStream handler = JsonParserStream.create(streamWriter, lhotkaCodecFactory)) {
83 handler.parse(new JsonReader(new StringReader(streamAsString)));
86 // Finally build the node
87 final NormalizedNode<?, ?> parsedData = result.getResult();
88 LOG.debug("Parsed NormalizedNodes: {}", parsedData);
91 * This is the serialization part.
93 // We want to write the first child out
94 final DataContainerChild<? extends PathArgument, ?> firstChild =
95 (DataContainerChild<? extends PathArgument, ?>) parsedData;
96 LOG.debug("Serializing first child: {}", firstChild);
99 final StringWriter writer = new StringWriter();
101 // StreamWriter which outputs JSON strings
102 // StreamWriter which outputs JSON strings
103 final NormalizedNodeStreamWriter jsonStream = JSONNormalizedNodeStreamWriter.createExclusiveWriter(
104 lhotkaCodecFactory, SchemaPath.ROOT, null, JsonWriterFactory.createJsonWriter(writer, 2));
106 // NormalizedNode -> StreamWriter
107 final NormalizedNodeWriter nodeWriter = NormalizedNodeWriter.forStreamWriter(jsonStream);
109 // Write multiple NormalizedNodes fluently, flush()/close() as needed
110 nodeWriter.write(firstChild).close();
112 // Just to put it somewhere
113 LOG.debug("Serialized JSON: {}", writer.toString());