2 * Copyright (C) 2014 EBay Software Foundation
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 * Authors : Ashwin Raveendran
10 package org.opendaylight.ovsdb.lib;
12 import static org.opendaylight.ovsdb.lib.operations.Operations.op;
14 import java.io.IOException;
15 import java.util.List;
17 import java.util.concurrent.ExecutionException;
18 import java.util.concurrent.ExecutorService;
19 import java.util.concurrent.Executors;
21 import junit.framework.Assert;
23 import org.junit.Before;
24 import org.junit.Test;
25 import org.opendaylight.ovsdb.lib.message.MonitorRequest;
26 import org.opendaylight.ovsdb.lib.message.MonitorRequestBuilder;
27 import org.opendaylight.ovsdb.lib.message.MonitorSelect;
28 import org.opendaylight.ovsdb.lib.message.OvsdbRPC;
29 import org.opendaylight.ovsdb.lib.message.TableUpdate;
30 import org.opendaylight.ovsdb.lib.message.TableUpdates;
31 import org.opendaylight.ovsdb.lib.message.UpdateNotification;
32 import org.opendaylight.ovsdb.lib.operations.OperationResult;
33 import org.opendaylight.ovsdb.lib.schema.ColumnSchema;
34 import org.opendaylight.ovsdb.lib.schema.DatabaseSchema;
35 import org.opendaylight.ovsdb.lib.schema.GenericTableSchema;
36 import org.opendaylight.ovsdb.lib.schema.TableSchema;
37 import org.slf4j.Logger;
38 import org.slf4j.LoggerFactory;
40 import com.google.common.collect.Lists;
41 import com.google.common.util.concurrent.ListenableFuture;
44 public class OvsDBClientTestIT extends OvsdbTestBase {
45 Logger logger = LoggerFactory.getLogger(OvsDBClientTestIT.class);
50 public void testTransact() throws IOException, InterruptedException, ExecutionException {
52 ListenableFuture<DatabaseSchema> schema = ovs.getSchema(OvsDBClient.OPEN_VSWITCH_SCHEMA, true);
53 TableSchema<GenericTableSchema> bridge = schema.get().table("Bridge", GenericTableSchema.class);
55 for (Map.Entry<String, ColumnSchema> names : bridge.getColumnSchemas().entrySet()) {
56 System.out.println("names = " + names.getKey());
57 System.out.println("names.getValue().getType() = " + names.getValue().getType().getBaseType());
60 ColumnSchema<GenericTableSchema, String> name = bridge.column("name", String.class);
61 ColumnSchema<GenericTableSchema, String> fail_mode = bridge.column("fail_mode", String.class);
63 ListenableFuture<List<OperationResult>> results = ovs.transactBuilder()
64 .add(op.insert(bridge).value(name, "br-int"))
65 .add(op.update(bridge)
66 .set(fail_mode, "secure")
67 .where(name.opEqual("br-int"))
68 //.and(name.opEqual("br-int"))
73 List<OperationResult> operationResults = results.get();
74 Assert.assertFalse(operationResults.isEmpty());
75 System.out.println("Insert & Update operation results = " + operationResults);
77 results = ovs.transactBuilder()
78 .add(op.delete(bridge)
79 .where(name.opEqual("br-int"))
84 operationResults = results.get();
85 Assert.assertFalse(operationResults.isEmpty());
86 System.out.println("Delete operation results = " + operationResults);
89 * Adding a separate Abort operation in a transaction. Lets not mix this with other
90 * valid transactions as above.
92 results = ovs.transactBuilder()
93 .add(op.delete(bridge)
94 .where(name.opEqual("br-int"))
99 operationResults = results.get();
100 Assert.assertFalse(operationResults.isEmpty());
101 System.out.println("Abort operation results = " + operationResults);
106 public void testMonitorRequest() throws ExecutionException, InterruptedException {
108 DatabaseSchema dbSchema = ovs.getSchema(OvsDBClient.OPEN_VSWITCH_SCHEMA, true).get();
109 GenericTableSchema bridge = dbSchema.table("Bridge", GenericTableSchema.class);
111 List<MonitorRequest<GenericTableSchema>> monitorRequests = Lists.newArrayList();
113 MonitorRequestBuilder.builder(bridge)
114 .addColumn(bridge.column("name"))
115 .addColumn(bridge.column("fail_mode", String.class))
116 .with(new MonitorSelect(true, true, true, true))
119 final List<Object> results = Lists.newArrayList();
121 MonitorHandle monitor = ovs.monitor(dbSchema, monitorRequests, new MonitorCallBack() {
123 public void update(TableUpdates result) {
125 System.out.println("result = " + result);
129 public void exception(Throwable t) {
131 System.out.println("t = " + t);
135 //for (int i = 0; i < 5 && results.isEmpty(); i++) { //wait 5 seconds to get a result
136 for (int i = 0; i < 5 ; i++) { //wait 5 seconds to get a result
137 System.out.println("waiting");
141 Assert.assertTrue(!results.isEmpty());
142 Object result = results.get(0);
143 Assert.assertTrue(result instanceof TableUpdates);
144 TableUpdate bridgeUpdate = ((TableUpdates) result).getUpdate(bridge);
145 Assert.assertNotNull(bridgeUpdate);
149 public void testGetDBs() throws ExecutionException, InterruptedException {
150 ListenableFuture<List<String>> databases = ovs.getDatabases();
151 List<String> dbNames = databases.get();
152 Assert.assertNotNull(dbNames);
153 Assert.assertTrue(dbNames.size() > 0);
157 public void initalize() throws IOException {
161 OvsdbRPC rpc = getTestConnection();
163 System.out.println("Unable to Establish Test Connection");
165 ExecutorService executorService = Executors.newFixedThreadPool(3);
166 ovs = new OvsDBClientImpl(rpc, executorService);
171 public void update(Object node, UpdateNotification upadateNotification) {
172 // TODO Auto-generated method stub
177 public void locked(Object node, List<String> ids) {
178 // TODO Auto-generated method stub
182 public void stolen(Object node, List<String> ids) {
183 // TODO Auto-generated method stub