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.stmt.yin;
10 import static org.junit.Assert.assertEquals;
11 import static org.junit.Assert.assertNotNull;
13 import java.io.IOException;
14 import java.net.URISyntaxException;
15 import java.util.Optional;
17 import org.junit.Before;
18 import org.junit.Test;
19 import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
20 import org.opendaylight.yangtools.yang.model.api.Module;
21 import org.opendaylight.yangtools.yang.model.api.RpcDefinition;
22 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
23 import org.opendaylight.yangtools.yang.parser.spi.meta.ReactorException;
24 import org.opendaylight.yangtools.yang.stmt.TestUtils;
25 import org.xml.sax.SAXException;
27 public class YinFileRpcStmtTest {
29 private SchemaContext context;
32 public void init() throws URISyntaxException, ReactorException, SAXException, IOException {
33 context = TestUtils.loadYinModules(getClass().getResource("/semantic-statement-parser/yin/modules").toURI());
34 assertEquals(9, context.getModules().size());
38 public void testRpc() {
39 Module testModule = TestUtils.findModule(context, "ietf-netconf-monitoring").get();
41 Set<RpcDefinition> rpcs = testModule.getRpcs();
42 assertEquals(1, rpcs.size());
44 RpcDefinition rpc = rpcs.iterator().next();
45 assertEquals("get-schema", rpc.getQName().getLocalName());
46 assertEquals(Optional.of("This operation is used to retrieve a schema from the\n"
49 + "Positive Response:\n"
50 + "The NETCONF server returns the requested schema.\n"
52 + "Negative Response:\n"
53 + "If requested schema does not exist, the <error-tag> is\n"
54 + "'invalid-value'.\n"
56 + "If more than one schema matches the requested parameters, the\n"
57 + "<error-tag> is 'operation-failed', and <error-app-tag> is\n"
58 + "'data-not-unique'."), rpc.getDescription());
60 ContainerSchemaNode input = rpc.getInput();
62 assertEquals(3, input.getChildNodes().size());
64 ContainerSchemaNode output = rpc.getOutput();
65 assertNotNull(output);
66 assertEquals(1, output.getChildNodes().size());