blob: 2ac7a29cb0d1a983e76313840a42ef26c25abb25 [file] [log] [blame]
Ray Milkey85267002016-11-16 11:06:35 -08001/*
2 * Copyright 2016-present Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Madan Jampani9e1a8c12016-06-27 11:19:10 -070016package org.onosproject.distributedprimitives.cli;
17
18import org.apache.karaf.shell.commands.Argument;
19import org.apache.karaf.shell.commands.Command;
20import org.onosproject.cli.AbstractShellCommand;
21import org.onosproject.cluster.ClusterService;
22import org.onosproject.cluster.Leadership;
23import org.onosproject.cluster.NodeId;
24import org.onosproject.store.service.LeaderElector;
25import org.onosproject.store.service.StorageService;
26
27import com.google.common.base.Joiner;
28
29@Command(scope = "onos", name = "leader-test",
30description = "LeaderElector test cli fixture")
31public class LeaderElectorTestCommand extends AbstractShellCommand {
32 @Argument(index = 0, name = "name",
33 description = "leader elector name",
34 required = true, multiValued = false)
35 String name = null;
36
37 @Argument(index = 1, name = "operation",
38 description = "operation",
39 required = true, multiValued = false)
40 String operation = null;
41
42
43 @Argument(index = 2, name = "topic",
44 description = "topic name",
45 required = false, multiValued = false)
46 String topic = null;
47
48 LeaderElector leaderElector;
49
50 @Override
51 protected void execute() {
52 StorageService storageService = get(StorageService.class);
53 ClusterService clusterService = get(ClusterService.class);
54 NodeId localNodeId = clusterService.getLocalNode().id();
55 leaderElector = storageService.leaderElectorBuilder()
56 .withName(name)
57 .build()
58 .asLeaderElector();
59 if (operation.equals("run")) {
60 print(leaderElector.run(topic, localNodeId));
61 } else if (operation.equals("withdraw")) {
62 leaderElector.withdraw(topic);
63 } else if (operation.equals("show")) {
64 print(leaderElector.getLeadership(topic));
65 }
66 }
67
68 private void print(Leadership leadership) {
69 if (leadership.leader() != null) {
70 print("leader=%s#term=%d#candidates=%s",
71 leadership.leaderNodeId(),
72 leadership.leader().term(),
73 leadership.candidates().isEmpty() ? "none" : Joiner.on(",").join(leadership.candidates()));
74 } else {
75 print("leader=none#candidates=%s",
76 leadership.candidates().isEmpty() ? "none" : Joiner.on(",").join(leadership.candidates()));
77 }
78 }
79}