* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
-
package org.opendaylight.restconf.nb.rfc8040.rests.utils;
import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
-import static org.junit.Assert.fail;
import static org.mockito.Mockito.doReturn;
-import static org.mockito.Mockito.when;
+import static org.opendaylight.yangtools.util.concurrent.FluentFutures.immediateFluentFuture;
-import com.google.common.base.Optional;
import com.google.common.collect.ImmutableList;
-import com.google.common.util.concurrent.Futures;
-import java.util.Collections;
-import javax.ws.rs.core.MultivaluedHashMap;
-import javax.ws.rs.core.UriInfo;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
+import org.eclipse.jdt.annotation.Nullable;
import org.junit.Before;
import org.junit.Test;
+import org.junit.runner.RunWith;
import org.mockito.Mock;
-import org.mockito.Mockito;
-import org.mockito.MockitoAnnotations;
-import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
-import org.opendaylight.controller.md.sal.dom.api.DOMDataReadOnlyTransaction;
-import org.opendaylight.controller.md.sal.dom.api.DOMTransactionChain;
+import org.mockito.junit.MockitoJUnitRunner;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.mdsal.dom.api.DOMDataBroker;
+import org.opendaylight.mdsal.dom.api.DOMDataTreeReadTransaction;
+import org.opendaylight.netconf.dom.api.NetconfDataTreeService;
import org.opendaylight.restconf.common.context.InstanceIdentifierContext;
-import org.opendaylight.restconf.common.context.WriterParameters;
-import org.opendaylight.restconf.common.errors.RestconfDocumentedException;
-import org.opendaylight.restconf.common.errors.RestconfError.ErrorTag;
-import org.opendaylight.restconf.common.errors.RestconfError.ErrorType;
-import org.opendaylight.restconf.nb.rfc8040.rests.transactions.TransactionVarsWrapper;
+import org.opendaylight.restconf.nb.rfc8040.ContentParameter;
+import org.opendaylight.restconf.nb.rfc8040.rests.transactions.MdsalRestconfStrategy;
+import org.opendaylight.restconf.nb.rfc8040.rests.transactions.NetconfRestconfStrategy;
+import org.opendaylight.restconf.nb.rfc8040.rests.transactions.RestconfStrategy;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
import org.opendaylight.yangtools.yang.data.api.schema.LeafSetEntryNode;
import org.opendaylight.yangtools.yang.data.api.schema.LeafSetNode;
import org.opendaylight.yangtools.yang.data.api.schema.UnkeyedListNode;
import org.opendaylight.yangtools.yang.data.impl.schema.Builders;
import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode;
-import org.opendaylight.yangtools.yang.model.api.SchemaContext;
+import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
+@RunWith(MockitoJUnitRunner.StrictStubs.class)
public class ReadDataTransactionUtilTest {
-
private static final TestData DATA = new TestData();
- private static final YangInstanceIdentifier.NodeIdentifier NODE_IDENTIFIER = new YangInstanceIdentifier
- .NodeIdentifier(QName.create("ns", "2016-02-28", "container"));
+ private static final NodeIdentifier NODE_IDENTIFIER =
+ new NodeIdentifier(QName.create("ns", "2016-02-28", "container"));
- private TransactionVarsWrapper wrapper;
+ private RestconfStrategy mdsalStrategy;
+ private RestconfStrategy netconfStrategy;
@Mock
- private DOMTransactionChain transactionChain;
+ private NetconfDataTreeService netconfService;
@Mock
private InstanceIdentifierContext<ContainerSchemaNode> context;
@Mock
- private DOMDataReadOnlyTransaction read;
- @Mock
- private SchemaContext schemaContext;
+ private DOMDataTreeReadTransaction read;
@Mock
- private ContainerSchemaNode containerSchemaNode;
+ private EffectiveModelContext schemaContext;
@Mock
- private LeafSchemaNode containerChildNode;
- private QName containerChildQName;
+ private DOMDataBroker mockDataBroker;
@Before
public void setUp() {
- MockitoAnnotations.initMocks(this);
-
- containerChildQName = QName.create("ns", "2016-02-28", "container-child");
-
- when(transactionChain.newReadOnlyTransaction()).thenReturn(read);
- when(context.getSchemaContext()).thenReturn(schemaContext);
- when(context.getSchemaNode()).thenReturn(containerSchemaNode);
- when(containerSchemaNode.getQName()).thenReturn(NODE_IDENTIFIER.getNodeType());
- when(containerChildNode.getQName()).thenReturn(containerChildQName);
- when(containerSchemaNode.getDataChildByName(containerChildQName)).thenReturn(containerChildNode);
-
- wrapper = new TransactionVarsWrapper(this.context, null, this.transactionChain);
+ // FIXME: these tests need to be parameterized somehow. The trouble is we need mocking before we invoke
+ // the strategy. This needs some more thought.
+ doReturn(read).when(mockDataBroker).newReadOnlyTransaction();
+ mdsalStrategy = new MdsalRestconfStrategy(mockDataBroker);
+ netconfStrategy = new NetconfRestconfStrategy(netconfService);
}
@Test
public void readDataConfigTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data3))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path);
- doReturn(DATA.path).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.CONFIG;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(netconfService).getConfig(DATA.path);
+ NormalizedNode normalizedNode = readData(ContentParameter.CONFIG, DATA.path, mdsalStrategy);
+ assertEquals(DATA.data3, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.CONFIG, DATA.path, netconfStrategy);
assertEquals(DATA.data3, normalizedNode);
}
@Test
public void readAllHavingOnlyConfigTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data3))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path);
- doReturn(Futures.immediateCheckedFuture(Optional.absent())).when(read)
+ doReturn(immediateFluentFuture(Optional.empty())).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path);
- doReturn(DATA.path).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.ALL;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(netconfService).getConfig(DATA.path);
+ doReturn(immediateFluentFuture(Optional.empty())).when(netconfService).get(DATA.path);
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path, mdsalStrategy);
+ assertEquals(DATA.data3, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path, netconfStrategy);
assertEquals(DATA.data3, normalizedNode);
}
@Test
public void readAllHavingOnlyNonConfigTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data2))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path2);
- doReturn(Futures.immediateCheckedFuture(Optional.absent())).when(read)
+ doReturn(immediateFluentFuture(Optional.empty())).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path2);
- doReturn(DATA.path2).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.ALL;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data2))).when(netconfService).get(DATA.path2);
+ doReturn(immediateFluentFuture(Optional.empty())).when(netconfService).getConfig(DATA.path2);
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path2, mdsalStrategy);
+ assertEquals(DATA.data2, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path2, netconfStrategy);
assertEquals(DATA.data2, normalizedNode);
}
@Test
public void readDataNonConfigTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data2))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path2);
- doReturn(DATA.path2).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.NONCONFIG;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data2))).when(netconfService).get(DATA.path2);
+ NormalizedNode normalizedNode = readData(ContentParameter.NONCONFIG, DATA.path2, mdsalStrategy);
+ assertEquals(DATA.data2, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.NONCONFIG, DATA.path2, netconfStrategy);
assertEquals(DATA.data2, normalizedNode);
}
@Test
public void readContainerDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data3))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data4))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data4))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path);
- doReturn(DATA.path).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.ALL;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(netconfService).getConfig(DATA.path);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data4))).when(netconfService).get(DATA.path);
final ContainerNode checkingData = Builders
.containerBuilder()
.withNodeIdentifier(NODE_IDENTIFIER)
.withChild(DATA.contentLeaf)
.withChild(DATA.contentLeaf2)
.build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path, mdsalStrategy);
+ assertEquals(checkingData, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path, netconfStrategy);
assertEquals(checkingData, normalizedNode);
}
@Test
public void readContainerDataConfigNoValueOfContentTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data3))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.data4))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.data4))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path);
- doReturn(DATA.path).when(context).getInstanceIdentifier();
- final NormalizedNode<?, ?> normalizedNode = ReadDataTransactionUtil.readData(
- RestconfDataServiceConstant.ReadData.ALL, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data3))).when(netconfService).getConfig(DATA.path);
+ doReturn(immediateFluentFuture(Optional.of(DATA.data4))).when(netconfService).get(DATA.path);
final ContainerNode checkingData = Builders
.containerBuilder()
.withNodeIdentifier(NODE_IDENTIFIER)
.withChild(DATA.contentLeaf)
.withChild(DATA.contentLeaf2)
.build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path, mdsalStrategy);
+ assertEquals(checkingData, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path, netconfStrategy);
assertEquals(checkingData, normalizedNode);
}
@Test
public void readListDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.listData))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.listData))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path3);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.listData2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.listData2))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path3);
- doReturn(DATA.path3).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.ALL;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.listData))).when(netconfService).get(DATA.path3);
+ doReturn(immediateFluentFuture(Optional.of(DATA.listData2))).when(netconfService).getConfig(DATA.path3);
final MapNode checkingData = Builders
.mapBuilder()
- .withNodeIdentifier(new YangInstanceIdentifier.NodeIdentifier(QName.create("ns", "2016-02-28", "list")))
+ .withNodeIdentifier(new NodeIdentifier(QName.create("ns", "2016-02-28", "list")))
.withChild(DATA.checkData)
.build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path3, mdsalStrategy);
+ assertEquals(checkingData, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path3, netconfStrategy);
assertEquals(checkingData, normalizedNode);
}
@Test
public void readOrderedListDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.orderedMapNode1))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedMapNode1))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path3);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.orderedMapNode2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedMapNode2))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path3);
- doReturn(DATA.path3).when(context).getInstanceIdentifier();
-
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(RestconfDataServiceConstant.ReadData.ALL, wrapper, schemaContext);
-
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedMapNode1))).when(netconfService).get(DATA.path3);
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedMapNode2))).when(netconfService)
+ .getConfig(DATA.path3);
final MapNode expectedData = Builders.orderedMapBuilder()
- .withNodeIdentifier(new YangInstanceIdentifier.NodeIdentifier(DATA.listQname)).withChild(DATA.checkData)
+ .withNodeIdentifier(new NodeIdentifier(DATA.listQname))
+ .withChild(DATA.checkData)
.build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path3,
+ mdsalStrategy);
+ assertEquals(expectedData, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path3, netconfStrategy);
assertEquals(expectedData, normalizedNode);
}
@Test
public void readUnkeyedListDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.unkeyedListNode1))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.unkeyedListNode1))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.path3);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.unkeyedListNode2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.unkeyedListNode2))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path3);
- doReturn(DATA.path3).when(context).getInstanceIdentifier();
-
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(RestconfDataServiceConstant.ReadData.ALL, wrapper, schemaContext);
-
+ doReturn(immediateFluentFuture(Optional.of(DATA.unkeyedListNode1))).when(netconfService).get(DATA.path3);
+ doReturn(immediateFluentFuture(Optional.of(DATA.unkeyedListNode2))).when(netconfService)
+ .getConfig(DATA.path3);
final UnkeyedListNode expectedData = Builders.unkeyedListBuilder()
- .withNodeIdentifier(new YangInstanceIdentifier.NodeIdentifier(DATA.listQname))
- .withChild(Builders.unkeyedListEntryBuilder().withNodeIdentifier(
- new YangInstanceIdentifier.NodeIdentifier(DATA.listQname))
- .withChild(DATA.unkeyedListEntryNode1.getValue().iterator().next())
- .withChild(DATA.unkeyedListEntryNode2.getValue().iterator().next()).build()).build();
+ .withNodeIdentifier(new NodeIdentifier(DATA.listQname))
+ .withChild(Builders.unkeyedListEntryBuilder()
+ .withNodeIdentifier(new NodeIdentifier(DATA.listQname))
+ .withChild(DATA.unkeyedListEntryNode1.body().iterator().next())
+ .withChild(DATA.unkeyedListEntryNode2.body().iterator().next()).build()).build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.path3, mdsalStrategy);
+ assertEquals(expectedData, normalizedNode);
+
+ normalizedNode = readData(ContentParameter.ALL, DATA.path3, netconfStrategy);
assertEquals(expectedData, normalizedNode);
}
@Test
public void readLeafListDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.leafSetNode1))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.leafSetNode1))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.leafSetNodePath);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.leafSetNode2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.leafSetNode2))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.leafSetNodePath);
- doReturn(DATA.leafSetNodePath).when(context).getInstanceIdentifier();
-
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(RestconfDataServiceConstant.ReadData.ALL, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.leafSetNode1))).when(netconfService)
+ .get(DATA.leafSetNodePath);
+ doReturn(immediateFluentFuture(Optional.of(DATA.leafSetNode2))).when(netconfService)
+ .getConfig(DATA.leafSetNodePath);
+ final LeafSetNode<String> expectedData = Builders.<String>leafSetBuilder()
+ .withNodeIdentifier(new NodeIdentifier(DATA.leafListQname))
+ .withValue(ImmutableList.<LeafSetEntryNode<String>>builder()
+ .addAll(DATA.leafSetNode1.body())
+ .addAll(DATA.leafSetNode2.body())
+ .build())
+ .build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.leafSetNodePath,
+ mdsalStrategy);
+ assertEquals(expectedData, normalizedNode);
- final LeafSetNode<String> expectedData = Builders.<String>leafSetBuilder().withNodeIdentifier(
- new YangInstanceIdentifier.NodeIdentifier(DATA.leafListQname)).withValue(
- ImmutableList.<LeafSetEntryNode<String>>builder().addAll(DATA.leafSetNode1.getValue())
- .addAll(DATA.leafSetNode2.getValue()).build()).build();
+ normalizedNode = readData(ContentParameter.ALL, DATA.leafSetNodePath, netconfStrategy);
assertEquals(expectedData, normalizedNode);
}
@Test
public void readOrderedLeafListDataAllTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.orderedLeafSetNode1))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedLeafSetNode1))).when(read)
.read(LogicalDatastoreType.OPERATIONAL, DATA.leafSetNodePath);
- doReturn(Futures.immediateCheckedFuture(Optional.of(DATA.orderedLeafSetNode2))).when(read)
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedLeafSetNode2))).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.leafSetNodePath);
- doReturn(DATA.leafSetNodePath).when(context).getInstanceIdentifier();
-
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(RestconfDataServiceConstant.ReadData.ALL, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedLeafSetNode1))).when(netconfService)
+ .get(DATA.leafSetNodePath);
+ doReturn(immediateFluentFuture(Optional.of(DATA.orderedLeafSetNode2))).when(netconfService)
+ .getConfig(DATA.leafSetNodePath);
+ final LeafSetNode<String> expectedData = Builders.<String>orderedLeafSetBuilder()
+ .withNodeIdentifier(new NodeIdentifier(DATA.leafListQname))
+ .withValue(ImmutableList.<LeafSetEntryNode<String>>builder()
+ .addAll(DATA.orderedLeafSetNode1.body())
+ .addAll(DATA.orderedLeafSetNode2.body())
+ .build())
+ .build();
+ NormalizedNode normalizedNode = readData(ContentParameter.ALL, DATA.leafSetNodePath,
+ mdsalStrategy);
+ assertEquals(expectedData, normalizedNode);
- final LeafSetNode<String> expectedData = Builders.<String>orderedLeafSetBuilder().withNodeIdentifier(
- new YangInstanceIdentifier.NodeIdentifier(DATA.leafListQname)).withValue(
- ImmutableList.<LeafSetEntryNode<String>>builder().addAll(DATA.orderedLeafSetNode1.getValue())
- .addAll(DATA.orderedLeafSetNode2.getValue()).build()).build();
+ normalizedNode = readData(ContentParameter.ALL, DATA.leafSetNodePath, netconfStrategy);
assertEquals(expectedData, normalizedNode);
}
@Test
public void readDataWrongPathOrNoContentTest() {
- doReturn(Futures.immediateCheckedFuture(Optional.absent())).when(read)
+ doReturn(immediateFluentFuture(Optional.empty())).when(read)
.read(LogicalDatastoreType.CONFIGURATION, DATA.path2);
- doReturn(DATA.path2).when(context).getInstanceIdentifier();
- final String valueOfContent = RestconfDataServiceConstant.ReadData.CONFIG;
- final NormalizedNode<?, ?> normalizedNode =
- ReadDataTransactionUtil.readData(valueOfContent, wrapper, schemaContext);
+ doReturn(immediateFluentFuture(Optional.empty())).when(netconfService).getConfig(DATA.path2);
+ NormalizedNode normalizedNode = readData(ContentParameter.CONFIG, DATA.path2, mdsalStrategy);
assertNull(normalizedNode);
- }
- @Test(expected = RestconfDocumentedException.class)
- public void readDataFailTest() {
- final String valueOfContent = RestconfDataServiceConstant.ReadData.READ_TYPE_TX;
- final NormalizedNode<?, ?> normalizedNode = ReadDataTransactionUtil.readData(
- valueOfContent, wrapper, schemaContext);
+ normalizedNode = readData(ContentParameter.CONFIG, DATA.path2, netconfStrategy);
assertNull(normalizedNode);
}
/**
- * Test of parsing default parameters from URI request.
- */
- @Test
- public void parseUriParametersDefaultTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- // no parameters, default values should be used
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- final WriterParameters parsedParameters = ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
-
- assertEquals("Not correctly parsed URI parameter",
- RestconfDataServiceConstant.ReadData.ALL, parsedParameters.getContent());
- assertNull("Not correctly parsed URI parameter",
- parsedParameters.getDepth());
- assertNull("Not correctly parsed URI parameter",
- parsedParameters.getFields());
- }
-
- /**
- * Test of parsing user defined parameters from URI request.
- */
- @Test
- public void parseUriParametersUserDefinedTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- final String content = "config";
- final String depth = "10";
- final String fields = containerChildQName.getLocalName();
-
- parameters.put("content", Collections.singletonList(content));
- parameters.put("depth", Collections.singletonList(depth));
- parameters.put("fields", Collections.singletonList(fields));
-
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- final WriterParameters parsedParameters = ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
-
- // content
- assertEquals("Not correctly parsed URI parameter",
- content, parsedParameters.getContent());
-
- // depth
- assertNotNull("Not correctly parsed URI parameter",
- parsedParameters.getDepth());
- assertEquals("Not correctly parsed URI parameter",
- depth, parsedParameters.getDepth().toString());
-
- // fields
- assertNotNull("Not correctly parsed URI parameter",
- parsedParameters.getFields());
- assertEquals("Not correctly parsed URI parameter",
- 1, parsedParameters.getFields().size());
- assertEquals("Not correctly parsed URI parameter",
- 1, parsedParameters.getFields().get(0).size());
- assertEquals("Not correctly parsed URI parameter",
- containerChildQName, parsedParameters.getFields().get(0).iterator().next());
- }
-
- /**
- * Negative test of parsing request URI parameters when content parameter has not allowed value.
- */
- @Test
- public void parseUriParametersContentParameterNegativeTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- parameters.put("content", Collections.singletonList("not-allowed-parameter-value"));
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- try {
- ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
- fail("Test expected to fail due to not allowed parameter value");
- } catch (final RestconfDocumentedException e) {
- // Bad request
- assertEquals("Error type is not correct", ErrorType.PROTOCOL, e.getErrors().get(0).getErrorType());
- assertEquals("Error tag is not correct", ErrorTag.INVALID_VALUE, e.getErrors().get(0).getErrorTag());
- assertEquals("Error status code is not correct", 400, e.getErrors().get(0).getErrorTag().getStatusCode());
- }
- }
-
- /**
- * Negative test of parsing request URI parameters when depth parameter has not allowed value.
- */
- @Test
- public void parseUriParametersDepthParameterNegativeTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- // inserted value is not allowed
- parameters.put("depth", Collections.singletonList("bounded"));
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- try {
- ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
- fail("Test expected to fail due to not allowed parameter value");
- } catch (final RestconfDocumentedException e) {
- // Bad request
- assertEquals("Error type is not correct", ErrorType.PROTOCOL, e.getErrors().get(0).getErrorType());
- assertEquals("Error tag is not correct", ErrorTag.INVALID_VALUE, e.getErrors().get(0).getErrorTag());
- assertEquals("Error status code is not correct", 400, e.getErrors().get(0).getErrorTag().getStatusCode());
- }
- }
-
- /**
- * Negative test of parsing request URI parameters when depth parameter has not allowed value (less than minimum).
+ * Read specific type of data from data store via transaction.
+ *
+ * @param content type of data to read (config, state, all)
+ * @param strategy {@link RestconfStrategy} - wrapper for variables
+ * @return {@link NormalizedNode}
*/
- @Test
- public void parseUriParametersDepthMinimalParameterNegativeTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- // inserted value is too low
- parameters.put(
- "depth", Collections.singletonList(String.valueOf(RestconfDataServiceConstant.ReadData.MIN_DEPTH - 1)));
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- try {
- ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
- fail("Test expected to fail due to not allowed parameter value");
- } catch (final RestconfDocumentedException e) {
- // Bad request
- assertEquals("Error type is not correct", ErrorType.PROTOCOL, e.getErrors().get(0).getErrorType());
- assertEquals("Error tag is not correct", ErrorTag.INVALID_VALUE, e.getErrors().get(0).getErrorTag());
- assertEquals("Error status code is not correct", 400, e.getErrors().get(0).getErrorTag().getStatusCode());
- }
- }
-
- /**
- * Negative test of parsing request URI parameters when depth parameter has not allowed value (more than maximum).
- */
- @Test
- public void parseUriParametersDepthMaximalParameterNegativeTest() {
- final UriInfo uriInfo = Mockito.mock(UriInfo.class);
- final MultivaluedHashMap<String, String> parameters = new MultivaluedHashMap<>();
-
- // inserted value is too high
- parameters.put(
- "depth", Collections.singletonList(String.valueOf(RestconfDataServiceConstant.ReadData.MAX_DEPTH + 1)));
- when(uriInfo.getQueryParameters()).thenReturn(parameters);
-
- try {
- ReadDataTransactionUtil.parseUriParameters(context, uriInfo);
- fail("Test expected to fail due to not allowed parameter value");
- } catch (final RestconfDocumentedException e) {
- // Bad request
- assertEquals("Error type is not correct", ErrorType.PROTOCOL, e.getErrors().get(0).getErrorType());
- assertEquals("Error tag is not correct", ErrorTag.INVALID_VALUE, e.getErrors().get(0).getErrorTag());
- assertEquals("Error status code is not correct", 400, e.getErrors().get(0).getErrorTag().getStatusCode());
- }
+ private @Nullable NormalizedNode readData(final @NonNull ContentParameter content,
+ final YangInstanceIdentifier path, final @NonNull RestconfStrategy strategy) {
+ return ReadDataTransactionUtil.readData(content, path, strategy, null, schemaContext);
}
}