From 13997ca2ac9fc0937dfe4cfbb0192d665d314120 Mon Sep 17 00:00:00 2001 From: Valentin Mayamsin Date: Fri, 16 Oct 2015 15:08:34 -0700 Subject: [PATCH 1/1] Deleting a non-existent node fails This adds a unit test for deletion of a non-existent node. JIRA: MDSAL-108 Change-Id: I32d537c7e58a6161147e7e51b80e71cb8aaa0d79 Signed-off-by: Valentin Mayamsin Signed-off-by: Robert Varga --- .../md/sal/binding/impl/test/Bug4494Test.java | 47 +++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 opendaylight/md-sal/sal-binding-broker/src/test/java/org/opendaylight/controller/md/sal/binding/impl/test/Bug4494Test.java diff --git a/opendaylight/md-sal/sal-binding-broker/src/test/java/org/opendaylight/controller/md/sal/binding/impl/test/Bug4494Test.java b/opendaylight/md-sal/sal-binding-broker/src/test/java/org/opendaylight/controller/md/sal/binding/impl/test/Bug4494Test.java new file mode 100644 index 0000000000..d099440b84 --- /dev/null +++ b/opendaylight/md-sal/sal-binding-broker/src/test/java/org/opendaylight/controller/md/sal/binding/impl/test/Bug4494Test.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * 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.controller.md.sal.binding.impl.test; + +import java.util.ArrayList; +import org.junit.Test; +import org.opendaylight.controller.md.sal.binding.api.DataBroker; +import org.opendaylight.controller.md.sal.binding.api.ReadWriteTransaction; +import org.opendaylight.controller.md.sal.binding.api.WriteTransaction; +import org.opendaylight.controller.md.sal.binding.test.AbstractDataBrokerTest; +import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.test.list.rev140701.Top; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.test.list.rev140701.TopBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.test.list.rev140701.two.level.list.TopLevelList; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.test.list.rev140701.two.level.list.TopLevelListBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.test.list.rev140701.two.level.list.TopLevelListKey; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; + +public class Bug4494Test extends AbstractDataBrokerTest { + @Test + public void testDelete() throws Exception { + DataBroker dataBroker = getDataBroker(); + WriteTransaction writeTransaction = dataBroker.newWriteOnlyTransaction(); + ArrayList list = new ArrayList<>(); + list.add(new TopLevelListBuilder().setName("name").build()); + TopBuilder builder = new TopBuilder().setTopLevelList(list); + writeTransaction.put(LogicalDatastoreType.OPERATIONAL, InstanceIdentifier.create(Top.class), builder.build()); + assertCommit(writeTransaction.submit()); + + InstanceIdentifier id = InstanceIdentifier.builder(Top.class) + .child(TopLevelList.class, new TopLevelListKey("name")).build(); + + ReadWriteTransaction writeTransaction1 = dataBroker.newReadWriteTransaction(); + + writeTransaction1.delete(LogicalDatastoreType.OPERATIONAL, id); + assertCommit(writeTransaction1.submit()); + ReadWriteTransaction writeTransaction2 = dataBroker.newReadWriteTransaction(); + + writeTransaction2.delete(LogicalDatastoreType.OPERATIONAL, id); + assertCommit(writeTransaction2.submit()); + } +} -- 2.36.6