Merge "BUG 3066 : Optimistic lock failed, on NetconfStateUpdate"
[controller.git] / opendaylight / netconf / netconf-testtool / src / main / java / org / opendaylight / controller / netconf / test / tool / client / stress / Parameters.java
1 /*
2  * Copyright (c) 2015 Cisco Systems, Inc. and others.  All rights reserved.
3  *
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
7  */
8
9 package org.opendaylight.controller.netconf.test.tool.client.stress;
10
11 import com.google.common.base.Preconditions;
12 import java.io.File;
13 import java.net.InetAddress;
14 import java.net.InetSocketAddress;
15 import java.net.UnknownHostException;
16 import net.sourceforge.argparse4j.ArgumentParsers;
17 import net.sourceforge.argparse4j.annotation.Arg;
18 import net.sourceforge.argparse4j.inf.ArgumentParser;
19
20 public class Parameters {
21
22     @Arg(dest = "ip")
23     public String ip;
24
25     @Arg(dest = "port")
26     public int port;
27
28     @Arg(dest = "edit-count")
29     public int editCount;
30
31     @Arg(dest = "edit-content")
32     public File editContent;
33
34     @Arg(dest = "edit-batch-size")
35     public int editBatchSize;
36
37     @Arg(dest = "debug")
38     public boolean debug;
39
40     @Arg(dest = "legacy-framing")
41     public boolean legacyFraming;
42
43     @Arg(dest = "exi")
44     public boolean exi;
45
46     @Arg(dest = "async")
47     public boolean async;
48
49     @Arg(dest = "ssh")
50     public boolean ssh;
51
52     @Arg(dest = "msg-timeout")
53     public long msgTimeout;
54
55     @Arg(dest = "tcp-header")
56     public String tcpHeader;
57
58     static ArgumentParser getParser() {
59         final ArgumentParser parser = ArgumentParsers.newArgumentParser("netconf stress client");
60
61         parser.description("Netconf stress client");
62
63         parser.addArgument("--ip")
64                 .type(String.class)
65                 .setDefault("127.0.0.1")
66                 .type(String.class)
67                 .help("Netconf server IP")
68                 .dest("ip");
69
70         parser.addArgument("--port")
71                 .type(Integer.class)
72                 .setDefault(2830)
73                 .type(Integer.class)
74                 .help("Netconf server port")
75                 .dest("port");
76
77         parser.addArgument("--edits")
78                 .type(Integer.class)
79                 .setDefault(50000)
80                 .type(Integer.class)
81                 .help("Netconf edit rpcs to be sent")
82                 .dest("edit-count");
83
84         parser.addArgument("--edit-content")
85                 .type(File.class)
86                 .setDefault(new File("edit.txt"))
87                 .type(File.class)
88                 .dest("edit-content");
89
90         parser.addArgument("--edit-batch-size")
91                 .type(Integer.class)
92                 .required(false)
93                 .setDefault(-1)
94                 .type(Integer.class)
95                 .dest("edit-batch-size");
96
97         parser.addArgument("--debug")
98                 .type(Boolean.class)
99                 .setDefault(false)
100                 .help("Whether to use debug log level instead of INFO")
101                 .dest("debug");
102
103         parser.addArgument("--legacy-framing")
104                 .type(Boolean.class)
105                 .setDefault(false)
106                 .dest("legacy-framing");
107
108         parser.addArgument("--exi")
109                 .type(Boolean.class)
110                 .setDefault(false)
111                 .dest("exi");
112
113         parser.addArgument("--async-requests")
114                 .type(Boolean.class)
115                 .setDefault(true)
116                 .dest("async");
117
118         parser.addArgument("--msg-timeout")
119                 .type(Integer.class)
120                 .setDefault(60)
121                 .dest("msg-timeout");
122
123         parser.addArgument("--ssh")
124                 .type(Boolean.class)
125                 .setDefault(false)
126                 .dest("ssh");
127
128         parser.addArgument("--tcp-header")
129                 .type(String.class)
130                 .required(false)
131                 .dest("tcp-header");
132
133         // TODO add get-config option instead of edit + commit
134         // TODO different edit config content
135
136         return parser;
137     }
138
139     void validate() {
140         Preconditions.checkArgument(port > 0, "Port =< 0");
141         Preconditions.checkArgument(editCount > 0, "Edit count =< 0");
142         if (editBatchSize == -1) {
143             editBatchSize = editCount;
144         } else {
145             Preconditions.checkArgument(editBatchSize <= editCount, "Edit count =< 0");
146         }
147
148         Preconditions.checkArgument(editContent.exists(), "Edit content file missing");
149         Preconditions.checkArgument(editContent.isDirectory() == false, "Edit content file is a dir");
150         Preconditions.checkArgument(editContent.canRead(), "Edit content file is unreadable");
151         // TODO validate
152     }
153
154     public InetSocketAddress getInetAddress() {
155         try {
156             return new InetSocketAddress(InetAddress.getByName(ip), port);
157         } catch (final UnknownHostException e) {
158             throw new IllegalArgumentException("Unknown ip", e);
159         }
160     }
161 }