2 * Copyright (c) 2017 Red Hat, 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.genius.datastoreutils.testutils.tests;
10 import static org.junit.Assert.assertTrue;
11 import static org.junit.Assert.fail;
12 import static org.junit.runners.MethodSorters.NAME_ASCENDING;
13 import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
15 import java.util.concurrent.ExecutionException;
16 import java.util.concurrent.TimeUnit;
17 import java.util.concurrent.TimeoutException;
18 import javax.inject.Inject;
19 import org.junit.Before;
20 import org.junit.FixMethodOrder;
21 import org.junit.Rule;
22 import org.junit.Test;
23 import org.junit.rules.MethodRule;
24 import org.mockito.Mockito;
25 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
26 import org.opendaylight.controller.md.sal.common.api.data.OptimisticLockFailedException;
27 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
28 import org.opendaylight.genius.datastoreutils.testutils.DataBrokerFailures;
29 import org.opendaylight.genius.datastoreutils.testutils.DataBrokerFailuresModule;
30 import org.opendaylight.infrautils.inject.guice.testutils.AnnotationsModule;
31 import org.opendaylight.infrautils.inject.guice.testutils.GuiceRule;
34 * Unit test for DataBrokerFailuresImpl.
36 * @author Michael Vorburger.ch
38 @FixMethodOrder(NAME_ASCENDING)
39 public class DataBrokerFailuresTest {
41 private final DataBroker mockDataBroker = Mockito.mock(DataBroker.class, RETURNS_DEEP_STUBS);
43 public @Rule MethodRule guice = new GuiceRule(
44 new DataBrokerFailuresModule(mockDataBroker), new AnnotationsModule());
46 @Inject DataBrokerFailures dbFailures;
47 @Inject DataBroker dataBroker;
55 public void testFailReadWriteTransactionSubmit() throws TimeoutException, InterruptedException {
56 dbFailures.failSubmits(new OptimisticLockFailedException("bada boum bam!"));
58 // Now make sure that it still fails, and not just once:
64 private void checkSubmitFails() throws TimeoutException, InterruptedException {
66 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
67 fail("This should have lead to a TransactionCommitFailedException!");
68 } catch (ExecutionException e) {
69 assertTrue("Expected TransactionCommitFailedException",
70 e.getCause() instanceof TransactionCommitFailedException);
75 public void testFailReadWriteTransactionSubmitNext()
76 throws TimeoutException, InterruptedException, ExecutionException {
77 // This must pass (the failSubmits from previous test cannot affect this)
78 // (It's a completely new instance of DataBroker & DataBrokerFailures anyways, but just to be to sure.)
79 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
83 public void testFailTwoReadWriteTransactionSubmit()
84 throws TimeoutException, InterruptedException, ExecutionException {
85 dbFailures.failSubmits(2, new OptimisticLockFailedException("bada boum bam!"));
87 // Now make sure that it still fails again a 2nd time, and not just once:
89 // But now it should pass.. because we specified howManyTimes = 2 above
90 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
91 dataBroker.newWriteOnlyTransaction().commit().get(5, TimeUnit.SECONDS);
92 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
95 @Test(expected = OptimisticLockFailedException.class)
96 @SuppressWarnings("checkstyle:AvoidHidingCauseException")
97 public void testFailWriteTransactionSubmit()
98 throws TimeoutException, InterruptedException, TransactionCommitFailedException {
99 dbFailures.failSubmits(new OptimisticLockFailedException("bada boum bam!"));
101 dataBroker.newWriteOnlyTransaction().commit().get(5, TimeUnit.SECONDS);
102 } catch (ExecutionException e) {
103 assertTrue("Expected TransactionCommitFailedException",
104 e.getCause() instanceof TransactionCommitFailedException);
105 throw (TransactionCommitFailedException)e.getCause();
110 public void testUnfailSubmits() throws TimeoutException, InterruptedException, ExecutionException {
111 dbFailures.failSubmits(new OptimisticLockFailedException("bada boum bam!"));
113 dbFailures.unfailSubmits();
114 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
115 dataBroker.newWriteOnlyTransaction().commit().get(5, TimeUnit.SECONDS);
116 dataBroker.newReadWriteTransaction().commit().get(5, TimeUnit.SECONDS);
120 public void testFailButSubmitsAnywaysReadWriteTransaction() throws TimeoutException, InterruptedException {
121 dbFailures.failButSubmitsAnyways();
125 // TODO make this work for TransactionChain as well ...