Lines 19-29
Link Here
|
19 |
package org.apache.jmeter.protocol.tcp.config.gui; |
19 |
package org.apache.jmeter.protocol.tcp.config.gui; |
20 |
|
20 |
|
21 |
import java.awt.BorderLayout; |
21 |
import java.awt.BorderLayout; |
|
|
22 |
import java.awt.Dimension; |
23 |
import java.awt.event.ItemEvent; |
24 |
import java.awt.event.ItemListener; |
22 |
|
25 |
|
|
|
26 |
import javax.swing.BorderFactory; |
23 |
import javax.swing.JCheckBox; |
27 |
import javax.swing.JCheckBox; |
24 |
import javax.swing.JLabel; |
28 |
import javax.swing.JLabel; |
25 |
import javax.swing.JPanel; |
29 |
import javax.swing.JPanel; |
26 |
import javax.swing.JTextArea; |
30 |
import javax.swing.JTextArea; |
|
|
31 |
import javax.swing.JTextField; |
27 |
|
32 |
|
28 |
import org.apache.jmeter.config.ConfigTestElement; |
33 |
import org.apache.jmeter.config.ConfigTestElement; |
29 |
import org.apache.jmeter.config.gui.AbstractConfigGui; |
34 |
import org.apache.jmeter.config.gui.AbstractConfigGui; |
Lines 49-58
Link Here
|
49 |
|
54 |
|
50 |
private JCheckBox setNoDelay; |
55 |
private JCheckBox setNoDelay; |
51 |
|
56 |
|
|
|
57 |
private JCheckBox closeConnection; |
58 |
|
59 |
private JTextField soLinger; |
60 |
|
61 |
private JTextField eolByte; |
62 |
|
52 |
private JTextArea requestData; |
63 |
private JTextArea requestData; |
53 |
|
64 |
|
54 |
private boolean displayName = true; |
65 |
private boolean displayName = true; |
55 |
|
66 |
|
|
|
67 |
private HorizontalPanel optionsPanel; |
68 |
|
56 |
public TCPConfigGui() { |
69 |
public TCPConfigGui() { |
57 |
this(true); |
70 |
this(true); |
58 |
} |
71 |
} |
Lines 73-86
Link Here
|
73 |
// N.B. this will be a config element, so we cannot use the getXXX() methods |
86 |
// N.B. this will be a config element, so we cannot use the getXXX() methods |
74 |
classname.setText(element.getPropertyAsString(TCPSampler.CLASSNAME)); |
87 |
classname.setText(element.getPropertyAsString(TCPSampler.CLASSNAME)); |
75 |
serverPanel.setServer(element.getPropertyAsString(TCPSampler.SERVER)); |
88 |
serverPanel.setServer(element.getPropertyAsString(TCPSampler.SERVER)); |
76 |
// Default to original behaviour, i.e. re-use connection |
|
|
77 |
reUseConnection.setSelected(element.getPropertyAsBoolean(TCPSampler.RE_USE_CONNECTION,true)); |
78 |
serverPanel.setPort(element.getPropertyAsString(TCPSampler.PORT)); |
89 |
serverPanel.setPort(element.getPropertyAsString(TCPSampler.PORT)); |
79 |
// filename.setText(element.getPropertyAsString(TCPSampler.FILENAME)); |
90 |
// filename.setText(element.getPropertyAsString(TCPSampler.FILENAME)); |
80 |
serverPanel.setResponseTimeout(element.getPropertyAsString(TCPSampler.TIMEOUT)); |
91 |
serverPanel.setResponseTimeout(element.getPropertyAsString(TCPSampler.TIMEOUT)); |
81 |
serverPanel.setConnectTimeout(element.getPropertyAsString(TCPSampler.TIMEOUT_CONNECT)); |
92 |
serverPanel.setConnectTimeout(element.getPropertyAsString(TCPSampler.TIMEOUT_CONNECT)); |
82 |
setNoDelay.setSelected(element.getPropertyAsBoolean(TCPSampler.NODELAY)); |
|
|
83 |
requestData.setText(element.getPropertyAsString(TCPSampler.REQUEST)); |
93 |
requestData.setText(element.getPropertyAsString(TCPSampler.REQUEST)); |
|
|
94 |
|
95 |
// Default to original behaviour, i.e. re-use connection |
96 |
reUseConnection.setSelected(element.getPropertyAsBoolean(TCPSampler.RE_USE_CONNECTION, true)); |
97 |
closeConnection.setSelected(element.getPropertyAsBoolean(TCPSampler.CLOSE_CONNECTION, false)); |
98 |
setNoDelay.setSelected(element.getPropertyAsBoolean(TCPSampler.NODELAY)); |
99 |
soLinger.setText(element.getPropertyAsString(TCPSampler.SO_LINGER)); |
100 |
eolByte.setText(element.getPropertyAsString(TCPSampler.EOL_BYTE)); |
84 |
} |
101 |
} |
85 |
|
102 |
|
86 |
@Override |
103 |
@Override |
Lines 101-113
Link Here
|
101 |
// N.B. this will be a config element, so we cannot use the setXXX() methods |
118 |
// N.B. this will be a config element, so we cannot use the setXXX() methods |
102 |
element.setProperty(TCPSampler.CLASSNAME, classname.getText(), ""); |
119 |
element.setProperty(TCPSampler.CLASSNAME, classname.getText(), ""); |
103 |
element.setProperty(TCPSampler.SERVER, serverPanel.getServer()); |
120 |
element.setProperty(TCPSampler.SERVER, serverPanel.getServer()); |
104 |
element.setProperty(TCPSampler.RE_USE_CONNECTION, reUseConnection.isSelected()); |
|
|
105 |
element.setProperty(TCPSampler.PORT, serverPanel.getPort()); |
121 |
element.setProperty(TCPSampler.PORT, serverPanel.getPort()); |
106 |
// element.setProperty(TCPSampler.FILENAME, filename.getText()); |
122 |
// element.setProperty(TCPSampler.FILENAME, filename.getText()); |
107 |
element.setProperty(TCPSampler.NODELAY, setNoDelay.isSelected()); |
|
|
108 |
element.setProperty(TCPSampler.TIMEOUT, serverPanel.getResponseTimeout()); |
123 |
element.setProperty(TCPSampler.TIMEOUT, serverPanel.getResponseTimeout()); |
109 |
element.setProperty(TCPSampler.TIMEOUT_CONNECT, serverPanel.getConnectTimeout(),""); |
124 |
element.setProperty(TCPSampler.TIMEOUT_CONNECT, serverPanel.getConnectTimeout(), ""); |
110 |
element.setProperty(TCPSampler.REQUEST, requestData.getText()); |
125 |
element.setProperty(TCPSampler.REQUEST, requestData.getText()); |
|
|
126 |
|
127 |
element.setProperty(TCPSampler.RE_USE_CONNECTION, reUseConnection.isSelected()); |
128 |
element.setProperty(TCPSampler.CLOSE_CONNECTION, closeConnection.isSelected()); |
129 |
element.setProperty(TCPSampler.NODELAY, setNoDelay.isSelected()); |
130 |
element.setProperty(TCPSampler.SO_LINGER, soLinger.getText()); |
131 |
element.setProperty(TCPSampler.EOL_BYTE, eolByte.getText()); |
111 |
} |
132 |
} |
112 |
|
133 |
|
113 |
/** |
134 |
/** |
Lines 121-163
Link Here
|
121 |
classname.setText(""); //$NON-NLS-1$ |
142 |
classname.setText(""); //$NON-NLS-1$ |
122 |
requestData.setText(""); //$NON-NLS-1$ |
143 |
requestData.setText(""); //$NON-NLS-1$ |
123 |
reUseConnection.setSelected(true); |
144 |
reUseConnection.setSelected(true); |
|
|
145 |
closeConnection.setSelected(false); |
124 |
setNoDelay.setSelected(false); |
146 |
setNoDelay.setSelected(false); |
|
|
147 |
soLinger.setText(""); //$NON-NLS-1$ |
148 |
eolByte.setText(""); //$NON-NLS-1$ |
125 |
} |
149 |
} |
126 |
|
150 |
|
127 |
|
151 |
private void addNoDelayOption() { |
128 |
private JPanel createNoDelayPanel() { |
152 |
setNoDelay = new JCheckBox(JMeterUtils.getResString("tcp_nodelay")); // $NON-NLS-1$ |
129 |
JLabel label = new JLabel(JMeterUtils.getResString("tcp_nodelay")); // $NON-NLS-1$ |
153 |
optionsPanel.add(setNoDelay); |
|
|
154 |
} |
130 |
|
155 |
|
131 |
setNoDelay = new JCheckBox(); |
156 |
private void addClosePortOption() { |
132 |
label.setLabelFor(setNoDelay); |
157 |
reUseConnection = new JCheckBox(JMeterUtils.getResString("reuseconnection"), true); //$NON-NLS-1$ |
|
|
158 |
reUseConnection.addItemListener(new ItemListener() { |
159 |
@Override |
160 |
public void itemStateChanged(final ItemEvent e) { |
161 |
if (e.getStateChange() == ItemEvent.SELECTED) { |
162 |
closeConnection.setEnabled(true); |
163 |
} else { |
164 |
closeConnection.setEnabled(false); |
165 |
closeConnection.setSelected(true); |
166 |
} |
167 |
} |
168 |
}); |
133 |
|
169 |
|
134 |
JPanel nodelayPanel = new JPanel(new BorderLayout(5, 0)); |
170 |
optionsPanel.add(reUseConnection); |
135 |
nodelayPanel.add(label, BorderLayout.WEST); |
|
|
136 |
nodelayPanel.add(setNoDelay, BorderLayout.CENTER); |
137 |
return nodelayPanel; |
138 |
} |
171 |
} |
139 |
|
172 |
|
140 |
private JPanel createClosePortPanel() { |
173 |
private void addCloseConnectionOption() { |
141 |
JLabel label = new JLabel(JMeterUtils.getResString("reuseconnection")); //$NON-NLS-1$ |
174 |
closeConnection = new JCheckBox(JMeterUtils.getResString("closeconnection"), false); //$NON-NLS-1$ |
142 |
|
175 |
optionsPanel.add(closeConnection); |
143 |
reUseConnection = new JCheckBox("", true); |
176 |
} |
144 |
label.setLabelFor(reUseConnection); |
|
|
145 |
|
177 |
|
146 |
JPanel closePortPanel = new JPanel(new BorderLayout(5, 0)); |
178 |
private void addSoLingerOption() { |
147 |
closePortPanel.add(label, BorderLayout.WEST); |
179 |
JLabel soLingerLable = new JLabel(JMeterUtils.getResString("solinger")); //$NON-NLS-1$ |
148 |
closePortPanel.add(reUseConnection, BorderLayout.CENTER); |
180 |
soLinger = new JTextField(5); // 5 columns size |
149 |
return closePortPanel; |
181 |
soLinger.setMaximumSize(new Dimension(50, 20)); |
|
|
182 |
soLingerLable.setLabelFor(soLinger); |
183 |
optionsPanel.add(soLingerLable); |
184 |
optionsPanel.add(soLinger); |
185 |
} |
186 |
|
187 |
private void addEolByteOption() { |
188 |
JLabel eolByteLabel = new JLabel(JMeterUtils.getResString("eolbyte")); //$NON-NLS-1$ |
189 |
eolByte = new JTextField(3); // 3 columns size |
190 |
eolByte.setMaximumSize(new Dimension(30, 20)); |
191 |
eolByteLabel.setLabelFor(eolByte); |
192 |
optionsPanel.add(eolByteLabel); |
193 |
optionsPanel.add(eolByte); |
150 |
} |
194 |
} |
151 |
|
195 |
|
152 |
private JPanel createRequestPanel() { |
196 |
private JPanel createRequestPanel() { |
153 |
JLabel reqLabel = new JLabel(JMeterUtils.getResString("tcp_request_data")); // $NON-NLS-1$ |
|
|
154 |
requestData = new JTextArea(3, 0); |
197 |
requestData = new JTextArea(3, 0); |
155 |
requestData.setLineWrap(true); |
198 |
requestData.setLineWrap(true); |
156 |
reqLabel.setLabelFor(requestData); |
|
|
157 |
|
199 |
|
158 |
JPanel reqDataPanel = new JPanel(new BorderLayout(5, 0)); |
200 |
final JPanel reqDataPanel = new VerticalPanel(); |
159 |
reqDataPanel.add(reqLabel, BorderLayout.WEST); |
201 |
reqDataPanel.setBorder(BorderFactory.createTitledBorder(BorderFactory.createEtchedBorder(), JMeterUtils.getResString("tcp_request_data"))); // $NON-NLS-1$ |
160 |
reqDataPanel.add(requestData, BorderLayout.CENTER); |
202 |
reqDataPanel.add(requestData); |
161 |
return reqDataPanel; |
203 |
return reqDataPanel; |
162 |
} |
204 |
} |
163 |
|
205 |
|
Lines 191-203
Link Here
|
191 |
mainPanel.add(classname); |
233 |
mainPanel.add(classname); |
192 |
mainPanel.add(serverPanel); |
234 |
mainPanel.add(serverPanel); |
193 |
|
235 |
|
194 |
HorizontalPanel optionsPanel = new HorizontalPanel(); |
236 |
optionsPanel = new HorizontalPanel(); |
195 |
optionsPanel.add(createClosePortPanel()); |
237 |
addClosePortOption(); |
196 |
optionsPanel.add(createNoDelayPanel()); |
238 |
addCloseConnectionOption(); |
|
|
239 |
addNoDelayOption(); |
240 |
addSoLingerOption(); |
241 |
addEolByteOption(); |
242 |
|
197 |
mainPanel.add(optionsPanel); |
243 |
mainPanel.add(optionsPanel); |
198 |
mainPanel.add(createRequestPanel()); |
244 |
mainPanel.add(createRequestPanel()); |
199 |
|
245 |
|
200 |
// mainPanel.add(createFilenamePanel()); |
246 |
// mainPanel.add(createFilenamePanel()); |
201 |
add(mainPanel, BorderLayout.CENTER); |
247 |
add(mainPanel, BorderLayout.CENTER); |
202 |
} |
248 |
} |
|
|
249 |
|
203 |
} |
250 |
} |