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 com.google.common.collect.Lists;
13 import com.google.common.collect.Sets;
14 import com.google.common.util.concurrent.ListenableFuture;
15 import static org.opendaylight.ovsdb.lib.operations.Operations.op;
17 import java.io.IOException;
18 import java.util.List;
20 import java.util.concurrent.ExecutionException;
21 import java.util.concurrent.ExecutorService;
22 import java.util.concurrent.Executors;
24 import junit.framework.Assert;
26 import org.junit.Before;
27 import org.junit.Test;
28 import org.opendaylight.ovsdb.lib.message.MonitorRequest;
29 import org.opendaylight.ovsdb.lib.message.MonitorRequestBuilder;
30 import org.opendaylight.ovsdb.lib.message.MonitorSelect;
31 import org.opendaylight.ovsdb.lib.message.OvsdbRPC;
32 import org.opendaylight.ovsdb.lib.message.TableUpdates;
33 import org.opendaylight.ovsdb.lib.message.UpdateNotification;
34 import org.opendaylight.ovsdb.lib.notation.Column;
35 import org.opendaylight.ovsdb.lib.notation.Row;
36 import org.opendaylight.ovsdb.lib.operations.OperationResult;
37 import org.opendaylight.ovsdb.lib.schema.ColumnSchema;
38 import org.opendaylight.ovsdb.lib.schema.DatabaseSchema;
39 import org.opendaylight.ovsdb.lib.schema.GenericTableSchema;
40 import org.opendaylight.ovsdb.lib.schema.TableSchema;
41 import org.slf4j.Logger;
42 import org.slf4j.LoggerFactory;
47 public class OvsDBClientTestIT extends OvsdbTestBase {
48 Logger logger = LoggerFactory.getLogger(OvsDBClientTestIT.class);
53 public void testTransact() throws IOException, InterruptedException, ExecutionException {
55 ListenableFuture<DatabaseSchema> schema = ovs.getSchema(OPEN_VSWITCH_SCHEMA, true);
56 TableSchema<GenericTableSchema> bridge = schema.get().table("Bridge", GenericTableSchema.class);
58 for (Map.Entry<String, ColumnSchema> names : bridge.getColumnSchemas().entrySet()) {
59 System.out.println("names = " + names.getKey());
60 System.out.println("names.getValue().getType() = " + names.getValue().getType().getBaseType());
63 ColumnSchema<GenericTableSchema, String> name = bridge.column("name", String.class);
64 ColumnSchema<GenericTableSchema, String> fail_mode = bridge.column("fail_mode", String.class);
65 ColumnSchema<GenericTableSchema, Set<Integer>> flood_vlans = bridge.multiValuedColumn("flood_vlans", Integer.class);
67 ListenableFuture<List<OperationResult>> results = ovs.transactBuilder()
68 .add(op.insert(bridge)
69 .value(name, "br-test")
70 .value(flood_vlans, Sets.newHashSet(100, 101, 4001)))
71 .add(op.comment("Inserting Bridge br-int"))
72 .add(op.update(bridge)
73 .set(fail_mode, "secure")
74 .where(name.opEqual("br-int"))
76 .add(op.select(bridge)
78 .where(name.opEqual("br-int"))
83 List<OperationResult> operationResults = results.get();
84 Assert.assertFalse(operationResults.isEmpty());
85 System.out.println("Insert & Update operation results = " + operationResults);
87 results = ovs.transactBuilder()
88 .add(op.delete(bridge)
89 .where(name.opEqual("br-int"))
94 operationResults = results.get();
95 Assert.assertFalse(operationResults.isEmpty());
96 System.out.println("Delete operation results = " + operationResults);
99 * Adding a separate Abort operation in a transaction. Lets not mix this with other
100 * valid transactions as above.
102 results = ovs.transactBuilder()
103 .add(op.delete(bridge)
104 .where(name.opEqual("br-int"))
109 operationResults = results.get();
110 Assert.assertFalse(operationResults.isEmpty());
111 /* Testing for Abort Error */
112 Assert.assertFalse(operationResults.get(1).getError() == null);
113 System.out.println("Abort operation results = " + operationResults);
116 * Adding a separate Abort operation in a transaction. Lets not mix this with other
117 * valid transactions as above.
119 results = ovs.transactBuilder()
120 .add(op.delete(bridge)
121 .where(name.opEqual("br-int"))
123 .add(op.assertion("Assert12345")) // Failing intentionally
126 operationResults = results.get();
127 Assert.assertFalse(operationResults.isEmpty());
128 /* Testing for an Assertion Error */
129 Assert.assertFalse(operationResults.get(1).getError() == null);
130 System.out.println("Assert operation results = " + operationResults);
135 public void testMonitorRequest() throws ExecutionException, InterruptedException {
137 DatabaseSchema dbSchema = ovs.getSchema(OPEN_VSWITCH_SCHEMA, true).get();
138 GenericTableSchema bridge = dbSchema.table("Bridge", GenericTableSchema.class);
140 List<MonitorRequest<GenericTableSchema>> monitorRequests = Lists.newArrayList();
141 ColumnSchema<GenericTableSchema, Set<Integer>> flood_vlans = bridge.multiValuedColumn("flood_vlans", Integer.class);
144 MonitorRequestBuilder.builder(bridge)
145 .addColumn(bridge.column("name"))
146 .addColumn(bridge.column("fail_mode", String.class))
147 .addColumn(flood_vlans)
148 .with(new MonitorSelect(true, true, true, true))
151 final List<Object> results = Lists.newArrayList();
153 MonitorHandle monitor = ovs.monitor(dbSchema, monitorRequests, new MonitorCallBack() {
155 public void update(TableUpdates result) {
157 System.out.println("result = " + result);
161 public void exception(Throwable t) {
163 System.out.println("t = " + t);
167 for (int i = 0; i < 5 ; i++) { //wait 5 seconds to get a result
168 System.out.println("waiting");
172 Assert.assertTrue(!results.isEmpty());
173 Object result = results.get(0);
174 Assert.assertTrue(result instanceof TableUpdates);
175 TableUpdates updates = (TableUpdates) result;
176 org.opendaylight.ovsdb.lib.message.TableUpdate<GenericTableSchema> update = updates.getUpdate(bridge);
177 Row<GenericTableSchema> aNew = update.getNew();
178 for (Column<GenericTableSchema, ?> column: aNew.getColumns()) {
179 if (column.getSchema().equals(flood_vlans)) {
180 Set<Integer> data = column.getData(flood_vlans);
181 Assert.assertTrue(!data.isEmpty());
186 public void testGetDBs() throws ExecutionException, InterruptedException {
187 ListenableFuture<List<String>> databases = ovs.getDatabases();
188 List<String> dbNames = databases.get();
189 Assert.assertNotNull(dbNames);
190 boolean hasOpenVswitchSchema = false;
191 for(String dbName : dbNames) {
192 if (dbName.equals(OPEN_VSWITCH_SCHEMA)) {
193 hasOpenVswitchSchema = true;
197 Assert.assertTrue(OPEN_VSWITCH_SCHEMA+" schema is not supported by the switch", hasOpenVswitchSchema);
201 public void initalize() throws IOException, ExecutionException, InterruptedException {
205 OvsdbRPC rpc = getTestConnection();
207 System.out.println("Unable to Establish Test Connection");
209 ExecutorService executorService = Executors.newFixedThreadPool(3);
210 ovs = new OvsDBClientImpl(rpc, executorService);
216 public void update(Object node, UpdateNotification upadateNotification) {
217 // TODO Auto-generated method stub
222 public void locked(Object node, List<String> ids) {
223 // TODO Auto-generated method stub
227 public void stolen(Object node, List<String> ids) {
228 // TODO Auto-generated method stub