aboutsummaryrefslogtreecommitdiffstats
path: root/uitest/src/com/vaadin/tests/widgetset/client/RoundTripTesterConnector.java
blob: b22b3fc4b8463bf204de75dd0de45cfa412fac1b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 * Copyright 2000-2014 Vaadin Ltd.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.vaadin.tests.widgetset.client;

import java.util.ArrayList;
import java.util.List;

import com.google.gwt.core.client.Duration;
import com.google.gwt.user.client.ui.HTML;
import com.vaadin.client.ui.AbstractComponentConnector;
import com.vaadin.shared.ui.Connect;
import com.vaadin.tests.widgetset.server.RoundTripTester;

@Connect(RoundTripTester.class)
public class RoundTripTesterConnector extends AbstractComponentConnector {

    private double lastPrintedTime = -1;
    private int receivedPings = 0;
    private List<Double> throughputData = new ArrayList<Double>();
    private int payloadSize = 0;

    @Override
    protected void init() {
        super.init();
        registerRpc(RoundTripTesterRpc.class, new RoundTripTesterRpc() {

            @Override
            public void ping(int nr, String payload) {
                getRpcProxy(RoundTripTesterRpc.class).ping(nr + 1, payload);
                payloadSize = payload.length();

                double now = Duration.currentTimeMillis();
                if (lastPrintedTime == -1) {
                    lastPrintedTime = now;
                    return;
                }
                receivedPings++;

                if (now - lastPrintedTime > 1000) {
                    double roundtripsPerSecond = receivedPings
                            / (now - lastPrintedTime) * 1000;
                    throughputData.add(roundtripsPerSecond);
                    getWidget().setText(
                            roundtripsPerSecond + " roundtrips/second");

                    lastPrintedTime = now;
                    receivedPings = 0;
                }

            }

            @Override
            public void done() {
                String result = "Test results for payload of size "
                        + payloadSize + ":";
                double max = -1;
                double min = 1239482038939.0;
                double avg = 0;

                for (Double throughput : throughputData) {
                    if (throughput > max) {
                        max = throughput;
                    }
                    if (throughput < min) {
                        min = throughput;
                    }

                    avg += throughput;
                }
                avg /= throughputData.size();

                for (Double throughput : throughputData) {
                    result += "<br/>" + formatThroughput(throughput);
                }
                result += "<br/>Max: " + formatThroughput(max);
                result += "<br/>Min: " + formatThroughput(min);
                result += "<br/>Average: " + formatThroughput(avg);
                getWidget().setHTML(result);
                getRpcProxy(RoundTripTesterRpc.class).done();
            }

            private String formatThroughput(double throughput) {
                return throughput + " roundtrips / second";
            }
        });
    }

    @Override
    public HTML getWidget() {
        return (HTML) super.getWidget();
    }

}